TPTP Problem File: ITP218_4.p

View Solutions - Solve Problem

%------------------------------------------------------------------------------
% File     : ITP218_4 : TPTP v8.2.0. Released v8.0.0.
% Domain   : Interactive Theorem Proving
% Problem  : Sledgehammer problem VEBT_List_Assn 00019_000444
% 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    : 0062_VEBT_List_Assn_00019_000444 [Des22]

% Status   : Theorem
% Rating   : 1.00 v8.1.0
% Syntax   : Number of formulae    : 8522 (2890 unt;1272 typ;   0 def)
%            Number of atoms       : 13854 (6634 equ)
%            Maximal formula atoms :   22 (   1 avg)
%            Number of connectives : 13671 (1828   ~; 222   |;1097   &)
%                                         (1437 <=>;9087  =>;   0  <=;   0 <~>)
%            Maximal formula depth :   27 (   6 avg)
%            Maximal term depth    :   15 (   2 avg)
%            Number of FOOLs       :  486 ( 306 fml; 180 var)
%            Number of X terms     :  331 (   0  []; 320 ite;  11 let)
%            Number of types       :   14 (  13 usr)
%            Number of type conns  : 1186 ( 870   >; 316   *;   0   +;   0  <<)
%            Number of predicates  :  268 ( 265 usr;   2 prp; 0-7 aty)
%            Number of functors    : 1001 (1001 usr;  27 con; 0-7 aty)
%            Number of variables   : 27834 (25422   !; 505   ?;27834   :)
%                                         (1907  !>;   0  ?*;   0  @-;   0  @+)
% SPC      : TX1_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 16:49:10.721
%------------------------------------------------------------------------------
% Could-be-implicit typings (26)
tff(ty_t_Heap__Time__Monad_OHeap,type,
    heap_Time_Heap: $tType > $tType ).

tff(ty_t_Code__Numeral_Onatural,type,
    code_natural: $tType ).

tff(ty_t_Heap_Oheap_Oheap__ext,type,
    heap_ext: $tType > $tType ).

tff(ty_t_Product__Type_Ounit,type,
    product_unit: $tType ).

tff(ty_t_Product__Type_Oprod,type,
    product_prod: ( $tType * $tType ) > $tType ).

tff(ty_t_Multiset_Omultiset,type,
    multiset: $tType > $tType ).

tff(ty_t_Typerep_Otyperep,type,
    typerep: $tType ).

tff(ty_t_Assertions_Oassn,type,
    assn: $tType ).

tff(ty_t_Sum__Type_Osum,type,
    sum_sum: ( $tType * $tType ) > $tType ).

tff(ty_t_Option_Ooption,type,
    option: $tType > $tType ).

tff(ty_t_Filter_Ofilter,type,
    filter: $tType > $tType ).

tff(ty_t_String_Ochar,type,
    char: $tType ).

tff(ty_t_Heap_Oarray,type,
    array: $tType > $tType ).

tff(ty_t_List_Olist,type,
    list: $tType > $tType ).

tff(ty_t_Heap_Oref,type,
    ref: $tType > $tType ).

tff(ty_t_Set_Oset,type,
    set: $tType > $tType ).

tff(ty_t_Rat_Orat,type,
    rat: $tType ).

tff(ty_t_Num_Onum,type,
    num: $tType ).

tff(ty_t_Nat_Onat,type,
    nat: $tType ).

tff(ty_t_Int_Oint,type,
    int: $tType ).

tff(ty_t_itself,type,
    itself: $tType > $tType ).

tff(ty_t_fun,type,
    fun: ( $tType * $tType ) > $tType ).

tff(ty_tf_d,type,
    d: $tType ).

tff(ty_tf_c,type,
    c: $tType ).

tff(ty_tf_b,type,
    b: $tType ).

tff(ty_tf_a,type,
    a: $tType ).

% Explicit typings (1246)
tff(sy_cl_HOL_Otype,type,
    type: 
      !>[A: $tType] : $o ).

tff(sy_cl_Heap_Oheap,type,
    heap: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Odvd,type,
    dvd: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oone,type,
    one: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oidom,type,
    idom: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oring,type,
    ring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ozero,type,
    zero: 
      !>[A: $tType] : $o ).

tff(sy_cl_Num_Onumeral,type,
    numeral: 
      !>[A: $tType] : $o ).

tff(sy_cl_Power_Opower,type,
    power: 
      !>[A: $tType] : $o ).

tff(sy_cl_Fields_Ofield,type,
    field: 
      !>[A: $tType] : $o ).

tff(sy_cl_GCD_Oring__gcd,type,
    ring_gcd: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ominus,type,
    minus: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Otimes,type,
    times: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Oinf,type,
    inf: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oring__1,type,
    ring_1: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ouminus,type,
    uminus: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Obot,type,
    bot: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Oord,type,
    ord: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Otop,type,
    top: 
      !>[A: $tType] : $o ).

tff(sy_cl_Fields_Oinverse,type,
    inverse: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemiring,type,
    semiring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Nat_Oring__char__0,type,
    ring_char_0: 
      !>[A: $tType] : $o ).

tff(sy_cl_Num_Oneg__numeral,type,
    neg_numeral: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Oorder,type,
    order: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ocomm__ring,type,
    comm_ring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Omult__zero,type,
    mult_zero: 
      !>[A: $tType] : $o ).

tff(sy_cl_GCD_Osemiring__Gcd,type,
    semiring_Gcd: 
      !>[A: $tType] : $o ).

tff(sy_cl_GCD_Osemiring__gcd,type,
    semiring_gcd: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ogroup__add,type,
    group_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Olattice,type,
    lattice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Ono__bot,type,
    no_bot: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Ono__top,type,
    no_top: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemiring__0,type,
    semiring_0: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemiring__1,type,
    semiring_1: 
      !>[A: $tType] : $o ).

tff(sy_cl_Finite__Set_Ofinite,type,
    finite_finite: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Omonoid__add,type,
    monoid_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ocomm__ring__1,type,
    comm_ring_1: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Omonoid__mult,type,
    monoid_mult: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Olinorder,type,
    linorder: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Opreorder,type,
    preorder: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oidom__abs__sgn,type,
    idom_abs_sgn: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oordered__ring,type,
    ordered_ring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ozero__neq__one,type,
    zero_neq_one: 
      !>[A: $tType] : $o ).

tff(sy_cl_Enum_Ofinite__lattice,type,
    finite_lattice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Fields_Ofield__char__0,type,
    field_char_0: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oab__group__add,type,
    ab_group_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Nat_Osemiring__char__0,type,
    semiring_char_0: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Oorder__bot,type,
    order_bot: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Oorder__top,type,
    order_top: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Owellorder,type,
    wellorder: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ocomm__semiring,type,
    comm_semiring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ozero__less__one,type,
    zero_less_one: 
      !>[A: $tType] : $o ).

tff(sy_cl_Fields_Odivision__ring,type,
    division_ring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Osemigroup__add,type,
    semigroup_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Num_Osemiring__numeral,type,
    semiring_numeral: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemidom__divide,type,
    semidom_divide: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemidom__modulo,type,
    semidom_modulo: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Osemigroup__mult,type,
    semigroup_mult: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Odense__order,type,
    dense_order: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ocomm__semiring__0,type,
    comm_semiring_0: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ocomm__semiring__1,type,
    comm_semiring_1: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__idom,type,
    linordered_idom: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__ring,type,
    linordered_ring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemiring__modulo,type,
    semiring_modulo: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocomm__monoid__add,type,
    comm_monoid_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Parity_Osemiring__parity,type,
    semiring_parity: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oordered__ring__abs,type,
    ordered_ring_abs: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oordered__semiring,type,
    ordered_semiring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Fields_Olinordered__field,type,
    linordered_field: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oab__semigroup__add,type,
    ab_semigroup_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocomm__monoid__diff,type,
    comm_monoid_diff: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocomm__monoid__mult,type,
    comm_monoid_mult: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oalgebraic__semidom,type,
    algebraic_semidom: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oab__semigroup__mult,type,
    ab_semigroup_mult: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Obounded__lattice,type,
    bounded_lattice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Odistrib__lattice,type,
    distrib_lattice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Osemilattice__inf,type,
    semilattice_inf: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Osemilattice__sup,type,
    semilattice_sup: 
      !>[A: $tType] : $o ).

tff(sy_cl_Orderings_Odense__linorder,type,
    dense_linorder: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__semidom,type,
    linordered_semidom: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oordered__semiring__0,type,
    ordered_semiring_0: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__semiring,type,
    linordered_semiring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Complete__Partial__Order_Occpo,type,
    comple9053668089753744459l_ccpo: 
      !>[A: $tType] : $o ).

tff(sy_cl_Enum_Ofinite__distrib__lattice,type,
    finite8700451911770168679attice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocancel__semigroup__add,type,
    cancel_semigroup_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__ab__group__add,type,
    ordered_ab_group_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__semiring__1,type,
    linord6961819062388156250ring_1: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Onormalization__semidom,type,
    normal8620421768224518004emidom: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oordered__comm__semiring,type,
    ordere2520102378445227354miring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Bit__Operations_Osemiring__bits,type,
    bit_semiring_bits: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Obounded__lattice__bot,type,
    bounded_lattice_bot: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Obounded__lattice__top,type,
    bounded_lattice_top: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Ocomm__semiring__1__cancel,type,
    comm_s4317794764714335236cancel: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__ring__strict,type,
    linord4710134922213307826strict: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocancel__comm__monoid__add,type,
    cancel1802427076303600483id_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Oring__1__no__zero__divisors,type,
    ring_15535105094025558882visors: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocancel__ab__semigroup__add,type,
    cancel2418104881723323429up_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Olinordered__ab__group__add,type,
    linord5086331880401160121up_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__comm__monoid__add,type,
    ordere6911136660526730532id_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Archimedean__Field_Ofloor__ceiling,type,
    archim2362893244070406136eiling: 
      !>[A: $tType] : $o ).

tff(sy_cl_GCD_Osemiring__gcd__mult__normalize,type,
    semiri6843258321239162965malize: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__ab__group__add__abs,type,
    ordere166539214618696060dd_abs: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__ab__semigroup__add,type,
    ordere6658533253407199908up_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemiring__no__zero__divisors,type,
    semiri3467727345109120633visors: 
      !>[A: $tType] : $o ).

tff(sy_cl_Boolean__Algebras_Oboolean__algebra,type,
    boolea8198339166811842893lgebra: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__semiring__strict,type,
    linord8928482502909563296strict: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemidom__divide__unit__factor,type,
    semido2269285787275462019factor: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__nonzero__semiring,type,
    linord181362715937106298miring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Bit__Operations_Oring__bit__operations,type,
    bit_ri3973907225187159222ations: 
      !>[A: $tType] : $o ).

tff(sy_cl_Complete__Lattices_Ocomplete__lattice,type,
    comple6319245703460814977attice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Olinordered__ab__semigroup__add,type,
    linord4140545234300271783up_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__semiring__1__strict,type,
    linord715952674999750819strict: 
      !>[A: $tType] : $o ).

tff(sy_cl_Archimedean__Field_Oarchimedean__field,type,
    archim462609752435547400_field: 
      !>[A: $tType] : $o ).

tff(sy_cl_Complete__Lattices_Ocomplete__linorder,type,
    comple5582772986160207858norder: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Obounded__semilattice__inf__top,type,
    bounde4346867609351753570nf_top: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Obounded__semilattice__sup__bot,type,
    bounde4967611905675639751up_bot: 
      !>[A: $tType] : $o ).

tff(sy_cl_Euclidean__Division_Oeuclidean__semiring,type,
    euclid3725896446679973847miring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ocanonically__ordered__monoid__add,type,
    canoni5634975068530333245id_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__cancel__comm__monoid__add,type,
    ordere8940638589300402666id_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ostrict__ordered__comm__monoid__add,type,
    strict7427464778891057005id_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Olinordered__comm__semiring__strict,type,
    linord2810124833399127020strict: 
      !>[A: $tType] : $o ).

tff(sy_cl_Bit__Operations_Osemiring__bit__operations,type,
    bit_se359711467146920520ations: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__ab__semigroup__add__imp__le,type,
    ordere2412721322843649153imp_le: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__cancel__ab__semigroup__add,type,
    ordere580206878836729694up_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__cancel__comm__monoid__diff,type,
    ordere1170586879665033532d_diff: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Ostrict__ordered__ab__semigroup__add,type,
    strict9044650504122735259up_add: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Osemiring__no__zero__divisors__cancel,type,
    semiri6575147826004484403cancel: 
      !>[A: $tType] : $o ).

tff(sy_cl_Euclidean__Division_Oeuclidean__ring__cancel,type,
    euclid8851590272496341667cancel: 
      !>[A: $tType] : $o ).

tff(sy_cl_Divides_Ounique__euclidean__semiring__numeral,type,
    unique1627219031080169319umeral: 
      !>[A: $tType] : $o ).

tff(sy_cl_Complete__Lattices_Ocomplete__distrib__lattice,type,
    comple592849572758109894attice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Rings_Onormalization__semidom__multiplicative,type,
    normal6328177297339901930cative: 
      !>[A: $tType] : $o ).

tff(sy_cl_Euclidean__Division_Oeuclidean__semiring__cancel,type,
    euclid4440199948858584721cancel: 
      !>[A: $tType] : $o ).

tff(sy_cl_Euclidean__Division_Ounique__euclidean__semiring,type,
    euclid3128863361964157862miring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oordered__ab__semigroup__monoid__add__imp__le,type,
    ordere1937475149494474687imp_le: 
      !>[A: $tType] : $o ).

tff(sy_cl_Euclidean__Division_Ounique__euclidean__ring__with__nat,type,
    euclid8789492081693882211th_nat: 
      !>[A: $tType] : $o ).

tff(sy_cl_Euclidean__Division_Ounique__euclidean__semiring__with__nat,type,
    euclid5411537665997757685th_nat: 
      !>[A: $tType] : $o ).

tff(sy_cl_Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct,type,
    semiri1453513574482234551roduct: 
      !>[A: $tType] : $o ).

tff(sy_cl_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations,type,
    bit_un5681908812861735899ations: 
      !>[A: $tType] : $o ).

tff(sy_cl_Conditionally__Complete__Lattices_Oconditionally__complete__lattice,type,
    condit1219197933456340205attice: 
      !>[A: $tType] : $o ).

tff(sy_cl_Conditionally__Complete__Lattices_Oconditionally__complete__linorder,type,
    condit6923001295902523014norder: 
      !>[A: $tType] : $o ).

tff(sy_c_ATP_058Lamp__a____,type,
    aTP_Lamp_a: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__aa____,type,
    aTP_Lamp_aa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ab____,type,
    aTP_Lamp_ab: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ac____,type,
    aTP_Lamp_ac: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ad____,type,
    aTP_Lamp_ad: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ae____,type,
    aTP_Lamp_ae: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__af____,type,
    aTP_Lamp_af: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ag____,type,
    aTP_Lamp_ag: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ah____,type,
    aTP_Lamp_ah: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ai____,type,
    aTP_Lamp_ai: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__aj____,type,
    aTP_Lamp_aj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ak____,type,
    aTP_Lamp_ak: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__al____,type,
    aTP_Lamp_al: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__am____,type,
    aTP_Lamp_am: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__an____,type,
    aTP_Lamp_an: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ao____,type,
    aTP_Lamp_ao: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ap____,type,
    aTP_Lamp_ap: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__aq____,type,
    aTP_Lamp_aq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ar____,type,
    aTP_Lamp_ar: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__as____,type,
    aTP_Lamp_as: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__at____,type,
    aTP_Lamp_at: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__au____,type,
    aTP_Lamp_au: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__av____,type,
    aTP_Lamp_av: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__aw____,type,
    aTP_Lamp_aw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ax____,type,
    aTP_Lamp_ax: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ay____,type,
    aTP_Lamp_ay: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__az____,type,
    aTP_Lamp_az: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ba____,type,
    aTP_Lamp_ba: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bb____,type,
    aTP_Lamp_bb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bc____,type,
    aTP_Lamp_bc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bd____,type,
    aTP_Lamp_bd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__be____,type,
    aTP_Lamp_be: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bf____,type,
    aTP_Lamp_bf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bg____,type,
    aTP_Lamp_bg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bh____,type,
    aTP_Lamp_bh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bi____,type,
    aTP_Lamp_bi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bj____,type,
    aTP_Lamp_bj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bk____,type,
    aTP_Lamp_bk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bl____,type,
    aTP_Lamp_bl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bm____,type,
    aTP_Lamp_bm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bn____,type,
    aTP_Lamp_bn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bo____,type,
    aTP_Lamp_bo: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__bp____,type,
    aTP_Lamp_bp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bq____,type,
    aTP_Lamp_bq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__br____,type,
    aTP_Lamp_br: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bs____,type,
    aTP_Lamp_bs: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bt____,type,
    aTP_Lamp_bt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bu____,type,
    aTP_Lamp_bu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bv____,type,
    aTP_Lamp_bv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bw____,type,
    aTP_Lamp_bw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bx____,type,
    aTP_Lamp_bx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__by____,type,
    aTP_Lamp_by: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__bz____,type,
    aTP_Lamp_bz: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ca____,type,
    aTP_Lamp_ca: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__cb____,type,
    aTP_Lamp_cb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cc____,type,
    aTP_Lamp_cc: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__cd____,type,
    aTP_Lamp_cd: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ce____,type,
    aTP_Lamp_ce: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__cf____,type,
    aTP_Lamp_cf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cg____,type,
    aTP_Lamp_cg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ch____,type,
    aTP_Lamp_ch: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ci____,type,
    aTP_Lamp_ci: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cj____,type,
    aTP_Lamp_cj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ck____,type,
    aTP_Lamp_ck: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cl____,type,
    aTP_Lamp_cl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cm____,type,
    aTP_Lamp_cm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cn____,type,
    aTP_Lamp_cn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__co____,type,
    aTP_Lamp_co: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cp____,type,
    aTP_Lamp_cp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cq____,type,
    aTP_Lamp_cq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cr____,type,
    aTP_Lamp_cr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cs____,type,
    aTP_Lamp_cs: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ct____,type,
    aTP_Lamp_ct: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cu____,type,
    aTP_Lamp_cu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cv____,type,
    aTP_Lamp_cv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cw____,type,
    aTP_Lamp_cw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cx____,type,
    aTP_Lamp_cx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cy____,type,
    aTP_Lamp_cy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__cz____,type,
    aTP_Lamp_cz: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__da____,type,
    aTP_Lamp_da: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__db____,type,
    aTP_Lamp_db: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dc____,type,
    aTP_Lamp_dc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dd____,type,
    aTP_Lamp_dd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__de____,type,
    aTP_Lamp_de: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__df____,type,
    aTP_Lamp_df: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dg____,type,
    aTP_Lamp_dg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dh____,type,
    aTP_Lamp_dh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__di____,type,
    aTP_Lamp_di: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dj____,type,
    aTP_Lamp_dj: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__dk____,type,
    aTP_Lamp_dk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dl____,type,
    aTP_Lamp_dl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dm____,type,
    aTP_Lamp_dm: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__dn____,type,
    aTP_Lamp_dn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__do____,type,
    aTP_Lamp_do: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dp____,type,
    aTP_Lamp_dp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dq____,type,
    aTP_Lamp_dq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dr____,type,
    aTP_Lamp_dr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ds____,type,
    aTP_Lamp_ds: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dt____,type,
    aTP_Lamp_dt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__du____,type,
    aTP_Lamp_du: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dv____,type,
    aTP_Lamp_dv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dw____,type,
    aTP_Lamp_dw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dx____,type,
    aTP_Lamp_dx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dy____,type,
    aTP_Lamp_dy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__dz____,type,
    aTP_Lamp_dz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ea____,type,
    aTP_Lamp_ea: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__eb____,type,
    aTP_Lamp_eb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ec____,type,
    aTP_Lamp_ec: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ed____,type,
    aTP_Lamp_ed: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ee____,type,
    aTP_Lamp_ee: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ef____,type,
    aTP_Lamp_ef: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__eg____,type,
    aTP_Lamp_eg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__eh____,type,
    aTP_Lamp_eh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ei____,type,
    aTP_Lamp_ei: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ej____,type,
    aTP_Lamp_ej: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ek____,type,
    aTP_Lamp_ek: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__el____,type,
    aTP_Lamp_el: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__em____,type,
    aTP_Lamp_em: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__en____,type,
    aTP_Lamp_en: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__eo____,type,
    aTP_Lamp_eo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ep____,type,
    aTP_Lamp_ep: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__eq____,type,
    aTP_Lamp_eq: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__er____,type,
    aTP_Lamp_er: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__es____,type,
    aTP_Lamp_es: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__et____,type,
    aTP_Lamp_et: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__eu____,type,
    aTP_Lamp_eu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ev____,type,
    aTP_Lamp_ev: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ew____,type,
    aTP_Lamp_ew: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ex____,type,
    aTP_Lamp_ex: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ey____,type,
    aTP_Lamp_ey: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ez____,type,
    aTP_Lamp_ez: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fa____,type,
    aTP_Lamp_fa: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fb____,type,
    aTP_Lamp_fb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fc____,type,
    aTP_Lamp_fc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fd____,type,
    aTP_Lamp_fd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fe____,type,
    aTP_Lamp_fe: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ff____,type,
    aTP_Lamp_ff: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fg____,type,
    aTP_Lamp_fg: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fh____,type,
    aTP_Lamp_fh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fi____,type,
    aTP_Lamp_fi: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fj____,type,
    aTP_Lamp_fj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fk____,type,
    aTP_Lamp_fk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fl____,type,
    aTP_Lamp_fl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fm____,type,
    aTP_Lamp_fm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fn____,type,
    aTP_Lamp_fn: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fo____,type,
    aTP_Lamp_fo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fp____,type,
    aTP_Lamp_fp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fq____,type,
    aTP_Lamp_fq: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fr____,type,
    aTP_Lamp_fr: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__fs____,type,
    aTP_Lamp_fs: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ft____,type,
    aTP_Lamp_ft: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fu____,type,
    aTP_Lamp_fu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fv____,type,
    aTP_Lamp_fv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fw____,type,
    aTP_Lamp_fw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fx____,type,
    aTP_Lamp_fx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fy____,type,
    aTP_Lamp_fy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__fz____,type,
    aTP_Lamp_fz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ga____,type,
    aTP_Lamp_ga: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gb____,type,
    aTP_Lamp_gb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gc____,type,
    aTP_Lamp_gc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gd____,type,
    aTP_Lamp_gd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ge____,type,
    aTP_Lamp_ge: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gf____,type,
    aTP_Lamp_gf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gg____,type,
    aTP_Lamp_gg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gh____,type,
    aTP_Lamp_gh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gi____,type,
    aTP_Lamp_gi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gj____,type,
    aTP_Lamp_gj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gk____,type,
    aTP_Lamp_gk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gl____,type,
    aTP_Lamp_gl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gm____,type,
    aTP_Lamp_gm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gn____,type,
    aTP_Lamp_gn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__go____,type,
    aTP_Lamp_go: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gp____,type,
    aTP_Lamp_gp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gq____,type,
    aTP_Lamp_gq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gr____,type,
    aTP_Lamp_gr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gs____,type,
    aTP_Lamp_gs: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gt____,type,
    aTP_Lamp_gt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gu____,type,
    aTP_Lamp_gu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gv____,type,
    aTP_Lamp_gv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gw____,type,
    aTP_Lamp_gw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gx____,type,
    aTP_Lamp_gx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gy____,type,
    aTP_Lamp_gy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__gz____,type,
    aTP_Lamp_gz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ha____,type,
    aTP_Lamp_ha: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hb____,type,
    aTP_Lamp_hb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hc____,type,
    aTP_Lamp_hc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hd____,type,
    aTP_Lamp_hd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__he____,type,
    aTP_Lamp_he: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hf____,type,
    aTP_Lamp_hf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hg____,type,
    aTP_Lamp_hg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hh____,type,
    aTP_Lamp_hh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hi____,type,
    aTP_Lamp_hi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hj____,type,
    aTP_Lamp_hj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hk____,type,
    aTP_Lamp_hk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hl____,type,
    aTP_Lamp_hl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hm____,type,
    aTP_Lamp_hm: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__hn____,type,
    aTP_Lamp_hn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ho____,type,
    aTP_Lamp_ho: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__hp____,type,
    aTP_Lamp_hp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hq____,type,
    aTP_Lamp_hq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hr____,type,
    aTP_Lamp_hr: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__hs____,type,
    aTP_Lamp_hs: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ht____,type,
    aTP_Lamp_ht: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hu____,type,
    aTP_Lamp_hu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hv____,type,
    aTP_Lamp_hv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hw____,type,
    aTP_Lamp_hw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hx____,type,
    aTP_Lamp_hx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hy____,type,
    aTP_Lamp_hy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hz____,type,
    aTP_Lamp_hz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ia____,type,
    aTP_Lamp_ia: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ib____,type,
    aTP_Lamp_ib: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ic____,type,
    aTP_Lamp_ic: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__id____,type,
    aTP_Lamp_id: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ie____,type,
    aTP_Lamp_ie: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__if____,type,
    aTP_Lamp_if: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ig____,type,
    aTP_Lamp_ig: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ih____,type,
    aTP_Lamp_ih: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ii____,type,
    aTP_Lamp_ii: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ij____,type,
    aTP_Lamp_ij: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ik____,type,
    aTP_Lamp_ik: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__il____,type,
    aTP_Lamp_il: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__im____,type,
    aTP_Lamp_im: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__in____,type,
    aTP_Lamp_in: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__io____,type,
    aTP_Lamp_io: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ip____,type,
    aTP_Lamp_ip: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__iq____,type,
    aTP_Lamp_iq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ir____,type,
    aTP_Lamp_ir: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__is____,type,
    aTP_Lamp_is: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__it____,type,
    aTP_Lamp_it: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__iu____,type,
    aTP_Lamp_iu: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__iv____,type,
    aTP_Lamp_iv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__iw____,type,
    aTP_Lamp_iw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ix____,type,
    aTP_Lamp_ix: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__iy____,type,
    aTP_Lamp_iy: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__iz____,type,
    aTP_Lamp_iz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ja____,type,
    aTP_Lamp_ja: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jb____,type,
    aTP_Lamp_jb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jc____,type,
    aTP_Lamp_jc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jd____,type,
    aTP_Lamp_jd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__je____,type,
    aTP_Lamp_je: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jf____,type,
    aTP_Lamp_jf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jg____,type,
    aTP_Lamp_jg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jh____,type,
    aTP_Lamp_jh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ji____,type,
    aTP_Lamp_ji: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jj____,type,
    aTP_Lamp_jj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jk____,type,
    aTP_Lamp_jk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jl____,type,
    aTP_Lamp_jl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jm____,type,
    aTP_Lamp_jm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jn____,type,
    aTP_Lamp_jn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jo____,type,
    aTP_Lamp_jo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jp____,type,
    aTP_Lamp_jp: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__jq____,type,
    aTP_Lamp_jq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jr____,type,
    aTP_Lamp_jr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__js____,type,
    aTP_Lamp_js: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jt____,type,
    aTP_Lamp_jt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ju____,type,
    aTP_Lamp_ju: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jv____,type,
    aTP_Lamp_jv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jw____,type,
    aTP_Lamp_jw: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__jx____,type,
    aTP_Lamp_jx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__jy____,type,
    aTP_Lamp_jy: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__jz____,type,
    aTP_Lamp_jz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ka____,type,
    aTP_Lamp_ka: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kb____,type,
    aTP_Lamp_kb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kc____,type,
    aTP_Lamp_kc: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__kd____,type,
    aTP_Lamp_kd: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ke____,type,
    aTP_Lamp_ke: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__kf____,type,
    aTP_Lamp_kf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kg____,type,
    aTP_Lamp_kg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kh____,type,
    aTP_Lamp_kh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ki____,type,
    aTP_Lamp_ki: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kj____,type,
    aTP_Lamp_kj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kk____,type,
    aTP_Lamp_kk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kl____,type,
    aTP_Lamp_kl: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__km____,type,
    aTP_Lamp_km: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__kn____,type,
    aTP_Lamp_kn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ko____,type,
    aTP_Lamp_ko: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kp____,type,
    aTP_Lamp_kp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kq____,type,
    aTP_Lamp_kq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kr____,type,
    aTP_Lamp_kr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ks____,type,
    aTP_Lamp_ks: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__kt____,type,
    aTP_Lamp_kt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ku____,type,
    aTP_Lamp_ku: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__kv____,type,
    aTP_Lamp_kv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kw____,type,
    aTP_Lamp_kw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kx____,type,
    aTP_Lamp_kx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ky____,type,
    aTP_Lamp_ky: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__kz____,type,
    aTP_Lamp_kz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__la____,type,
    aTP_Lamp_la: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__lb____,type,
    aTP_Lamp_lb: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__lc____,type,
    aTP_Lamp_lc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ld____,type,
    aTP_Lamp_ld: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__le____,type,
    aTP_Lamp_le: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lf____,type,
    aTP_Lamp_lf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lg____,type,
    aTP_Lamp_lg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lh____,type,
    aTP_Lamp_lh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__li____,type,
    aTP_Lamp_li: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lj____,type,
    aTP_Lamp_lj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lk____,type,
    aTP_Lamp_lk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ll____,type,
    aTP_Lamp_ll: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lm____,type,
    aTP_Lamp_lm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ln____,type,
    aTP_Lamp_ln: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lo____,type,
    aTP_Lamp_lo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lp____,type,
    aTP_Lamp_lp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lq____,type,
    aTP_Lamp_lq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lr____,type,
    aTP_Lamp_lr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ls____,type,
    aTP_Lamp_ls: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lt____,type,
    aTP_Lamp_lt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lu____,type,
    aTP_Lamp_lu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lv____,type,
    aTP_Lamp_lv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lw____,type,
    aTP_Lamp_lw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__lx____,type,
    aTP_Lamp_lx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ly____,type,
    aTP_Lamp_ly: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__lz____,type,
    aTP_Lamp_lz: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ma____,type,
    aTP_Lamp_ma: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mb____,type,
    aTP_Lamp_mb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mc____,type,
    aTP_Lamp_mc: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__md____,type,
    aTP_Lamp_md: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__me____,type,
    aTP_Lamp_me: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mf____,type,
    aTP_Lamp_mf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mg____,type,
    aTP_Lamp_mg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mh____,type,
    aTP_Lamp_mh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mi____,type,
    aTP_Lamp_mi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mj____,type,
    aTP_Lamp_mj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mk____,type,
    aTP_Lamp_mk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ml____,type,
    aTP_Lamp_ml: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mm____,type,
    aTP_Lamp_mm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mn____,type,
    aTP_Lamp_mn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mo____,type,
    aTP_Lamp_mo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mp____,type,
    aTP_Lamp_mp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mq____,type,
    aTP_Lamp_mq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mr____,type,
    aTP_Lamp_mr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ms____,type,
    aTP_Lamp_ms: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__mt____,type,
    aTP_Lamp_mt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mu____,type,
    aTP_Lamp_mu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mv____,type,
    aTP_Lamp_mv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mw____,type,
    aTP_Lamp_mw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mx____,type,
    aTP_Lamp_mx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__my____,type,
    aTP_Lamp_my: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__mz____,type,
    aTP_Lamp_mz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__na____,type,
    aTP_Lamp_na: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nb____,type,
    aTP_Lamp_nb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nc____,type,
    aTP_Lamp_nc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nd____,type,
    aTP_Lamp_nd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ne____,type,
    aTP_Lamp_ne: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nf____,type,
    aTP_Lamp_nf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ng____,type,
    aTP_Lamp_ng: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nh____,type,
    aTP_Lamp_nh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ni____,type,
    aTP_Lamp_ni: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nj____,type,
    aTP_Lamp_nj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nk____,type,
    aTP_Lamp_nk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nl____,type,
    aTP_Lamp_nl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nm____,type,
    aTP_Lamp_nm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nn____,type,
    aTP_Lamp_nn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__no____,type,
    aTP_Lamp_no: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__np____,type,
    aTP_Lamp_np: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nq____,type,
    aTP_Lamp_nq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nr____,type,
    aTP_Lamp_nr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ns____,type,
    aTP_Lamp_ns: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nt____,type,
    aTP_Lamp_nt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nu____,type,
    aTP_Lamp_nu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nv____,type,
    aTP_Lamp_nv: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__nw____,type,
    aTP_Lamp_nw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nx____,type,
    aTP_Lamp_nx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ny____,type,
    aTP_Lamp_ny: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__nz____,type,
    aTP_Lamp_nz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oa____,type,
    aTP_Lamp_oa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ob____,type,
    aTP_Lamp_ob: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__oc____,type,
    aTP_Lamp_oc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__od____,type,
    aTP_Lamp_od: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__oe____,type,
    aTP_Lamp_oe: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__of____,type,
    aTP_Lamp_of: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__og____,type,
    aTP_Lamp_og: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oh____,type,
    aTP_Lamp_oh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oi____,type,
    aTP_Lamp_oi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oj____,type,
    aTP_Lamp_oj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ok____,type,
    aTP_Lamp_ok: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ol____,type,
    aTP_Lamp_ol: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__om____,type,
    aTP_Lamp_om: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__on____,type,
    aTP_Lamp_on: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oo____,type,
    aTP_Lamp_oo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__op____,type,
    aTP_Lamp_op: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oq____,type,
    aTP_Lamp_oq: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__or____,type,
    aTP_Lamp_or: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__os____,type,
    aTP_Lamp_os: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ot____,type,
    aTP_Lamp_ot: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ou____,type,
    aTP_Lamp_ou: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ov____,type,
    aTP_Lamp_ov: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ow____,type,
    aTP_Lamp_ow: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ox____,type,
    aTP_Lamp_ox: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__oy____,type,
    aTP_Lamp_oy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oz____,type,
    aTP_Lamp_oz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pa____,type,
    aTP_Lamp_pa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pb____,type,
    aTP_Lamp_pb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pc____,type,
    aTP_Lamp_pc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pd____,type,
    aTP_Lamp_pd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pe____,type,
    aTP_Lamp_pe: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pf____,type,
    aTP_Lamp_pf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pg____,type,
    aTP_Lamp_pg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ph____,type,
    aTP_Lamp_ph: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pi____,type,
    aTP_Lamp_pi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pj____,type,
    aTP_Lamp_pj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pk____,type,
    aTP_Lamp_pk: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__pl____,type,
    aTP_Lamp_pl: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__pm____,type,
    aTP_Lamp_pm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pn____,type,
    aTP_Lamp_pn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__po____,type,
    aTP_Lamp_po: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pp____,type,
    aTP_Lamp_pp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pq____,type,
    aTP_Lamp_pq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pr____,type,
    aTP_Lamp_pr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ps____,type,
    aTP_Lamp_ps: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pt____,type,
    aTP_Lamp_pt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pu____,type,
    aTP_Lamp_pu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pv____,type,
    aTP_Lamp_pv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pw____,type,
    aTP_Lamp_pw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__px____,type,
    aTP_Lamp_px: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__py____,type,
    aTP_Lamp_py: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pz____,type,
    aTP_Lamp_pz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qa____,type,
    aTP_Lamp_qa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qb____,type,
    aTP_Lamp_qb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qc____,type,
    aTP_Lamp_qc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qd____,type,
    aTP_Lamp_qd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qe____,type,
    aTP_Lamp_qe: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qf____,type,
    aTP_Lamp_qf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qg____,type,
    aTP_Lamp_qg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qh____,type,
    aTP_Lamp_qh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qi____,type,
    aTP_Lamp_qi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qj____,type,
    aTP_Lamp_qj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qk____,type,
    aTP_Lamp_qk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ql____,type,
    aTP_Lamp_ql: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qm____,type,
    aTP_Lamp_qm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qn____,type,
    aTP_Lamp_qn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qo____,type,
    aTP_Lamp_qo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qp____,type,
    aTP_Lamp_qp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qq____,type,
    aTP_Lamp_qq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qr____,type,
    aTP_Lamp_qr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qs____,type,
    aTP_Lamp_qs: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qt____,type,
    aTP_Lamp_qt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qu____,type,
    aTP_Lamp_qu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qv____,type,
    aTP_Lamp_qv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qw____,type,
    aTP_Lamp_qw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qx____,type,
    aTP_Lamp_qx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qy____,type,
    aTP_Lamp_qy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__qz____,type,
    aTP_Lamp_qz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ra____,type,
    aTP_Lamp_ra: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rb____,type,
    aTP_Lamp_rb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rc____,type,
    aTP_Lamp_rc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rd____,type,
    aTP_Lamp_rd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__re____,type,
    aTP_Lamp_re: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rf____,type,
    aTP_Lamp_rf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rg____,type,
    aTP_Lamp_rg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rh____,type,
    aTP_Lamp_rh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ri____,type,
    aTP_Lamp_ri: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rj____,type,
    aTP_Lamp_rj: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__rk____,type,
    aTP_Lamp_rk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rl____,type,
    aTP_Lamp_rl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rm____,type,
    aTP_Lamp_rm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rn____,type,
    aTP_Lamp_rn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ro____,type,
    aTP_Lamp_ro: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rp____,type,
    aTP_Lamp_rp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rq____,type,
    aTP_Lamp_rq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rr____,type,
    aTP_Lamp_rr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rs____,type,
    aTP_Lamp_rs: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__rt____,type,
    aTP_Lamp_rt: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ru____,type,
    aTP_Lamp_ru: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__rv____,type,
    aTP_Lamp_rv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rw____,type,
    aTP_Lamp_rw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rx____,type,
    aTP_Lamp_rx: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ry____,type,
    aTP_Lamp_ry: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__rz____,type,
    aTP_Lamp_rz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sa____,type,
    aTP_Lamp_sa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sb____,type,
    aTP_Lamp_sb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sc____,type,
    aTP_Lamp_sc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sd____,type,
    aTP_Lamp_sd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__se____,type,
    aTP_Lamp_se: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sf____,type,
    aTP_Lamp_sf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sg____,type,
    aTP_Lamp_sg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sh____,type,
    aTP_Lamp_sh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__si____,type,
    aTP_Lamp_si: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sj____,type,
    aTP_Lamp_sj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sk____,type,
    aTP_Lamp_sk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sl____,type,
    aTP_Lamp_sl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sm____,type,
    aTP_Lamp_sm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sn____,type,
    aTP_Lamp_sn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__so____,type,
    aTP_Lamp_so: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sp____,type,
    aTP_Lamp_sp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sq____,type,
    aTP_Lamp_sq: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__sr____,type,
    aTP_Lamp_sr: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ss____,type,
    aTP_Lamp_ss: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__st____,type,
    aTP_Lamp_st: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__su____,type,
    aTP_Lamp_su: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sv____,type,
    aTP_Lamp_sv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sw____,type,
    aTP_Lamp_sw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sx____,type,
    aTP_Lamp_sx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sy____,type,
    aTP_Lamp_sy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__sz____,type,
    aTP_Lamp_sz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ta____,type,
    aTP_Lamp_ta: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tb____,type,
    aTP_Lamp_tb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tc____,type,
    aTP_Lamp_tc: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__td____,type,
    aTP_Lamp_td: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__te____,type,
    aTP_Lamp_te: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tf____,type,
    aTP_Lamp_tf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tg____,type,
    aTP_Lamp_tg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__th____,type,
    aTP_Lamp_th: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ti____,type,
    aTP_Lamp_ti: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tj____,type,
    aTP_Lamp_tj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tk____,type,
    aTP_Lamp_tk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tl____,type,
    aTP_Lamp_tl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tm____,type,
    aTP_Lamp_tm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tn____,type,
    aTP_Lamp_tn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__to____,type,
    aTP_Lamp_to: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__tp____,type,
    aTP_Lamp_tp: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__tq____,type,
    aTP_Lamp_tq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tr____,type,
    aTP_Lamp_tr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ts____,type,
    aTP_Lamp_ts: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__tt____,type,
    aTP_Lamp_tt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tu____,type,
    aTP_Lamp_tu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tv____,type,
    aTP_Lamp_tv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tw____,type,
    aTP_Lamp_tw: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__tx____,type,
    aTP_Lamp_tx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ty____,type,
    aTP_Lamp_ty: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__tz____,type,
    aTP_Lamp_tz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ua____,type,
    aTP_Lamp_ua: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ub____,type,
    aTP_Lamp_ub: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__uc____,type,
    aTP_Lamp_uc: 
      !>[A: $tType,B: $tType] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ud____,type,
    aTP_Lamp_ud: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ue____,type,
    aTP_Lamp_ue: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uf____,type,
    aTP_Lamp_uf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ug____,type,
    aTP_Lamp_ug: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uh____,type,
    aTP_Lamp_uh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ui____,type,
    aTP_Lamp_ui: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uj____,type,
    aTP_Lamp_uj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uk____,type,
    aTP_Lamp_uk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ul____,type,
    aTP_Lamp_ul: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__um____,type,
    aTP_Lamp_um: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__un____,type,
    aTP_Lamp_un: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uo____,type,
    aTP_Lamp_uo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__up____,type,
    aTP_Lamp_up: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uq____,type,
    aTP_Lamp_uq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ur____,type,
    aTP_Lamp_ur: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_Archimedean__Field_Oceiling,type,
    archimedean_ceiling: 
      !>[A: $tType] : ( A > int ) ).

tff(sy_c_Archimedean__Field_Ofloor__ceiling__class_Ofloor,type,
    archim6421214686448440834_floor: 
      !>[A: $tType] : ( A > int ) ).

tff(sy_c_Archimedean__Field_Ofrac,type,
    archimedean_frac: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Archimedean__Field_Oround,type,
    archimedean_round: 
      !>[A: $tType] : ( A > int ) ).

tff(sy_c_Array__Time_Ofreeze,type,
    array_freeze: 
      !>[A: $tType] : ( array(A) > heap_Time_Heap(list(A)) ) ).

tff(sy_c_Array__Time_Oget,type,
    array_get: 
      !>[A: $tType] : ( ( heap_ext(product_unit) * array(A) ) > list(A) ) ).

tff(sy_c_Array__Time_Olen,type,
    array_len: 
      !>[A: $tType] : ( array(A) > heap_Time_Heap(nat) ) ).

tff(sy_c_Array__Time_Omake,type,
    array_make: 
      !>[A: $tType] : ( ( nat * fun(nat,A) ) > heap_Time_Heap(array(A)) ) ).

tff(sy_c_Array__Time_Onew,type,
    array_new: 
      !>[A: $tType] : ( ( nat * A ) > heap_Time_Heap(array(A)) ) ).

tff(sy_c_Array__Time_Onth,type,
    array_nth: 
      !>[A: $tType] : ( ( array(A) * nat ) > heap_Time_Heap(A) ) ).

tff(sy_c_Array__Time_Oof__list,type,
    array_of_list: 
      !>[A: $tType] : ( list(A) > heap_Time_Heap(array(A)) ) ).

tff(sy_c_Array__Time_Oset,type,
    array_set: 
      !>[A: $tType] : ( ( array(A) * list(A) * heap_ext(product_unit) ) > heap_ext(product_unit) ) ).

tff(sy_c_Array__Time_Oupd,type,
    array_upd: 
      !>[A: $tType] : ( ( nat * A * array(A) ) > heap_Time_Heap(array(A)) ) ).

tff(sy_c_Assertions_Oassn_OAbs__assn,type,
    abs_assn: fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn) ).

tff(sy_c_Assertions_Oassn_ORep__assn,type,
    rep_assn: fun(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o)) ).

tff(sy_c_Assertions_Oentails,type,
    entails: fun(assn,fun(assn,$o)) ).

tff(sy_c_Assertions_Oentailst,type,
    entailst: ( assn * assn ) > $o ).

tff(sy_c_Assertions_Oex__assn,type,
    ex_assn: 
      !>[A: $tType] : ( fun(A,assn) > assn ) ).

tff(sy_c_Assertions_Oin__range,type,
    in_range: fun(product_prod(heap_ext(product_unit),set(nat)),$o) ).

tff(sy_c_Assertions_Oin__range__rel,type,
    in_range_rel: fun(product_prod(heap_ext(product_unit),set(nat)),fun(product_prod(heap_ext(product_unit),set(nat)),$o)) ).

tff(sy_c_Assertions_Ois__pure__assn,type,
    is_pure_assn: assn > $o ).

tff(sy_c_Assertions_Oone__assn__raw,type,
    one_assn_raw: fun(product_prod(heap_ext(product_unit),set(nat)),$o) ).

tff(sy_c_Assertions_Oone__assn__raw__rel,type,
    one_assn_raw_rel: fun(product_prod(heap_ext(product_unit),set(nat)),fun(product_prod(heap_ext(product_unit),set(nat)),$o)) ).

tff(sy_c_Assertions_Oprecise,type,
    precise: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,assn)) > $o ) ).

tff(sy_c_Assertions_Oproper,type,
    proper: fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o) ).

tff(sy_c_Assertions_Opure__assn,type,
    pure_assn: $o > assn ).

tff(sy_c_Assertions_Opure__assn__raw,type,
    pure_assn_raw: 
      !>[A: $tType,B: $tType] : ( $o > fun(product_prod(A,set(B)),$o) ) ).

tff(sy_c_Assertions_Opure__assn__raw__rel,type,
    pure_assn_raw_rel: 
      !>[A: $tType,B: $tType] : fun(product_prod($o,product_prod(A,set(B))),fun(product_prod($o,product_prod(A,set(B))),$o)) ).

tff(sy_c_Assertions_OrelH,type,
    relH: ( set(nat) * heap_ext(product_unit) * heap_ext(product_unit) ) > $o ).

tff(sy_c_Assertions_Osnga__assn,type,
    snga_assn: 
      !>[A: $tType] : ( ( array(A) * list(A) ) > assn ) ).

tff(sy_c_Assertions_Osnga__assn__raw,type,
    snga_assn_raw: 
      !>[A: $tType] : ( ( array(A) * list(A) ) > fun(product_prod(heap_ext(product_unit),set(nat)),$o) ) ).

tff(sy_c_Assertions_Osnga__assn__raw__rel,type,
    snga_assn_raw_rel: 
      !>[A: $tType] : fun(product_prod(array(A),product_prod(list(A),product_prod(heap_ext(product_unit),set(nat)))),fun(product_prod(array(A),product_prod(list(A),product_prod(heap_ext(product_unit),set(nat)))),$o)) ).

tff(sy_c_Assertions_Osngr__assn,type,
    sngr_assn: 
      !>[A: $tType] : ( ( ref(A) * A ) > assn ) ).

tff(sy_c_Assertions_Osngr__assn__raw,type,
    sngr_assn_raw: 
      !>[A: $tType] : ( ( ref(A) * A ) > fun(product_prod(heap_ext(product_unit),set(nat)),$o) ) ).

tff(sy_c_Assertions_Osngr__assn__raw__rel,type,
    sngr_assn_raw_rel: 
      !>[A: $tType] : fun(product_prod(ref(A),product_prod(A,product_prod(heap_ext(product_unit),set(nat)))),fun(product_prod(ref(A),product_prod(A,product_prod(heap_ext(product_unit),set(nat)))),$o)) ).

tff(sy_c_Assertions_Otimes__assn__raw,type,
    times_assn_raw: ( fun(product_prod(heap_ext(product_unit),set(nat)),$o) * fun(product_prod(heap_ext(product_unit),set(nat)),$o) ) > fun(product_prod(heap_ext(product_unit),set(nat)),$o) ).

tff(sy_c_Assertions_Otimes__assn__raw__rel,type,
    times_assn_raw_rel: fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),$o)) ).

tff(sy_c_Assertions_Owand__assn,type,
    wand_assn: ( assn * assn ) > assn ).

tff(sy_c_Assertions_Owand__raw,type,
    wand_raw: ( fun(product_prod(heap_ext(product_unit),set(nat)),$o) * fun(product_prod(heap_ext(product_unit),set(nat)),$o) ) > fun(product_prod(heap_ext(product_unit),set(nat)),$o) ).

tff(sy_c_Assertions_Owand__raw__rel,type,
    wand_raw_rel: fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),$o)) ).

tff(sy_c_Automation_OFI,type,
    fi: ( list(product_prod(assn,assn)) * assn * assn * assn * assn * assn ) > $o ).

tff(sy_c_Automation_OFI__QUERY,type,
    fI_QUERY: ( assn * assn * assn ) > $o ).

tff(sy_c_Automation_OFI__RESULT,type,
    fI_RESULT: ( list(product_prod(assn,assn)) * assn * assn * assn ) > $o ).

tff(sy_c_Automation_OSLN,type,
    sln: assn ).

tff(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(fun(A,B),fun(A,B))) ) ).

tff(sy_c_BNF__Cardinal__Arithmetic_Oczero,type,
    bNF_Cardinal_czero: 
      !>[A: $tType] : set(product_prod(A,A)) ).

tff(sy_c_BNF__Cardinal__Order__Relation_Ocard__of,type,
    bNF_Ca6860139660246222851ard_of: 
      !>[A: $tType] : ( set(A) > set(product_prod(A,A)) ) ).

tff(sy_c_BNF__Cardinal__Order__Relation_Ocard__order__on,type,
    bNF_Ca8970107618336181345der_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_BNF__Cardinal__Order__Relation_OnatLeq,type,
    bNF_Ca8665028551170535155natLeq: set(product_prod(nat,nat)) ).

tff(sy_c_BNF__Composition_Oid__bnf,type,
    bNF_id_bnf: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_BNF__Def_Orel__fun,type,
    bNF_rel_fun: 
      !>[A: $tType,C: $tType,B: $tType,D: $tType] : ( ( fun(A,fun(C,$o)) * fun(B,fun(D,$o)) ) > fun(fun(A,B),fun(fun(C,D),$o)) ) ).

tff(sy_c_BNF__Def_Orel__set,type,
    bNF_rel_set: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(set(A),fun(set(B),$o)) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OShift,type,
    bNF_Greatest_Shift: 
      !>[A: $tType] : ( ( set(list(A)) * A ) > set(list(A)) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OSucc,type,
    bNF_Greatest_Succ: 
      !>[A: $tType] : ( ( set(list(A)) * list(A) ) > set(A) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_Oshift,type,
    bNF_Greatest_shift: 
      !>[A: $tType,B: $tType] : ( ( fun(list(A),B) * A * list(A) ) > B ) ).

tff(sy_c_BNF__Wellorder__Constructions_OFunc,type,
    bNF_Wellorder_Func: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(B) ) > set(fun(A,B)) ) ).

tff(sy_c_BNF__Wellorder__Constructions_OFunc__map,type,
    bNF_We4925052301507509544nc_map: 
      !>[B: $tType,C: $tType,A: $tType,D: $tType] : ( ( set(B) * fun(C,A) * fun(B,D) ) > fun(fun(D,C),fun(B,A)) ) ).

tff(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))) ) ).

tff(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)))) ).

tff(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)))) ).

tff(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)))) ).

tff(sy_c_BNF__Wellorder__Embedding_Oembed,type,
    bNF_Wellorder_embed: 
      !>[A: $tType,A2: $tType] : ( ( set(product_prod(A,A)) * set(product_prod(A2,A2)) * fun(A,A2) ) > $o ) ).

tff(sy_c_BNF__Wellorder__Embedding_OembedS,type,
    bNF_Wellorder_embedS: 
      !>[A: $tType,A2: $tType] : ( ( set(product_prod(A,A)) * set(product_prod(A2,A2)) * fun(A,A2) ) > $o ) ).

tff(sy_c_BNF__Wellorder__Embedding_Oiso,type,
    bNF_Wellorder_iso: 
      !>[A: $tType,A2: $tType] : ( ( set(product_prod(A,A)) * set(product_prod(A2,A2)) * fun(A,A2) ) > $o ) ).

tff(sy_c_BNF__Wellorder__Relation_Owo__rel,type,
    bNF_Wellorder_wo_rel: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_BNF__Wellorder__Relation_Owo__rel_OisMinim,type,
    bNF_We4791949203932849705sMinim: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) * A ) > $o ) ).

tff(sy_c_BNF__Wellorder__Relation_Owo__rel_Omax2,type,
    bNF_We1388413361240627857o_max2: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * A * A ) > A ) ).

tff(sy_c_BNF__Wellorder__Relation_Owo__rel_Ominim,type,
    bNF_We6954850376910717587_minim: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) ) > A ) ).

tff(sy_c_BNF__Wellorder__Relation_Owo__rel_Osuc,type,
    bNF_Wellorder_wo_suc: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) ) > A ) ).

tff(sy_c_Basic__BNFs_Ofsts,type,
    basic_fsts: 
      !>[A: $tType,B: $tType] : ( product_prod(A,B) > set(A) ) ).

tff(sy_c_Basic__BNFs_Orel__prod,type,
    basic_rel_prod: 
      !>[A: $tType,B: $tType,C: $tType,D: $tType] : ( ( fun(A,fun(B,$o)) * fun(C,fun(D,$o)) ) > fun(product_prod(A,C),fun(product_prod(B,D),$o)) ) ).

tff(sy_c_Basic__BNFs_Osnds,type,
    basic_snds: 
      !>[A: $tType,B: $tType] : ( product_prod(A,B) > set(B) ) ).

tff(sy_c_Binomial_Obinomial,type,
    binomial: ( nat * nat ) > nat ).

tff(sy_c_Binomial_Ogbinomial,type,
    gbinomial: 
      !>[A: $tType] : ( A > fun(nat,A) ) ).

tff(sy_c_Bit__Operations_Oring__bit__operations__class_Onot,type,
    bit_ri4277139882892585799ns_not: 
      !>[A: $tType] : fun(A,A) ).

tff(sy_c_Bit__Operations_Oring__bit__operations__class_Osigned__take__bit,type,
    bit_ri4674362597316999326ke_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oand,type,
    bit_se5824344872417868541ns_and: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Odrop__bit,type,
    bit_se4197421643247451524op_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oflip__bit,type,
    bit_se8732182000553998342ip_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Omask,type,
    bit_se2239418461657761734s_mask: 
      !>[A: $tType] : ( nat > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oor,type,
    bit_se1065995026697491101ons_or: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Opush__bit,type,
    bit_se4730199178511100633sh_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oset__bit,type,
    bit_se5668285175392031749et_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Otake__bit,type,
    bit_se2584673776208193580ke_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Ounset__bit,type,
    bit_se2638667681897837118et_bit: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Oxor,type,
    bit_se5824344971392196577ns_xor: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Bit__Operations_Osemiring__bits__class_Obit,type,
    bit_se5641148757651400278ts_bit: 
      !>[A: $tType] : ( ( A * nat ) > $o ) ).

tff(sy_c_Bit__Operations_Osemiring__bits__class_Opossible__bit,type,
    bit_se6407376104438227557le_bit: 
      !>[A: $tType] : ( ( itself(A) * nat ) > $o ) ).

tff(sy_c_Boolean__Algebras_Oabstract__boolean__algebra,type,
    boolea2506097494486148201lgebra: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,A)) * fun(A,A) * A * A ) > $o ) ).

tff(sy_c_Boolean__Algebras_Oabstract__boolean__algebra__axioms,type,
    boolea6902313364301356556axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,A)) * fun(A,A) * A * A ) > $o ) ).

tff(sy_c_Boolean__Algebras_Oabstract__boolean__algebra__sym__diff,type,
    boolea3799213064322606851m_diff: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,A)) * fun(A,A) * A * A * fun(A,fun(A,A)) ) > $o ) ).

tff(sy_c_Boolean__Algebras_Oabstract__boolean__algebra__sym__diff__axioms,type,
    boolea5476839437570043046axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,A)) * fun(A,A) * fun(A,fun(A,A)) ) > $o ) ).

tff(sy_c_Complete__Lattices_OInf__class_OInf,type,
    complete_Inf_Inf: 
      !>[A: $tType] : fun(set(A),A) ).

tff(sy_c_Complete__Lattices_OSup__class_OSup,type,
    complete_Sup_Sup: 
      !>[A: $tType] : fun(set(A),A) ).

tff(sy_c_Complete__Partial__Order_Occpo_Oadmissible,type,
    comple1908693960933563346ssible: 
      !>[A: $tType] : ( ( fun(set(A),A) * fun(A,fun(A,$o)) * fun(A,$o) ) > $o ) ).

tff(sy_c_Complete__Partial__Order_Occpo_Ofixp,type,
    comple187402453842119260l_fixp: 
      !>[A: $tType] : ( ( fun(set(A),A) * fun(A,fun(A,$o)) * fun(A,A) ) > A ) ).

tff(sy_c_Complete__Partial__Order_Occpo__class_Ofixp,type,
    comple115746919287870866o_fixp: 
      !>[A: $tType] : ( fun(A,A) > A ) ).

tff(sy_c_Complete__Partial__Order_Occpo__class_Oiterates,type,
    comple6359979572994053840erates: 
      !>[A: $tType] : ( fun(A,A) > set(A) ) ).

tff(sy_c_Complete__Partial__Order_Ochain,type,
    comple1602240252501008431_chain: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * set(A) ) > $o ) ).

tff(sy_c_Complete__Partial__Order_Omonotone,type,
    comple7038119648293358887notone: 
      !>[A: $tType,B: $tType] : fun(fun(A,fun(A,$o)),fun(fun(B,fun(B,$o)),fun(fun(A,B),$o))) ).

tff(sy_c_Conditionally__Complete__Lattices_Opreorder_Obdd__above,type,
    condit8047198070973881523_above: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * set(A) ) > $o ) ).

tff(sy_c_Conditionally__Complete__Lattices_Opreorder_Obdd__below,type,
    condit8119078960628432327_below: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * set(A) ) > $o ) ).

tff(sy_c_Conditionally__Complete__Lattices_Opreorder__class_Obdd__above,type,
    condit941137186595557371_above: 
      !>[A: $tType] : ( set(A) > $o ) ).

tff(sy_c_Conditionally__Complete__Lattices_Opreorder__class_Obdd__below,type,
    condit1013018076250108175_below: 
      !>[A: $tType] : ( set(A) > $o ) ).

tff(sy_c_Divides_Ounique__euclidean__semiring__numeral__class_Odivmod,type,
    unique8689654367752047608divmod: 
      !>[A: $tType] : ( ( num * num ) > product_prod(A,A) ) ).

tff(sy_c_Divides_Ounique__euclidean__semiring__numeral__class_Odivmod__step,type,
    unique1321980374590559556d_step: 
      !>[A: $tType] : ( ( num * product_prod(A,A) ) > product_prod(A,A) ) ).

tff(sy_c_Equiv__Relations_Ocongruent,type,
    equiv_congruent: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,A)) * fun(A,B) ) > $o ) ).

tff(sy_c_Equiv__Relations_Ocongruent2,type,
    equiv_congruent2: 
      !>[A: $tType,B: $tType,C: $tType] : ( ( set(product_prod(A,A)) * set(product_prod(B,B)) * fun(A,fun(B,C)) ) > $o ) ).

tff(sy_c_Equiv__Relations_Oequiv,type,
    equiv_equiv: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_Equiv__Relations_Oproj,type,
    equiv_proj: 
      !>[B: $tType,A: $tType] : ( ( set(product_prod(B,A)) * B ) > set(A) ) ).

tff(sy_c_Equiv__Relations_Oquotient,type,
    equiv_quotient: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > set(set(A)) ) ).

tff(sy_c_Euclidean__Division_Oeuclidean__semiring__class_Oeuclidean__size,type,
    euclid6346220572633701492n_size: 
      !>[A: $tType] : ( A > nat ) ).

tff(sy_c_Euclidean__Division_Ounique__euclidean__semiring__class_Odivision__segment,type,
    euclid7384307370059645450egment: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Factorial_Ocomm__semiring__1__class_Opochhammer,type,
    comm_s3205402744901411588hammer: 
      !>[A: $tType] : ( ( A * nat ) > A ) ).

tff(sy_c_Factorial_Osemiring__char__0__class_Ofact,type,
    semiring_char_0_fact: 
      !>[A: $tType] : ( nat > A ) ).

tff(sy_c_Fields_Oinverse__class_Oinverse,type,
    inverse_inverse: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Filter_Oeventually,type,
    eventually: 
      !>[A: $tType] : ( ( fun(A,$o) * filter(A) ) > $o ) ).

tff(sy_c_Filter_Ofilter_OAbs__filter,type,
    abs_filter: 
      !>[A: $tType] : ( fun(fun(A,$o),$o) > filter(A) ) ).

tff(sy_c_Filter_Ofilterlim,type,
    filterlim: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * filter(B) * filter(A) ) > $o ) ).

tff(sy_c_Filter_Ofiltermap,type,
    filtermap: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * filter(A) ) > filter(B) ) ).

tff(sy_c_Filter_Oprincipal,type,
    principal: 
      !>[A: $tType] : ( set(A) > filter(A) ) ).

tff(sy_c_Filter_Oprod__filter,type,
    prod_filter: 
      !>[A: $tType,B: $tType] : ( ( filter(A) * filter(B) ) > filter(product_prod(A,B)) ) ).

tff(sy_c_Filter_Orel__filter,type,
    rel_filter: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(filter(A),fun(filter(B),$o)) ) ).

tff(sy_c_Finite__Set_OFpow,type,
    finite_Fpow: 
      !>[A: $tType] : ( set(A) > set(set(A)) ) ).

tff(sy_c_Finite__Set_Ocard,type,
    finite_card: 
      !>[B: $tType] : ( set(B) > nat ) ).

tff(sy_c_Finite__Set_Ocomp__fun__commute,type,
    finite6289374366891150609ommute: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,B)) > $o ) ).

tff(sy_c_Finite__Set_Ocomp__fun__commute__on,type,
    finite4664212375090638736ute_on: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,fun(B,B)) ) > $o ) ).

tff(sy_c_Finite__Set_Ocomp__fun__idem__on,type,
    finite673082921795544331dem_on: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,fun(B,B)) ) > $o ) ).

tff(sy_c_Finite__Set_Ofinite,type,
    finite_finite2: 
      !>[A: $tType] : fun(set(A),$o) ).

tff(sy_c_Finite__Set_Ofold,type,
    finite_fold: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(B,B)) * B * set(A) ) > B ) ).

tff(sy_c_Finite__Set_Ofold__graph,type,
    finite_fold_graph: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(B,B)) * B * set(A) * B ) > $o ) ).

tff(sy_c_Finite__Set_Ofolding__on,type,
    finite_folding_on: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,fun(B,B)) ) > $o ) ).

tff(sy_c_Finite__Set_Ofolding__on_OF,type,
    finite_folding_F: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(B,B)) * B ) > fun(set(A),B) ) ).

tff(sy_c_Fun_Obij__betw,type,
    bij_betw: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * set(A) * set(B) ) > $o ) ).

tff(sy_c_Fun_Ocomp,type,
    comp: 
      !>[B: $tType,C: $tType,A: $tType] : ( ( fun(B,C) * fun(A,B) ) > fun(A,C) ) ).

tff(sy_c_Fun_Ofun__upd,type,
    fun_upd: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * A * B ) > fun(A,B) ) ).

tff(sy_c_Fun_Oid,type,
    id: 
      !>[A: $tType] : fun(A,A) ).

tff(sy_c_Fun_Oinj__on,type,
    inj_on: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * set(A) ) > $o ) ).

tff(sy_c_Fun_Ooverride__on,type,
    override_on: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * fun(A,B) * set(A) ) > fun(A,B) ) ).

tff(sy_c_Fun_Othe__inv__into,type,
    the_inv_into: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,B) * B ) > A ) ).

tff(sy_c_GCD_OGcd__class_OGcd,type,
    gcd_Gcd: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_GCD_OGcd__class_OLcm,type,
    gcd_Lcm: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_GCD_Obounded__quasi__semilattice,type,
    bounde8507323023520639062attice: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * A * fun(A,A) ) > $o ) ).

tff(sy_c_GCD_Obounded__quasi__semilattice__set,type,
    bounde6485984586167503788ce_set: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * A * fun(A,A) ) > $o ) ).

tff(sy_c_GCD_Obounded__quasi__semilattice__set_OF,type,
    bounde2362111253966948842tice_F: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * A ) > fun(set(A),A) ) ).

tff(sy_c_GCD_Ogcd__class_Ogcd,type,
    gcd_gcd: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_GCD_Ogcd__class_Olcm,type,
    gcd_lcm: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_GCD_Osemiring__gcd__class_OGcd__fin,type,
    semiring_gcd_Gcd_fin: 
      !>[A: $tType] : fun(set(A),A) ).

tff(sy_c_GCD_Osemiring__gcd__class_OLcm__fin,type,
    semiring_gcd_Lcm_fin: 
      !>[A: $tType] : fun(set(A),A) ).

tff(sy_c_Groups_Oabel__semigroup,type,
    abel_semigroup: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Groups_Oabel__semigroup__axioms,type,
    abel_s757365448890700780axioms: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Groups_Oabs__class_Oabs,type,
    abs_abs: 
      !>[A: $tType] : fun(A,A) ).

tff(sy_c_Groups_Ocomm__monoid,type,
    comm_monoid: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups_Ocomm__monoid__axioms,type,
    comm_monoid_axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups_Ogroup,type,
    group: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * fun(A,A) ) > $o ) ).

tff(sy_c_Groups_Ogroup__axioms,type,
    group_axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * fun(A,A) ) > $o ) ).

tff(sy_c_Groups_Ominus__class_Ominus,type,
    minus_minus: 
      !>[A: $tType] : ( ( A * A ) > A ) ).

tff(sy_c_Groups_Omonoid,type,
    monoid: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups_Omonoid__axioms,type,
    monoid_axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups_Oone__class_Oone,type,
    one_one: 
      !>[A: $tType] : A ).

tff(sy_c_Groups_Oplus__class_Oplus,type,
    plus_plus: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Groups_Osemigroup,type,
    semigroup: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Groups_Osgn__class_Osgn,type,
    sgn_sgn: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Groups_Otimes__class_Otimes,type,
    times_times: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Groups_Ouminus__class_Ouminus,type,
    uminus_uminus: 
      !>[A: $tType] : fun(A,A) ).

tff(sy_c_Groups_Ozero__class_Ozero,type,
    zero_zero: 
      !>[A: $tType] : A ).

tff(sy_c_Groups__Big_Ocomm__monoid__add__class_Osum,type,
    groups7311177749621191930dd_sum: 
      !>[B: $tType,A: $tType] : fun(fun(B,A),fun(set(B),A)) ).

tff(sy_c_Groups__Big_Ocomm__monoid__add__class_Osum_H,type,
    groups1027152243600224163dd_sum: 
      !>[C: $tType,A: $tType] : ( ( fun(C,A) * set(C) ) > A ) ).

tff(sy_c_Groups__Big_Ocomm__monoid__mult__class_Oprod,type,
    groups7121269368397514597t_prod: 
      !>[B: $tType,A: $tType] : fun(fun(B,A),fun(set(B),A)) ).

tff(sy_c_Groups__Big_Ocomm__monoid__mult__class_Oprod_H,type,
    groups1962203154675924110t_prod: 
      !>[C: $tType,A: $tType] : fun(fun(C,A),fun(set(C),A)) ).

tff(sy_c_Groups__Big_Ocomm__monoid__set,type,
    groups778175481326437816id_set: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups__Big_Ocomm__monoid__set_OF,type,
    groups_comm_monoid_F: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(A,A)) * A ) > fun(fun(B,A),fun(set(B),A)) ) ).

tff(sy_c_Groups__Big_Ocomm__monoid__set_OG,type,
    groups_comm_monoid_G: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(A,A)) * A ) > fun(fun(B,A),fun(set(B),A)) ) ).

tff(sy_c_Groups__List_Ocomm__monoid__list,type,
    groups1828464146339083142d_list: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups__List_Ocomm__monoid__list__set,type,
    groups4802862169904069756st_set: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups__List_Ocomm__semiring__0__class_Ohorner__sum,type,
    groups4207007520872428315er_sum: 
      !>[B: $tType,A: $tType] : fun(fun(B,A),fun(A,fun(list(B),A))) ).

tff(sy_c_Groups__List_Omonoid__add__class_Osum__list,type,
    groups8242544230860333062m_list: 
      !>[A: $tType] : ( list(A) > A ) ).

tff(sy_c_Groups__List_Omonoid__list,type,
    groups_monoid_list: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Groups__List_Omonoid__list_OF,type,
    groups_monoid_F: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > fun(list(A),A) ) ).

tff(sy_c_Groups__List_Omonoid__mult__class_Oprod__list,type,
    groups5270119922927024881d_list: 
      !>[A: $tType] : fun(list(A),A) ).

tff(sy_c_HOL_ONO__MATCH,type,
    nO_MATCH: 
      !>[A: $tType,B: $tType] : ( ( A * B ) > $o ) ).

tff(sy_c_HOL_OThe,type,
    the: 
      !>[A: $tType] : ( fun(A,$o) > A ) ).

tff(sy_c_HOL_OUniq,type,
    uniq: 
      !>[A: $tType] : ( fun(A,$o) > $o ) ).

tff(sy_c_HOL_Oundefined,type,
    undefined: 
      !>[A: $tType] : A ).

tff(sy_c_Heap_Oaddr__of__array,type,
    addr_of_array: 
      !>[A: $tType] : ( array(A) > nat ) ).

tff(sy_c_Heap_Oaddr__of__ref,type,
    addr_of_ref: 
      !>[A: $tType] : ( ref(A) > nat ) ).

tff(sy_c_Heap_Oheap_Oarrays,type,
    arrays: 
      !>[Z: $tType] : ( ( heap_ext(Z) * typerep * nat ) > list(nat) ) ).

tff(sy_c_Heap_Oheap_Olim,type,
    lim: 
      !>[Z: $tType] : ( heap_ext(Z) > nat ) ).

tff(sy_c_Heap_Oheap_Orefs,type,
    refs: 
      !>[Z: $tType] : ( ( heap_ext(Z) * typerep * nat ) > nat ) ).

tff(sy_c_Heap__Time__Monad_Obind,type,
    heap_Time_bind: 
      !>[A: $tType,B: $tType] : ( ( heap_Time_Heap(A) * fun(A,heap_Time_Heap(B)) ) > heap_Time_Heap(B) ) ).

tff(sy_c_Heap__Time__Monad_Oraise,type,
    heap_Time_raise: 
      !>[A: $tType] : ( list(char) > heap_Time_Heap(A) ) ).

tff(sy_c_Heap__Time__Monad_Oreturn,type,
    heap_Time_return: 
      !>[A: $tType] : ( A > heap_Time_Heap(A) ) ).

tff(sy_c_Heap__Time__Monad_Owait,type,
    heap_Time_wait: nat > heap_Time_Heap(product_unit) ).

tff(sy_c_Hilbert__Choice_Oinv__into,type,
    hilbert_inv_into: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,B) ) > fun(B,A) ) ).

tff(sy_c_Hoare__Triple_Ohoare__triple,type,
    hoare_hoare_triple: 
      !>[A: $tType] : ( ( assn * heap_Time_Heap(A) * fun(A,assn) ) > $o ) ).

tff(sy_c_Inductive_Ocomplete__lattice__class_Olfp,type,
    complete_lattice_lfp: 
      !>[A: $tType] : ( fun(A,A) > A ) ).

tff(sy_c_Infinite__Set_Owellorder__class_Oenumerate,type,
    infini527867602293511546merate: 
      !>[A: $tType] : ( ( set(A) * nat ) > A ) ).

tff(sy_c_Int_Onat,type,
    nat2: int > nat ).

tff(sy_c_Int_Opower__int,type,
    power_int: 
      !>[A: $tType] : ( ( A * int ) > A ) ).

tff(sy_c_Int_Oring__1__class_OInts,type,
    ring_1_Ints: 
      !>[A: $tType] : set(A) ).

tff(sy_c_Int_Oring__1__class_Oof__int,type,
    ring_1_of_int: 
      !>[A: $tType] : fun(int,A) ).

tff(sy_c_Lattices_Oinf__class_Oinf,type,
    inf_inf: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Lattices_Osemilattice,type,
    semilattice: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Lattices_Osemilattice__axioms,type,
    semilattice_axioms: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Lattices_Osemilattice__neutr,type,
    semilattice_neutr: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Lattices_Osemilattice__neutr__order,type,
    semila1105856199041335345_order: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Lattices_Osemilattice__order,type,
    semilattice_order: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Lattices_Osemilattice__order__axioms,type,
    semila6385135966242565138axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Lattices_Osup__class_Osup,type,
    sup_sup: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Lattices__Big_Olinorder__class_OMax,type,
    lattic643756798349783984er_Max: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_Lattices__Big_Olinorder__class_OMin,type,
    lattic643756798350308766er_Min: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_Lattices__Big_Oord__class_Oarg__min__on,type,
    lattic7623131987881927897min_on: 
      !>[B: $tType,A: $tType] : ( ( fun(B,A) * set(B) ) > B ) ).

tff(sy_c_Lattices__Big_Oord__class_Ois__arg__min,type,
    lattic501386751177426532rg_min: 
      !>[B: $tType,A: $tType] : ( ( fun(B,A) * fun(B,$o) * B ) > $o ) ).

tff(sy_c_Lattices__Big_Osemilattice__inf__class_OInf__fin,type,
    lattic7752659483105999362nf_fin: 
      !>[A: $tType] : fun(set(A),A) ).

tff(sy_c_Lattices__Big_Osemilattice__neutr__set,type,
    lattic5652469242046573047tr_set: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Lattices__Big_Osemilattice__neutr__set_OF,type,
    lattic5214292709420241887eutr_F: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * set(A) ) > A ) ).

tff(sy_c_Lattices__Big_Osemilattice__order__set,type,
    lattic4895041142388067077er_set: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Lattices__Big_Osemilattice__set,type,
    lattic149705377957585745ce_set: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Lattices__Big_Osemilattice__set_OF,type,
    lattic1715443433743089157tice_F: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > fun(set(A),A) ) ).

tff(sy_c_Lattices__Big_Osemilattice__sup__class_OSup__fin,type,
    lattic5882676163264333800up_fin: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_List_OBleast,type,
    bleast: 
      !>[A: $tType] : ( ( set(A) * fun(A,$o) ) > A ) ).

tff(sy_c_List_Oabort__Bleast,type,
    abort_Bleast: 
      !>[A: $tType] : ( ( set(A) * fun(A,$o) ) > A ) ).

tff(sy_c_List_Oall__interval__int,type,
    all_interval_int: ( fun(int,$o) * int * int ) > $o ).

tff(sy_c_List_Oall__interval__nat,type,
    all_interval_nat: ( fun(nat,$o) * nat * nat ) > $o ).

tff(sy_c_List_Oappend,type,
    append: 
      !>[A: $tType] : fun(list(A),fun(list(A),list(A))) ).

tff(sy_c_List_Oarg__min__list,type,
    arg_min_list: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * list(A) ) > A ) ).

tff(sy_c_List_Oarg__min__list__rel,type,
    arg_min_list_rel: 
      !>[A: $tType,B: $tType] : fun(product_prod(fun(A,B),list(A)),fun(product_prod(fun(A,B),list(A)),$o)) ).

tff(sy_c_List_Obind,type,
    bind: 
      !>[A: $tType,B: $tType] : ( ( list(A) * fun(A,list(B)) ) > list(B) ) ).

tff(sy_c_List_Obutlast,type,
    butlast: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_List_Ocan__select,type,
    can_select: 
      !>[A: $tType] : ( ( fun(A,$o) * set(A) ) > $o ) ).

tff(sy_c_List_Oconcat,type,
    concat: 
      !>[A: $tType] : fun(list(list(A)),list(A)) ).

tff(sy_c_List_Ocoset,type,
    coset: 
      !>[A: $tType] : ( list(A) > set(A) ) ).

tff(sy_c_List_Ocount__list,type,
    count_list: 
      !>[A: $tType] : ( list(A) > fun(A,nat) ) ).

tff(sy_c_List_Odistinct,type,
    distinct: 
      !>[A: $tType] : fun(list(A),$o) ).

tff(sy_c_List_Odistinct__adj,type,
    distinct_adj: 
      !>[A: $tType] : fun(list(A),$o) ).

tff(sy_c_List_Odrop,type,
    drop: 
      !>[A: $tType] : fun(nat,fun(list(A),list(A))) ).

tff(sy_c_List_OdropWhile,type,
    dropWhile: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),list(A))) ).

tff(sy_c_List_Oenumerate,type,
    enumerate: 
      !>[A: $tType] : ( ( nat * list(A) ) > list(product_prod(nat,A)) ) ).

tff(sy_c_List_Oextract,type,
    extract: 
      !>[A: $tType] : ( ( fun(A,$o) * list(A) ) > option(product_prod(list(A),product_prod(A,list(A)))) ) ).

tff(sy_c_List_Ofilter,type,
    filter2: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),list(A))) ).

tff(sy_c_List_Ofind,type,
    find: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),option(A))) ).

tff(sy_c_List_Ofold,type,
    fold: 
      !>[A: $tType,B: $tType] : fun(fun(A,fun(B,B)),fun(list(A),fun(B,B))) ).

tff(sy_c_List_Ofolding__insort__key,type,
    folding_insort_key: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,fun(A,$o)) * set(B) * fun(B,A) ) > $o ) ).

tff(sy_c_List_Ofolding__insort__key__axioms,type,
    foldin3648464208017769352axioms: 
      !>[B: $tType,A: $tType] : ( ( set(B) * fun(B,A) ) > $o ) ).

tff(sy_c_List_Ofoldl,type,
    foldl: 
      !>[B: $tType,A: $tType] : fun(fun(B,fun(A,B)),fun(B,fun(list(A),B))) ).

tff(sy_c_List_Ofoldr,type,
    foldr: 
      !>[A: $tType,B: $tType] : fun(fun(A,fun(B,B)),fun(list(A),fun(B,B))) ).

tff(sy_c_List_Ogen__length,type,
    gen_length: 
      !>[A: $tType] : ( nat > fun(list(A),nat) ) ).

tff(sy_c_List_Oinsert,type,
    insert: 
      !>[A: $tType] : fun(A,fun(list(A),list(A))) ).

tff(sy_c_List_Olast,type,
    last: 
      !>[A: $tType] : ( list(A) > A ) ).

tff(sy_c_List_Olenlex,type,
    lenlex: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(list(A),list(A))) ) ).

tff(sy_c_List_Olex,type,
    lex: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(list(A),list(A))) ) ).

tff(sy_c_List_Olexn,type,
    lexn: 
      !>[A: $tType] : ( set(product_prod(A,A)) > fun(nat,set(product_prod(list(A),list(A)))) ) ).

tff(sy_c_List_Olexord,type,
    lexord: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(list(A),list(A))) ) ).

tff(sy_c_List_Olexordp,type,
    lexordp: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * list(A) * list(A) ) > $o ) ).

tff(sy_c_List_Olinorder_Oinsort__key,type,
    insort_key: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(A,$o)) > fun(fun(B,A),fun(B,fun(list(B),list(B)))) ) ).

tff(sy_c_List_Olinorder_Osorted__key__list__of__set,type,
    sorted8670434370408473282of_set: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(A,$o)) > fun(fun(B,A),fun(set(B),list(B))) ) ).

tff(sy_c_List_Olinorder__class_Oinsort__insert__key,type,
    linord329482645794927042rt_key: 
      !>[B: $tType,A: $tType] : ( ( fun(B,A) * B * list(B) ) > list(B) ) ).

tff(sy_c_List_Olinorder__class_Oinsort__key,type,
    linorder_insort_key: 
      !>[B: $tType,A: $tType] : ( fun(B,A) > fun(B,fun(list(B),list(B))) ) ).

tff(sy_c_List_Olinorder__class_Osort__key,type,
    linorder_sort_key: 
      !>[B: $tType,A: $tType] : fun(fun(B,A),fun(list(B),list(B))) ).

tff(sy_c_List_Olinorder__class_Osorted__key__list__of__set,type,
    linord144544945434240204of_set: 
      !>[B: $tType,A: $tType] : ( fun(B,A) > fun(set(B),list(B)) ) ).

tff(sy_c_List_Olinorder__class_Osorted__list__of__set,type,
    linord4507533701916653071of_set: 
      !>[A: $tType] : fun(set(A),list(A)) ).

tff(sy_c_List_Olinorder__class_Ostable__sort__key,type,
    linord3483353639454293061rt_key: 
      !>[B: $tType,A: $tType] : ( fun(fun(B,A),fun(list(B),list(B))) > $o ) ).

tff(sy_c_List_Olist_OCons,type,
    cons: 
      !>[A: $tType] : fun(A,fun(list(A),list(A))) ).

tff(sy_c_List_Olist_ONil,type,
    nil: 
      !>[A: $tType] : list(A) ).

tff(sy_c_List_Olist_Ocase__list,type,
    case_list: 
      !>[B: $tType,A: $tType] : fun(B,fun(fun(A,fun(list(A),B)),fun(list(A),B))) ).

tff(sy_c_List_Olist_Ohd,type,
    hd: 
      !>[A: $tType] : fun(list(A),A) ).

tff(sy_c_List_Olist_Olist__all,type,
    list_all: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),$o)) ).

tff(sy_c_List_Olist_Olist__all2,type,
    list_all2: 
      !>[A: $tType,B: $tType] : fun(fun(A,fun(B,$o)),fun(list(A),fun(list(B),$o))) ).

tff(sy_c_List_Olist_Omap,type,
    map: 
      !>[A: $tType,Aa: $tType] : fun(fun(A,Aa),fun(list(A),list(Aa))) ).

tff(sy_c_List_Olist_Orec__list,type,
    rec_list: 
      !>[C: $tType,A: $tType] : fun(C,fun(fun(A,fun(list(A),fun(C,C))),fun(list(A),C))) ).

tff(sy_c_List_Olist_Oset,type,
    set2: 
      !>[A: $tType] : fun(list(A),set(A)) ).

tff(sy_c_List_Olist_Osize__list,type,
    size_list: 
      !>[A: $tType] : ( fun(A,nat) > fun(list(A),nat) ) ).

tff(sy_c_List_Olist_Otl,type,
    tl: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_List_Olist__ex,type,
    list_ex: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),$o)) ).

tff(sy_c_List_Olist__ex1,type,
    list_ex1: 
      !>[A: $tType] : ( ( fun(A,$o) * list(A) ) > $o ) ).

tff(sy_c_List_Olist__update,type,
    list_update: 
      !>[A: $tType] : fun(list(A),fun(nat,fun(A,list(A)))) ).

tff(sy_c_List_Olistrel,type,
    listrel: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > set(product_prod(list(A),list(B))) ) ).

tff(sy_c_List_Olistrel1,type,
    listrel1: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(list(A),list(A))) ) ).

tff(sy_c_List_Olistrel1p,type,
    listrel1p: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * list(A) * list(A) ) > $o ) ).

tff(sy_c_List_Olistrelp,type,
    listrelp: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(list(A),fun(list(B),$o)) ) ).

tff(sy_c_List_Olists,type,
    lists: 
      !>[A: $tType] : fun(set(A),set(list(A))) ).

tff(sy_c_List_Olistset,type,
    listset: 
      !>[A: $tType] : fun(list(set(A)),set(list(A))) ).

tff(sy_c_List_Olistsp,type,
    listsp: 
      !>[A: $tType] : ( fun(A,$o) > fun(list(A),$o) ) ).

tff(sy_c_List_Omap__filter,type,
    map_filter: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * list(A) ) > list(B) ) ).

tff(sy_c_List_Omap__project,type,
    map_project: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * set(A) ) > set(B) ) ).

tff(sy_c_List_Omap__tailrec,type,
    map_tailrec: 
      !>[A: $tType,B: $tType] : fun(fun(A,B),fun(list(A),list(B))) ).

tff(sy_c_List_Omap__tailrec__rev,type,
    map_tailrec_rev: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * list(A) * list(B) ) > list(B) ) ).

tff(sy_c_List_Omap__tailrec__rev__rel,type,
    map_tailrec_rev_rel: 
      !>[A: $tType,B: $tType] : fun(product_prod(fun(A,B),product_prod(list(A),list(B))),fun(product_prod(fun(A,B),product_prod(list(A),list(B))),$o)) ).

tff(sy_c_List_Omaps,type,
    maps: 
      !>[A: $tType,B: $tType] : ( ( fun(A,list(B)) * list(A) ) > list(B) ) ).

tff(sy_c_List_Omeasures,type,
    measures: 
      !>[A: $tType] : ( list(fun(A,nat)) > set(product_prod(A,A)) ) ).

tff(sy_c_List_Omember,type,
    member: 
      !>[A: $tType] : ( ( list(A) * A ) > $o ) ).

tff(sy_c_List_Omin__list,type,
    min_list: 
      !>[A: $tType] : ( list(A) > A ) ).

tff(sy_c_List_Omin__list__rel,type,
    min_list_rel: 
      !>[A: $tType] : fun(list(A),fun(list(A),$o)) ).

tff(sy_c_List_On__lists,type,
    n_lists: 
      !>[A: $tType] : ( ( nat * list(A) ) > list(list(A)) ) ).

tff(sy_c_List_Onth,type,
    nth: 
      !>[A: $tType] : ( list(A) > fun(nat,A) ) ).

tff(sy_c_List_Onths,type,
    nths: 
      !>[A: $tType] : fun(list(A),fun(set(nat),list(A))) ).

tff(sy_c_List_Onull,type,
    null: 
      !>[A: $tType] : fun(list(A),$o) ).

tff(sy_c_List_Oord_Olexordp,type,
    lexordp2: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(list(A),fun(list(A),$o)) ) ).

tff(sy_c_List_Oord_Olexordp__eq,type,
    lexordp_eq: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(list(A),fun(list(A),$o)) ) ).

tff(sy_c_List_Oord__class_Olexordp,type,
    ord_lexordp: 
      !>[A: $tType] : fun(list(A),fun(list(A),$o)) ).

tff(sy_c_List_Oord__class_Olexordp__eq,type,
    ord_lexordp_eq: 
      !>[A: $tType] : ( ( list(A) * list(A) ) > $o ) ).

tff(sy_c_List_Opartition,type,
    partition: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),product_prod(list(A),list(A)))) ).

tff(sy_c_List_Oproduct,type,
    product: 
      !>[A: $tType,B: $tType] : fun(list(A),fun(list(B),list(product_prod(A,B)))) ).

tff(sy_c_List_Oproduct__lists,type,
    product_lists: 
      !>[A: $tType] : fun(list(list(A)),list(list(A))) ).

tff(sy_c_List_Oremdups,type,
    remdups: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_List_Oremdups__adj,type,
    remdups_adj: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_List_Oremdups__adj__rel,type,
    remdups_adj_rel: 
      !>[A: $tType] : fun(list(A),fun(list(A),$o)) ).

tff(sy_c_List_Oremove1,type,
    remove1: 
      !>[A: $tType] : fun(A,fun(list(A),list(A))) ).

tff(sy_c_List_OremoveAll,type,
    removeAll: 
      !>[A: $tType] : fun(A,fun(list(A),list(A))) ).

tff(sy_c_List_Oreplicate,type,
    replicate: 
      !>[A: $tType] : fun(nat,fun(A,list(A))) ).

tff(sy_c_List_Orev,type,
    rev: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_List_Orotate,type,
    rotate: 
      !>[A: $tType] : fun(nat,fun(list(A),list(A))) ).

tff(sy_c_List_Orotate1,type,
    rotate1: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_List_Oset__Cons,type,
    set_Cons: 
      !>[A: $tType] : fun(set(A),fun(set(list(A)),set(list(A)))) ).

tff(sy_c_List_Oshuffles,type,
    shuffles: 
      !>[A: $tType] : fun(list(A),fun(list(A),set(list(A)))) ).

tff(sy_c_List_Oshuffles__rel,type,
    shuffles_rel: 
      !>[A: $tType] : fun(product_prod(list(A),list(A)),fun(product_prod(list(A),list(A)),$o)) ).

tff(sy_c_List_Osorted__wrt,type,
    sorted_wrt: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * list(A) ) > $o ) ).

tff(sy_c_List_Osorted__wrt__rel,type,
    sorted_wrt_rel: 
      !>[A: $tType] : fun(product_prod(fun(A,fun(A,$o)),list(A)),fun(product_prod(fun(A,fun(A,$o)),list(A)),$o)) ).

tff(sy_c_List_Osplice,type,
    splice: 
      !>[A: $tType] : fun(list(A),fun(list(A),list(A))) ).

tff(sy_c_List_Osplice__rel,type,
    splice_rel: 
      !>[A: $tType] : fun(product_prod(list(A),list(A)),fun(product_prod(list(A),list(A)),$o)) ).

tff(sy_c_List_Osubseqs,type,
    subseqs: 
      !>[A: $tType] : fun(list(A),list(list(A))) ).

tff(sy_c_List_Osuccessively,type,
    successively: 
      !>[A: $tType] : fun(fun(A,fun(A,$o)),fun(list(A),$o)) ).

tff(sy_c_List_Osuccessively__rel,type,
    successively_rel: 
      !>[A: $tType] : fun(product_prod(fun(A,fun(A,$o)),list(A)),fun(product_prod(fun(A,fun(A,$o)),list(A)),$o)) ).

tff(sy_c_List_Otake,type,
    take: 
      !>[A: $tType] : fun(nat,fun(list(A),list(A))) ).

tff(sy_c_List_OtakeWhile,type,
    takeWhile: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),list(A))) ).

tff(sy_c_List_Othose,type,
    those: 
      !>[A: $tType] : fun(list(option(A)),option(list(A))) ).

tff(sy_c_List_Otranspose,type,
    transpose: 
      !>[A: $tType] : ( list(list(A)) > list(list(A)) ) ).

tff(sy_c_List_Otranspose__rel,type,
    transpose_rel: 
      !>[A: $tType] : fun(list(list(A)),fun(list(list(A)),$o)) ).

tff(sy_c_List_Ounion,type,
    union: 
      !>[A: $tType] : fun(list(A),fun(list(A),list(A))) ).

tff(sy_c_List_Oupt,type,
    upt: ( nat * nat ) > list(nat) ).

tff(sy_c_List_Oupto,type,
    upto: ( int * int ) > list(int) ).

tff(sy_c_List_Oupto__aux,type,
    upto_aux: ( int * int * list(int) ) > list(int) ).

tff(sy_c_List_Oupto__rel,type,
    upto_rel: fun(product_prod(int,int),fun(product_prod(int,int),$o)) ).

tff(sy_c_List_Ozip,type,
    zip: 
      !>[A: $tType,B: $tType] : fun(list(A),fun(list(B),list(product_prod(A,B)))) ).

tff(sy_c_Map_Odom,type,
    dom: 
      !>[A: $tType,B: $tType] : ( fun(A,option(B)) > set(A) ) ).

tff(sy_c_Map_Ograph,type,
    graph: 
      !>[A: $tType,B: $tType] : ( fun(A,option(B)) > set(product_prod(A,B)) ) ).

tff(sy_c_Map_Omap__add,type,
    map_add: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * fun(A,option(B)) ) > fun(A,option(B)) ) ).

tff(sy_c_Map_Omap__le,type,
    map_le: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * fun(A,option(B)) ) > $o ) ).

tff(sy_c_Map_Omap__of,type,
    map_of: 
      !>[A: $tType,B: $tType] : ( list(product_prod(A,B)) > fun(A,option(B)) ) ).

tff(sy_c_Map_Omap__upds,type,
    map_upds: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * list(A) * list(B) ) > fun(A,option(B)) ) ).

tff(sy_c_Map_Oran,type,
    ran: 
      !>[A: $tType,B: $tType] : ( fun(A,option(B)) > set(B) ) ).

tff(sy_c_Map_Orestrict__map,type,
    restrict_map: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * set(A) ) > fun(A,option(B)) ) ).

tff(sy_c_Misc_OCODE__ABORT,type,
    cODE_ABORT: 
      !>[A: $tType] : ( fun(product_unit,A) > A ) ).

tff(sy_c_Misc_OEps__Opt,type,
    eps_Opt: 
      !>[A: $tType] : ( fun(A,$o) > option(A) ) ).

tff(sy_c_Misc_Obijective,type,
    bijective: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > $o ) ).

tff(sy_c_Misc_Obrk__rel,type,
    brk_rel: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > set(product_prod(product_prod($o,A),product_prod($o,B))) ) ).

tff(sy_c_Misc_Odflt__None__set,type,
    dflt_None_set: 
      !>[A: $tType] : ( set(A) > option(set(A)) ) ).

tff(sy_c_Misc_Ofilter__rev,type,
    filter_rev: 
      !>[A: $tType] : fun(fun(A,$o),fun(list(A),list(A))) ).

tff(sy_c_Misc_Ofilter__rev__aux,type,
    filter_rev_aux: 
      !>[A: $tType] : ( list(A) > fun(fun(A,$o),fun(list(A),list(A))) ) ).

tff(sy_c_Misc_Ofun__of__rel,type,
    fun_of_rel: 
      !>[B: $tType,A: $tType] : ( ( set(product_prod(B,A)) * B ) > A ) ).

tff(sy_c_Misc_Oinv__on,type,
    inv_on: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * set(A) ) > fun(B,A) ) ).

tff(sy_c_Misc_Olist__all__zip,type,
    list_all_zip: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(B,$o)) * list(A) * list(B) ) > $o ) ).

tff(sy_c_Misc_Olist__all__zip__rel,type,
    list_all_zip_rel: 
      !>[A: $tType,B: $tType] : fun(product_prod(fun(A,fun(B,$o)),product_prod(list(A),list(B))),fun(product_prod(fun(A,fun(B,$o)),product_prod(list(A),list(B))),$o)) ).

tff(sy_c_Misc_Olist__collect__set,type,
    list_collect_set: 
      !>[B: $tType,A: $tType] : ( ( fun(B,set(A)) * list(B) ) > set(A) ) ).

tff(sy_c_Misc_Omap__mmupd,type,
    map_mmupd: 
      !>[B: $tType,A: $tType] : ( ( fun(B,option(A)) * set(B) * A ) > fun(B,option(A)) ) ).

tff(sy_c_Misc_Omap__to__set,type,
    map_to_set: 
      !>[A: $tType,B: $tType] : ( fun(A,option(B)) > set(product_prod(A,B)) ) ).

tff(sy_c_Misc_Omerge,type,
    merge: 
      !>[A: $tType] : ( ( list(A) * list(A) ) > list(A) ) ).

tff(sy_c_Misc_Omerge__list,type,
    merge_list: 
      !>[A: $tType] : ( ( list(list(A)) * list(list(A)) ) > list(A) ) ).

tff(sy_c_Misc_Omerge__list__rel,type,
    merge_list_rel: 
      !>[A: $tType] : fun(product_prod(list(list(A)),list(list(A))),fun(product_prod(list(list(A)),list(list(A))),$o)) ).

tff(sy_c_Misc_Omerge__rel,type,
    merge_rel: 
      !>[A: $tType] : fun(product_prod(list(A),list(A)),fun(product_prod(list(A),list(A)),$o)) ).

tff(sy_c_Misc_Omergesort,type,
    mergesort: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_Misc_Omergesort__by__rel,type,
    mergesort_by_rel: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(list(A),list(A)) ) ).

tff(sy_c_Misc_Omergesort__by__rel__merge,type,
    merges9089515139780605204_merge: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * list(A) * list(A) ) > list(A) ) ).

tff(sy_c_Misc_Omergesort__by__rel__merge__rel,type,
    merges2244889521215249637ge_rel: 
      !>[A: $tType] : fun(product_prod(fun(A,fun(A,$o)),product_prod(list(A),list(A))),fun(product_prod(fun(A,fun(A,$o)),product_prod(list(A),list(A))),$o)) ).

tff(sy_c_Misc_Omergesort__by__rel__rel,type,
    mergesort_by_rel_rel: 
      !>[A: $tType] : fun(product_prod(fun(A,fun(A,$o)),list(A)),fun(product_prod(fun(A,fun(A,$o)),list(A)),$o)) ).

tff(sy_c_Misc_Omergesort__by__rel__split,type,
    merges295452479951948502_split: 
      !>[A: $tType] : ( ( product_prod(list(A),list(A)) * list(A) ) > product_prod(list(A),list(A)) ) ).

tff(sy_c_Misc_Omergesort__by__rel__split__rel,type,
    merges7066485432131860899it_rel: 
      !>[A: $tType] : fun(product_prod(product_prod(list(A),list(A)),list(A)),fun(product_prod(product_prod(list(A),list(A)),list(A)),$o)) ).

tff(sy_c_Misc_Omergesort__remdups,type,
    mergesort_remdups: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_Misc_Opairself,type,
    pairself: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > fun(product_prod(A,A),product_prod(B,B)) ) ).

tff(sy_c_Misc_Opairself__rel,type,
    pairself_rel: 
      !>[A: $tType,B: $tType] : fun(product_prod(fun(A,B),product_prod(A,A)),fun(product_prod(fun(A,B),product_prod(A,A)),$o)) ).

tff(sy_c_Misc_Opartition__rev,type,
    partition_rev: 
      !>[A: $tType] : ( ( fun(A,$o) * product_prod(list(A),list(A)) * list(A) ) > product_prod(list(A),list(A)) ) ).

tff(sy_c_Misc_Opartition__rev__rel,type,
    partition_rev_rel: 
      !>[A: $tType] : fun(product_prod(fun(A,$o),product_prod(product_prod(list(A),list(A)),list(A))),fun(product_prod(fun(A,$o),product_prod(product_prod(list(A),list(A)),list(A))),$o)) ).

tff(sy_c_Misc_Oquicksort__by__rel,type,
    quicksort_by_rel: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * list(A) ) > fun(list(A),list(A)) ) ).

tff(sy_c_Misc_Oquicksort__by__rel__rel,type,
    quicksort_by_rel_rel: 
      !>[A: $tType] : fun(product_prod(fun(A,fun(A,$o)),product_prod(list(A),list(A))),fun(product_prod(fun(A,fun(A,$o)),product_prod(list(A),list(A))),$o)) ).

tff(sy_c_Misc_Orel__of,type,
    rel_of: 
      !>[A: $tType,B: $tType] : ( ( fun(A,option(B)) * fun(product_prod(A,B),$o) ) > set(product_prod(A,B)) ) ).

tff(sy_c_Misc_Orel__restrict,type,
    rel_restrict: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) ) > set(product_prod(A,A)) ) ).

tff(sy_c_Misc_Oremove__rev,type,
    remove_rev: 
      !>[A: $tType] : ( A > fun(list(A),list(A)) ) ).

tff(sy_c_Misc_Orevg,type,
    revg: 
      !>[A: $tType] : ( ( list(A) * list(A) ) > list(A) ) ).

tff(sy_c_Misc_Orevg__rel,type,
    revg_rel: 
      !>[A: $tType] : fun(product_prod(list(A),list(A)),fun(product_prod(list(A),list(A)),$o)) ).

tff(sy_c_Misc_Oset__to__map,type,
    set_to_map: 
      !>[B: $tType,A: $tType] : ( set(product_prod(B,A)) > fun(B,option(A)) ) ).

tff(sy_c_Misc_Oslice,type,
    slice: 
      !>[A: $tType] : ( ( nat * nat * list(A) ) > list(A) ) ).

tff(sy_c_Misc_Osu__rel__fun,type,
    su_rel_fun: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,B)) * fun(A,B) ) > $o ) ).

tff(sy_c_Misc_Othe__default,type,
    the_default: 
      !>[A: $tType] : ( ( A * option(A) ) > A ) ).

tff(sy_c_Misc_Ouncurry,type,
    uncurry: 
      !>[A: $tType,B: $tType,C: $tType] : ( fun(A,fun(B,C)) > fun(product_prod(A,B),C) ) ).

tff(sy_c_Misc_Ozipf,type,
    zipf: 
      !>[A: $tType,B: $tType,C: $tType] : ( ( fun(A,fun(B,C)) * list(A) * list(B) ) > list(C) ) ).

tff(sy_c_Misc_Ozipf__rel,type,
    zipf_rel: 
      !>[A: $tType,B: $tType,C: $tType] : fun(product_prod(fun(A,fun(B,C)),product_prod(list(A),list(B))),fun(product_prod(fun(A,fun(B,C)),product_prod(list(A),list(B))),$o)) ).

tff(sy_c_Multiset_Oadd__mset,type,
    add_mset: 
      !>[A: $tType] : ( ( A * multiset(A) ) > multiset(A) ) ).

tff(sy_c_Multiset_Ocomm__monoid__add__class_Osum__mset,type,
    comm_m7189776963980413722m_mset: 
      !>[A: $tType] : ( multiset(A) > A ) ).

tff(sy_c_Multiset_Ocomm__monoid__mset,type,
    comm_monoid_mset: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $o ) ).

tff(sy_c_Multiset_Ocomm__monoid__mset_OF,type,
    comm_monoid_F: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > fun(multiset(A),A) ) ).

tff(sy_c_Multiset_Ocomm__monoid__mult__class_Oprod__mset,type,
    comm_m9189036328036947845d_mset: 
      !>[A: $tType] : fun(multiset(A),A) ).

tff(sy_c_Multiset_Ofold__mset,type,
    fold_mset: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(B,B)) * B * multiset(A) ) > B ) ).

tff(sy_c_Multiset_Oimage__mset,type,
    image_mset: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * multiset(A) ) > multiset(B) ) ).

tff(sy_c_Multiset_Ointer__mset,type,
    inter_mset: 
      !>[A: $tType] : ( ( multiset(A) * multiset(A) ) > multiset(A) ) ).

tff(sy_c_Multiset_Olinorder__class_Opart,type,
    linorder_part: 
      !>[B: $tType,A: $tType] : ( ( fun(B,A) * A * list(B) ) > product_prod(list(B),product_prod(list(B),list(B))) ) ).

tff(sy_c_Multiset_Olinorder__class_Osorted__list__of__multiset,type,
    linord6283353356039996273ltiset: 
      !>[A: $tType] : ( multiset(A) > list(A) ) ).

tff(sy_c_Multiset_Omset,type,
    mset: 
      !>[A: $tType] : ( list(A) > multiset(A) ) ).

tff(sy_c_Multiset_Omset__set,type,
    mset_set: 
      !>[B: $tType] : ( set(B) > multiset(B) ) ).

tff(sy_c_Multiset_Omultiset_Ocount,type,
    count: 
      !>[A: $tType] : ( multiset(A) > fun(A,nat) ) ).

tff(sy_c_Multiset_Oreplicate__mset,type,
    replicate_mset: 
      !>[A: $tType] : ( ( nat * A ) > multiset(A) ) ).

tff(sy_c_Multiset_Oset__mset,type,
    set_mset: 
      !>[A: $tType] : ( multiset(A) > set(A) ) ).

tff(sy_c_Multiset_Osubset__eq__mset__impl,type,
    subset_eq_mset_impl: 
      !>[A: $tType] : ( ( list(A) * list(A) ) > option($o) ) ).

tff(sy_c_Multiset_Osubset__eq__mset__impl__rel,type,
    subset751672762298770561pl_rel: 
      !>[A: $tType] : fun(product_prod(list(A),list(A)),fun(product_prod(list(A),list(A)),$o)) ).

tff(sy_c_Multiset_Osubseteq__mset,type,
    subseteq_mset: 
      !>[A: $tType] : fun(multiset(A),fun(multiset(A),$o)) ).

tff(sy_c_Multiset_Ounion__mset,type,
    union_mset: 
      !>[A: $tType] : ( ( multiset(A) * multiset(A) ) > multiset(A) ) ).

tff(sy_c_Multiset_Owcount,type,
    wcount: 
      !>[A: $tType] : ( ( fun(A,nat) * multiset(A) ) > fun(A,nat) ) ).

tff(sy_c_Nat_OSuc,type,
    suc: fun(nat,nat) ).

tff(sy_c_Nat_Ocompow,type,
    compow: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Nat_Onat_Ocase__nat,type,
    case_nat: 
      !>[A: $tType] : ( ( A * fun(nat,A) * nat ) > A ) ).

tff(sy_c_Nat_Osemiring__1__class_Oof__nat,type,
    semiring_1_of_nat: 
      !>[A: $tType] : fun(nat,A) ).

tff(sy_c_Nat_Osemiring__1__class_Oof__nat__aux,type,
    semiri8178284476397505188at_aux: 
      !>[A: $tType] : ( ( fun(A,A) * nat * A ) > A ) ).

tff(sy_c_Nat_Osize__class_Osize,type,
    size_size: 
      !>[A: $tType] : fun(A,nat) ).

tff(sy_c_Num_OBitM,type,
    bitM: num > num ).

tff(sy_c_Num_Oinc,type,
    inc: num > num ).

tff(sy_c_Num_Oneg__numeral__class_Odbl,type,
    neg_numeral_dbl: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Num_Oneg__numeral__class_Odbl__dec,type,
    neg_numeral_dbl_dec: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Num_Oneg__numeral__class_Odbl__inc,type,
    neg_numeral_dbl_inc: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Num_Oneg__numeral__class_Ois__num,type,
    neg_numeral_is_num: 
      !>[A: $tType] : ( A > $o ) ).

tff(sy_c_Num_Oneg__numeral__class_Osub,type,
    neg_numeral_sub: 
      !>[A: $tType] : ( ( num * num ) > A ) ).

tff(sy_c_Num_Onum_OBit0,type,
    bit0: num > num ).

tff(sy_c_Num_Onum_OBit1,type,
    bit1: num > num ).

tff(sy_c_Num_Onum_OOne,type,
    one2: num ).

tff(sy_c_Num_Onum__of__nat,type,
    num_of_nat: nat > num ).

tff(sy_c_Num_Onumeral__class_Onumeral,type,
    numeral_numeral: 
      !>[A: $tType] : fun(num,A) ).

tff(sy_c_Num_Opred__numeral,type,
    pred_numeral: num > nat ).

tff(sy_c_Num_Oring__1__class_Oiszero,type,
    ring_1_iszero: 
      !>[A: $tType] : ( A > $o ) ).

tff(sy_c_Num_Osqr,type,
    sqr: num > num ).

tff(sy_c_Option_Ooption_ONone,type,
    none: 
      !>[A: $tType] : option(A) ).

tff(sy_c_Option_Ooption_OSome,type,
    some: 
      !>[A: $tType] : fun(A,option(A)) ).

tff(sy_c_Option_Ooption_Ocase__option,type,
    case_option: 
      !>[B: $tType,A: $tType] : ( ( B * fun(A,B) * option(A) ) > B ) ).

tff(sy_c_Option_Ooption_Omap__option,type,
    map_option: 
      !>[A: $tType,Aa: $tType] : ( ( fun(A,Aa) * option(A) ) > option(Aa) ) ).

tff(sy_c_Option_Ooption_Orel__option,type,
    rel_option: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(option(A),fun(option(B),$o)) ) ).

tff(sy_c_Option_Ooption_Oset__option,type,
    set_option: 
      !>[A: $tType] : ( option(A) > set(A) ) ).

tff(sy_c_Option_Ooption_Othe,type,
    the2: 
      !>[A: $tType] : fun(option(A),A) ).

tff(sy_c_Option_Othese,type,
    these: 
      !>[A: $tType] : ( set(option(A)) > set(A) ) ).

tff(sy_c_Order__Relation_OAboveS,type,
    order_AboveS: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) ) > set(A) ) ).

tff(sy_c_Order__Relation_Oabove,type,
    order_above: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * A ) > set(A) ) ).

tff(sy_c_Order__Relation_Olinear__order__on,type,
    order_679001287576687338der_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_Order__Relation_Oofilter,type,
    order_ofilter: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) ) > $o ) ).

tff(sy_c_Order__Relation_Opartial__order__on,type,
    order_7125193373082350890der_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_Order__Relation_Opreorder__on,type,
    order_preorder_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_Order__Relation_Ounder,type,
    order_under: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * A ) > set(A) ) ).

tff(sy_c_Order__Relation_OunderS,type,
    order_underS: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * A ) > set(A) ) ).

tff(sy_c_Order__Relation_Owell__order__on,type,
    order_well_order_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_Orderings_Obot__class_Obot,type,
    bot_bot: 
      !>[A: $tType] : A ).

tff(sy_c_Orderings_Oord_OLeast,type,
    least: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(fun(A,$o),A) ) ).

tff(sy_c_Orderings_Oord__class_OLeast,type,
    ord_Least: 
      !>[A: $tType] : ( fun(A,$o) > A ) ).

tff(sy_c_Orderings_Oord__class_Oless,type,
    ord_less: 
      !>[A: $tType] : fun(A,fun(A,$o)) ).

tff(sy_c_Orderings_Oord__class_Oless__eq,type,
    ord_less_eq: 
      !>[A: $tType] : fun(A,fun(A,$o)) ).

tff(sy_c_Orderings_Oord__class_Omax,type,
    ord_max: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Orderings_Oord__class_Omin,type,
    ord_min: 
      !>[A: $tType] : fun(A,fun(A,A)) ).

tff(sy_c_Orderings_Oorder_Omono,type,
    mono: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(A,$o)) > fun(fun(A,B),$o) ) ).

tff(sy_c_Orderings_Oorder__class_OGreatest,type,
    order_Greatest: 
      !>[A: $tType] : ( fun(A,$o) > A ) ).

tff(sy_c_Orderings_Oorder__class_Oantimono,type,
    order_antimono: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > $o ) ).

tff(sy_c_Orderings_Oorder__class_Omono,type,
    order_mono: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > $o ) ).

tff(sy_c_Orderings_Oordering,type,
    ordering: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Orderings_Oordering__axioms,type,
    ordering_axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Orderings_Oordering__top,type,
    ordering_top: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,fun(A,$o)) * A ) > $o ) ).

tff(sy_c_Orderings_Oordering__top__axioms,type,
    ordering_top_axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * A ) > $o ) ).

tff(sy_c_Orderings_Opartial__preordering,type,
    partial_preordering: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $o ) ).

tff(sy_c_Orderings_Opreordering,type,
    preordering: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Orderings_Opreordering__axioms,type,
    preordering_axioms: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,fun(A,$o)) ) > $o ) ).

tff(sy_c_Orderings_Otop__class_Otop,type,
    top_top: 
      !>[A: $tType] : A ).

tff(sy_c_Partial__Function_Oflat__lub,type,
    partial_flat_lub: 
      !>[A: $tType] : ( ( A * set(A) ) > A ) ).

tff(sy_c_Partial__Function_Ofun__lub,type,
    partial_fun_lub: 
      !>[C: $tType,B: $tType,A: $tType] : fun(fun(set(C),B),fun(set(fun(A,C)),fun(A,B))) ).

tff(sy_c_Partial__Function_Ofun__ord,type,
    partial_fun_ord: 
      !>[A: $tType,B: $tType,C: $tType] : fun(fun(A,fun(B,$o)),fun(fun(C,A),fun(fun(C,B),$o))) ).

tff(sy_c_Partial__Function_Opartial__function__definitions,type,
    partia7178651479351089652itions: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * fun(set(A),A) ) > $o ) ).

tff(sy_c_Power_Opower__class_Opower,type,
    power_power: 
      !>[A: $tType] : fun(A,fun(nat,A)) ).

tff(sy_c_Product__Type_OPair,type,
    product_Pair: 
      !>[A: $tType,B: $tType] : fun(A,fun(B,product_prod(A,B))) ).

tff(sy_c_Product__Type_OSigma,type,
    product_Sigma: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,set(B)) ) > set(product_prod(A,B)) ) ).

tff(sy_c_Product__Type_OUnity,type,
    product_Unity: product_unit ).

tff(sy_c_Product__Type_Oapfst,type,
    product_apfst: 
      !>[A: $tType,C: $tType,B: $tType] : ( fun(A,C) > fun(product_prod(A,B),product_prod(C,B)) ) ).

tff(sy_c_Product__Type_Ocurry,type,
    product_curry: 
      !>[A: $tType,B: $tType,C: $tType] : ( fun(product_prod(A,B),C) > fun(A,fun(B,C)) ) ).

tff(sy_c_Product__Type_Omap__prod,type,
    product_map_prod: 
      !>[A: $tType,C: $tType,B: $tType,D: $tType] : ( ( fun(A,C) * fun(B,D) ) > fun(product_prod(A,B),product_prod(C,D)) ) ).

tff(sy_c_Product__Type_Oprod_Ocase__prod,type,
    product_case_prod: 
      !>[A: $tType,B: $tType,C: $tType] : ( fun(A,fun(B,C)) > fun(product_prod(A,B),C) ) ).

tff(sy_c_Product__Type_Oprod_Ofst,type,
    product_fst: 
      !>[A: $tType,B: $tType] : fun(product_prod(A,B),A) ).

tff(sy_c_Product__Type_Oprod_Osnd,type,
    product_snd: 
      !>[A: $tType,B: $tType] : fun(product_prod(A,B),B) ).

tff(sy_c_Product__Type_Oproduct,type,
    product_product: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(B) ) > set(product_prod(A,B)) ) ).

tff(sy_c_Pure_Otype,type,
    type2: 
      !>[A: $tType] : itself(A) ).

tff(sy_c_Quicksort_Olinorder__class_Oquicksort,type,
    linorder_quicksort: 
      !>[A: $tType] : fun(list(A),list(A)) ).

tff(sy_c_Quicksort_Olinorder__class_Oquicksort__rel,type,
    linord6200660962353139674rt_rel: 
      !>[A: $tType] : fun(list(A),fun(list(A),$o)) ).

tff(sy_c_Random_Oselect,type,
    select: 
      !>[A: $tType] : ( list(A) > fun(product_prod(code_natural,code_natural),product_prod(A,product_prod(code_natural,code_natural))) ) ).

tff(sy_c_Random_Oselect__weight,type,
    select_weight: 
      !>[A: $tType] : ( list(product_prod(code_natural,A)) > fun(product_prod(code_natural,code_natural),product_prod(A,product_prod(code_natural,code_natural))) ) ).

tff(sy_c_Rat_Ofield__char__0__class_Oof__rat,type,
    field_char_0_of_rat: 
      !>[A: $tType] : ( rat > A ) ).

tff(sy_c_Ref__Time_Oget,type,
    ref_get: 
      !>[A: $tType] : ( ( heap_ext(product_unit) * ref(A) ) > A ) ).

tff(sy_c_Ref__Time_Olookup,type,
    ref_lookup: 
      !>[A: $tType] : ( ref(A) > heap_Time_Heap(A) ) ).

tff(sy_c_Ref__Time_Oref,type,
    ref_ref: 
      !>[A: $tType] : ( A > heap_Time_Heap(ref(A)) ) ).

tff(sy_c_Ref__Time_Oset,type,
    ref_set: 
      !>[A: $tType] : ( ( ref(A) * A * heap_ext(product_unit) ) > heap_ext(product_unit) ) ).

tff(sy_c_Ref__Time_Oupdate,type,
    ref_update: 
      !>[A: $tType] : ( ( ref(A) * A ) > heap_Time_Heap(product_unit) ) ).

tff(sy_c_Relation_ODomain,type,
    domain: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > set(A) ) ).

tff(sy_c_Relation_ODomainp,type,
    domainp: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(A,$o) ) ).

tff(sy_c_Relation_OField,type,
    field2: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(A) ) ).

tff(sy_c_Relation_OId,type,
    id2: 
      !>[A: $tType] : set(product_prod(A,A)) ).

tff(sy_c_Relation_OId__on,type,
    id_on: 
      !>[A: $tType] : ( set(A) > set(product_prod(A,A)) ) ).

tff(sy_c_Relation_OImage,type,
    image: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,B)) * set(A) ) > set(B) ) ).

tff(sy_c_Relation_ORange,type,
    range: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > set(B) ) ).

tff(sy_c_Relation_ORangep,type,
    rangep: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(B,$o) ) ).

tff(sy_c_Relation_Oantisym,type,
    antisym: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Relation_Oasym,type,
    asym: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Relation_Oconverse,type,
    converse: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > set(product_prod(B,A)) ) ).

tff(sy_c_Relation_Oinv__image,type,
    inv_image: 
      !>[B: $tType,A: $tType] : ( ( set(product_prod(B,B)) * fun(A,B) ) > set(product_prod(A,A)) ) ).

tff(sy_c_Relation_Oirrefl,type,
    irrefl: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Relation_Orefl__on,type,
    refl_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(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)) ) ).

tff(sy_c_Relation_Osingle__valued,type,
    single_valued: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > $o ) ).

tff(sy_c_Relation_Osym,type,
    sym: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Relation_Ototal__on,type,
    total_on: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

tff(sy_c_Relation_Otrans,type,
    trans: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Relation_Otransp,type,
    transp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $o ) ).

tff(sy_c_Rings_Oalgebraic__semidom__class_Ocoprime,type,
    algebr8660921524188924756oprime: 
      !>[A: $tType] : ( ( A * A ) > $o ) ).

tff(sy_c_Rings_Odivide__class_Odivide,type,
    divide_divide: 
      !>[A: $tType] : ( ( A * A ) > A ) ).

tff(sy_c_Rings_Odvd__class_Odvd,type,
    dvd_dvd: 
      !>[A: $tType] : ( ( A * A ) > $o ) ).

tff(sy_c_Rings_Omodulo__class_Omodulo,type,
    modulo_modulo: 
      !>[A: $tType] : ( ( A * A ) > A ) ).

tff(sy_c_Rings_Onormalization__semidom__class_Onormalize,type,
    normal6383669964737779283malize: 
      !>[A: $tType] : fun(A,A) ).

tff(sy_c_Rings_Ounit__factor__class_Ounit__factor,type,
    unit_f5069060285200089521factor: 
      !>[A: $tType] : ( A > A ) ).

tff(sy_c_Rings_Ozero__neq__one__class_Oof__bool,type,
    zero_neq_one_of_bool: 
      !>[A: $tType] : fun($o,A) ).

tff(sy_c_Set_OCollect,type,
    collect: 
      !>[A: $tType] : ( fun(A,$o) > set(A) ) ).

tff(sy_c_Set_OPow,type,
    pow: 
      !>[A: $tType] : ( set(A) > set(set(A)) ) ).

tff(sy_c_Set_Obind,type,
    bind2: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,set(B)) ) > set(B) ) ).

tff(sy_c_Set_Odisjnt,type,
    disjnt: 
      !>[A: $tType] : fun(set(A),fun(set(A),$o)) ).

tff(sy_c_Set_Ofilter,type,
    filter3: 
      !>[A: $tType] : ( ( fun(A,$o) * set(A) ) > set(A) ) ).

tff(sy_c_Set_Oimage,type,
    image2: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > fun(set(A),set(B)) ) ).

tff(sy_c_Set_Oinsert,type,
    insert2: 
      !>[A: $tType] : fun(A,fun(set(A),set(A))) ).

tff(sy_c_Set_Ois__empty,type,
    is_empty: 
      !>[A: $tType] : ( set(A) > $o ) ).

tff(sy_c_Set_Ois__singleton,type,
    is_singleton: 
      !>[A: $tType] : ( set(A) > $o ) ).

tff(sy_c_Set_Opairwise,type,
    pairwise: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * set(A) ) > $o ) ).

tff(sy_c_Set_Oremove,type,
    remove: 
      !>[A: $tType] : fun(A,fun(set(A),set(A))) ).

tff(sy_c_Set_Othe__elem,type,
    the_elem: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_Set_Ovimage,type,
    vimage: 
      !>[A: $tType,B: $tType] : fun(fun(A,B),fun(set(B),set(A))) ).

tff(sy_c_Set__Interval_Ofold__atLeastAtMost__nat,type,
    set_fo6178422350223883121st_nat: 
      !>[A: $tType] : ( ( fun(nat,fun(A,A)) * nat * nat * A ) > A ) ).

tff(sy_c_Set__Interval_Oord__class_OatLeast,type,
    set_ord_atLeast: 
      !>[A: $tType] : ( A > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OatLeastAtMost,type,
    set_or1337092689740270186AtMost: 
      !>[A: $tType] : ( ( A * A ) > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OatLeastLessThan,type,
    set_or7035219750837199246ssThan: 
      !>[A: $tType] : ( ( A * A ) > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OatMost,type,
    set_ord_atMost: 
      !>[A: $tType] : ( A > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OgreaterThan,type,
    set_ord_greaterThan: 
      !>[A: $tType] : ( A > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OgreaterThanAtMost,type,
    set_or3652927894154168847AtMost: 
      !>[A: $tType] : ( ( A * A ) > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OgreaterThanLessThan,type,
    set_or5935395276787703475ssThan: 
      !>[A: $tType] : ( ( A * A ) > set(A) ) ).

tff(sy_c_Set__Interval_Oord__class_OlessThan,type,
    set_ord_lessThan: 
      !>[A: $tType] : ( A > set(A) ) ).

tff(sy_c_Sum__Type_OPlus,type,
    sum_Plus: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(B) ) > set(sum_sum(A,B)) ) ).

tff(sy_c_Syntax__Match_Oac__operator,type,
    syntax_ac_operator: 
      !>[A: $tType] : ( fun(A,fun(A,A)) > $o ) ).

tff(sy_c_Syntax__Match_Osyntax__fo__nomatch,type,
    syntax7388354845996824322omatch: 
      !>[A: $tType,B: $tType] : ( ( A * B ) > $o ) ).

tff(sy_c_Transfer_Obi__total,type,
    bi_total: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > $o ) ).

tff(sy_c_Transfer_Obi__unique,type,
    bi_unique: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > $o ) ).

tff(sy_c_Transfer_Oright__total,type,
    right_total: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > $o ) ).

tff(sy_c_Transitive__Closure_Oacyclic,type,
    transitive_acyclic: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Transitive__Closure_Ontrancl,type,
    transitive_ntrancl: 
      !>[A: $tType] : ( ( nat * set(product_prod(A,A)) ) > set(product_prod(A,A)) ) ).

tff(sy_c_Transitive__Closure_Ortrancl,type,
    transitive_rtrancl: 
      !>[A: $tType] : fun(set(product_prod(A,A)),set(product_prod(A,A))) ).

tff(sy_c_Transitive__Closure_Otrancl,type,
    transitive_trancl: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(A,A)) ) ).

tff(sy_c_Typedef_Otype__definition,type,
    type_definition: 
      !>[B: $tType,A: $tType] : ( ( fun(B,A) * fun(A,B) * set(A) ) > $o ) ).

tff(sy_c_VEBT__List__Assn_Olist__assn,type,
    vEBT_List_list_assn: 
      !>[A: $tType,C: $tType] : ( ( fun(A,fun(C,assn)) * list(A) * list(C) ) > assn ) ).

tff(sy_c_VEBT__List__Assn_Olist__assn__rel,type,
    vEBT_L4249061453398456502sn_rel: 
      !>[A: $tType,C: $tType] : fun(product_prod(fun(A,fun(C,assn)),product_prod(list(A),list(C))),fun(product_prod(fun(A,fun(C,assn)),product_prod(list(A),list(C))),$o)) ).

tff(sy_c_Wellfounded_Oaccp,type,
    accp: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * A ) > $o ) ).

tff(sy_c_Wellfounded_Oless__than,type,
    less_than: set(product_prod(nat,nat)) ).

tff(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))) ) ).

tff(sy_c_Wellfounded_Omax__ext,type,
    max_ext: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(set(A),set(A))) ) ).

tff(sy_c_Wellfounded_Omin__ext,type,
    min_ext: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(set(A),set(A))) ) ).

tff(sy_c_Wellfounded_Owf,type,
    wf: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

tff(sy_c_Wellfounded_OwfP,type,
    wfP: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $o ) ).

tff(sy_c_Wfrec_Osame__fst,type,
    same_fst: 
      !>[A: $tType,B: $tType] : ( ( fun(A,$o) * fun(A,set(product_prod(B,B))) ) > set(product_prod(product_prod(A,B),product_prod(A,B))) ) ).

tff(sy_c_Zorn_Opred__on_Ochain,type,
    pred_chain: 
      !>[A: $tType] : ( ( set(A) * fun(A,fun(A,$o)) * set(A) ) > $o ) ).

tff(sy_c_aa,type,
    aa: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * A ) > B ) ).

tff(sy_c_fChoice,type,
    fChoice: 
      !>[A: $tType] : ( fun(A,$o) > A ) ).

tff(sy_c_fNot,type,
    fNot: fun($o,$o) ).

tff(sy_c_fequal,type,
    fequal: 
      !>[A: $tType] : fun(A,fun(A,$o)) ).

tff(sy_c_member,type,
    member2: 
      !>[A: $tType] : ( ( A * set(A) ) > $o ) ).

tff(sy_v_P,type,
    p: fun(a,fun(b,assn)) ).

tff(sy_v_l_H,type,
    l: list(b) ).

% Relevant facts (6678)
tff(fact_0_pure__assn__eq__conv,axiom,
    ! [Pa: $o,Q: $o] :
      ( ( pure_assn((Pa)) = pure_assn((Q)) )
    <=> ( (Pa)
      <=> (Q) ) ) ).

% pure_assn_eq_conv
tff(fact_1_list__assn_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,assn))] : vEBT_List_list_assn(C,D,Pa,nil(C),nil(D)) = one_one(assn) ).

% list_assn.simps(1)
tff(fact_2_is__pure__assn__pure,axiom,
    ! [Pa: $o] : is_pure_assn(pure_assn((Pa))) ).

% is_pure_assn_pure
tff(fact_3_list__ex1__simps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : ~ list_ex1(C,Pa,nil(C)) ).

% list_ex1_simps(1)
tff(fact_4_bind__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,list(C))] : bind(D,C,nil(D),F) = nil(C) ).

% bind_simps(1)
tff(fact_5_member__rec_I2_J,axiom,
    ! [C: $tType,Y: C] : ~ member(C,nil(C),Y) ).

% member_rec(2)
tff(fact_6_is__pure__assnE,axiom,
    ! [A3: assn] :
      ( is_pure_assn(A3)
     => ~ ! [P: $o] : A3 != pure_assn((P)) ) ).

% is_pure_assnE
tff(fact_7_is__pure__assn__def,axiom,
    ! [A3: assn] :
      ( is_pure_assn(A3)
    <=> ? [P2: $o] : A3 = pure_assn((P2)) ) ).

% is_pure_assn_def
tff(fact_8_gen__length__code_I1_J,axiom,
    ! [C: $tType,N: nat] : aa(list(C),nat,gen_length(C,N),nil(C)) = N ).

% gen_length_code(1)
tff(fact_9_list__assn_Osimps_I4_J,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,fun(D,assn)),V: D,Va: list(D)] : vEBT_List_list_assn(C,D,Uu,nil(C),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V),Va)) = bot_bot(assn) ).

% list_assn.simps(4)
tff(fact_10_list__assn_Osimps_I3_J,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,fun(D,assn)),V: C,Va: list(C)] : vEBT_List_list_assn(C,D,Uu,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va),nil(D)) = bot_bot(assn) ).

% list_assn.simps(3)
tff(fact_11_list_Oinject,axiom,
    ! [C: $tType,X21: C,X22: list(C),Y21: C,Y22: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y21),Y22) )
    <=> ( ( X21 = Y21 )
        & ( X22 = Y22 ) ) ) ).

% list.inject
tff(fact_12_pure__assn__eq__emp__iff,axiom,
    ! [Pa: $o] :
      ( ( pure_assn((Pa)) = one_one(assn) )
    <=> (Pa) ) ).

% pure_assn_eq_emp_iff
tff(fact_13_pure__true,axiom,
    pure_assn($true) = one_one(assn) ).

% pure_true
tff(fact_14_pure__assn__eq__false__iff,axiom,
    ! [Pa: $o] :
      ( ( pure_assn((Pa)) = bot_bot(assn) )
    <=> ~ (Pa) ) ).

% pure_assn_eq_false_iff
tff(fact_15_pure__false,axiom,
    pure_assn($false) = bot_bot(assn) ).

% pure_false
tff(fact_16_assn__basic__inequalities_I3_J,axiom,
    bot_bot(assn) != one_one(assn) ).

% assn_basic_inequalities(3)
tff(fact_17_member__rec_I1_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C] :
      ( member(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),Y)
    <=> ( ( X = Y )
        | member(C,Xs,Y) ) ) ).

% member_rec(1)
tff(fact_18_is__pure__assn__basic__simps_I2_J,axiom,
    is_pure_assn(one_one(assn)) ).

% is_pure_assn_basic_simps(2)
tff(fact_19_is__pure__assn__basic__simps_I1_J,axiom,
    is_pure_assn(bot_bot(assn)) ).

% is_pure_assn_basic_simps(1)
tff(fact_20_transpose_Ocases,axiom,
    ! [C: $tType,X: list(list(C))] :
      ( ( X != nil(list(C)) )
     => ( ! [Xss: list(list(C))] : X != aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss)
       => ~ ! [X2: C,Xs2: list(C),Xss: list(list(C))] : X != aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xss) ) ) ).

% transpose.cases
tff(fact_21_not__Cons__self2,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) != Xs ).

% not_Cons_self2
tff(fact_22_list__nonempty__induct,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(list(C),$o)] :
      ( ( Xs != nil(C) )
     => ( ! [X2: C] : aa(list(C),$o,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))
       => ( ! [X2: C,Xs2: list(C)] :
              ( ( Xs2 != nil(C) )
             => ( aa(list(C),$o,Pa,Xs2)
               => aa(list(C),$o,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)) ) )
         => aa(list(C),$o,Pa,Xs) ) ) ) ).

% list_nonempty_induct
tff(fact_23_list__induct2_H,axiom,
    ! [C: $tType,D: $tType,Pa: fun(list(C),fun(list(D),$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),nil(D))
     => ( ! [X2: C,Xs2: list(C)] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),nil(D))
       => ( ! [Y2: D,Ys2: list(D)] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2))
         => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
                ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs2),Ys2)
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)) )
           => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs),Ys) ) ) ) ) ).

% list_induct2'
tff(fact_24_neq__Nil__conv,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
    <=> ? [Y3: C,Ys3: list(C)] : Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) ) ).

% neq_Nil_conv
tff(fact_25_remdups__adj_Ocases,axiom,
    ! [C: $tType,X: list(C)] :
      ( ( X != nil(C) )
     => ( ! [X2: C] : X != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))
       => ~ ! [X2: C,Y2: C,Xs2: list(C)] : X != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) ) ).

% remdups_adj.cases
tff(fact_26_min__list_Ocases,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: list(C)] :
          ( ! [X2: C,Xs2: list(C)] : X != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)
         => ( X = nil(C) ) ) ) ).

% min_list.cases
tff(fact_27_list_Oexhaust,axiom,
    ! [C: $tType,Y: list(C)] :
      ( ( Y != nil(C) )
     => ~ ! [X212: C,X222: list(C)] : Y != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X212),X222) ) ).

% list.exhaust
tff(fact_28_list_OdiscI,axiom,
    ! [C: $tType,List: list(C),X21: C,X22: list(C)] :
      ( ( List = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22) )
     => ( List != nil(C) ) ) ).

% list.discI
tff(fact_29_list_Odistinct_I1_J,axiom,
    ! [C: $tType,X21: C,X22: list(C)] : nil(C) != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22) ).

% list.distinct(1)
tff(fact_30_bot__apply,axiom,
    ! [D: $tType,C: $tType] :
      ( bot(C)
     => ! [X: D] : aa(D,C,bot_bot(fun(D,C)),X) = bot_bot(C) ) ).

% bot_apply
tff(fact_31_mergesort__by__rel__merge__induct,axiom,
    ! [C: $tType,D: $tType,Pa: fun(list(C),fun(list(D),$o)),R: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D)] :
      ( ! [Xs2: list(C)] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs2),nil(D))
     => ( ! [Ys2: list(D)] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),Ys2)
       => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
              ( aa(D,$o,aa(C,fun(D,$o),R,X2),Y2)
             => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2))
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)) ) )
         => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
                ( ~ aa(D,$o,aa(C,fun(D,$o),R,X2),Y2)
               => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2)
                 => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)) ) )
           => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs),Ys) ) ) ) ) ).

% mergesort_by_rel_merge_induct
tff(fact_32_mem__Collect__eq,axiom,
    ! [C: $tType,A3: C,Pa: fun(C,$o)] :
      ( member2(C,A3,collect(C,Pa))
    <=> aa(C,$o,Pa,A3) ) ).

% mem_Collect_eq
tff(fact_33_Collect__mem__eq,axiom,
    ! [C: $tType,A4: set(C)] : collect(C,aTP_Lamp_a(set(C),fun(C,$o),A4)) = A4 ).

% Collect_mem_eq
tff(fact_34_Collect__cong,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ! [X2: C] :
          ( aa(C,$o,Pa,X2)
        <=> aa(C,$o,Q,X2) )
     => ( collect(C,Pa) = collect(C,Q) ) ) ).

% Collect_cong
tff(fact_35_ext,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),G: fun(C,D)] :
      ( ! [X2: C] : aa(C,D,F,X2) = aa(C,D,G,X2)
     => ( F = G ) ) ).

% ext
tff(fact_36_list__induct__first2,axiom,
    ! [C: $tType,Pa: fun(list(C),$o),Xs: list(C)] :
      ( aa(list(C),$o,Pa,nil(C))
     => ( ! [X2: C] : aa(list(C),$o,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))
       => ( ! [X1: C,X23: C,Xs2: list(C)] :
              ( aa(list(C),$o,Pa,Xs2)
             => aa(list(C),$o,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs2))) )
         => aa(list(C),$o,Pa,Xs) ) ) ) ).

% list_induct_first2
tff(fact_37_list__2pre__induct,axiom,
    ! [C: $tType,D: $tType,Pa: fun(list(C),fun(list(D),$o)),W1: list(C),W2: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),nil(D))
     => ( ! [E: C,W12: list(C),W22: list(D)] :
            ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,W12),W22)
           => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E),W12)),W22) )
       => ( ! [E: D,W13: list(C),W23: list(D)] :
              ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,W13),W23)
             => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,W13),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),E),W23)) )
         => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,W1),W2) ) ) ) ).

% list_2pre_induct
tff(fact_38_neq__NilE,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( La != nil(C) )
     => ~ ! [X2: C,Xs2: list(C)] : La != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) ) ).

% neq_NilE
tff(fact_39_quicksort_Ocases,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(C)] :
          ( ( X != nil(C) )
         => ~ ! [X2: C,Xs2: list(C)] : X != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) ) ) ).

% quicksort.cases
tff(fact_40_list__assn_Oelims,axiom,
    ! [D: $tType,C: $tType,X: fun(C,fun(D,assn)),Xa: list(C),Xb: list(D),Y: assn] :
      ( ( vEBT_List_list_assn(C,D,X,Xa,Xb) = Y )
     => ( ( ( Xa = nil(C) )
         => ( ( Xb = nil(D) )
           => ( Y != one_one(assn) ) ) )
       => ( ! [A5: C,As: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
             => ! [C2: D,Cs: list(D)] :
                  ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),C2),Cs) )
                 => ( Y != aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),X,A5),C2)),vEBT_List_list_assn(C,D,X,As,Cs)) ) ) )
         => ( ( ? [V2: C,Va2: list(C)] : Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)
             => ( ( Xb = nil(D) )
               => ( Y != bot_bot(assn) ) ) )
           => ~ ( ( Xa = nil(C) )
               => ( ? [V2: D,Va2: list(D)] : Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)
                 => ( Y != bot_bot(assn) ) ) ) ) ) ) ) ).

% list_assn.elims
tff(fact_41_mult__1,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),one_one(C)),A3) = A3 ) ).

% mult_1
tff(fact_42_mult_Oright__neutral,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),one_one(C)) = A3 ) ).

% mult.right_neutral
tff(fact_43_merge__pure__star,axiom,
    ! [A3: $o,B2: $o] :
      aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),pure_assn((A3))),pure_assn((B2))) = pure_assn(( (A3)
        & (B2) )) ).

% merge_pure_star
tff(fact_44_star__false__right,axiom,
    ! [Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),bot_bot(assn)) = bot_bot(assn) ).

% star_false_right
tff(fact_45_star__false__left,axiom,
    ! [Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),bot_bot(assn)),Pa) = bot_bot(assn) ).

% star_false_left
tff(fact_46_is__pure__assn__starI,axiom,
    ! [A3: assn,B2: assn] :
      ( is_pure_assn(A3)
     => ( is_pure_assn(B2)
       => is_pure_assn(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),B2)) ) ) ).

% is_pure_assn_starI
tff(fact_47_assn__times__comm,axiom,
    ! [Pa: assn,Q: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),Q) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),Pa) ).

% assn_times_comm
tff(fact_48_assn__times__assoc,axiom,
    ! [Pa: assn,Q: assn,R: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),Q)),R) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),R)) ).

% assn_times_assoc
tff(fact_49_ab__semigroup__mult__class_Omult_Oleft__commute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% ab_semigroup_mult_class.mult.left_commute
tff(fact_50_ab__semigroup__mult__class_Omult_Ocommute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3) ) ).

% ab_semigroup_mult_class.mult.commute
tff(fact_51_mult_Oassoc,axiom,
    ! [C: $tType] :
      ( semigroup_mult(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% mult.assoc
tff(fact_52_mult_Ocomm__neutral,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),one_one(C)) = A3 ) ).

% mult.comm_neutral
tff(fact_53_comm__monoid__mult__class_Omult__1,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),one_one(C)),A3) = A3 ) ).

% comm_monoid_mult_class.mult_1
tff(fact_54_assn__one__left,axiom,
    ! [Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),one_one(assn)),Pa) = Pa ).

% assn_one_left
tff(fact_55_list__assn_Osimps_I2_J,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,assn)),A3: C,As2: list(C),C3: D,Cs2: list(D)] : vEBT_List_list_assn(C,D,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),As2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),C3),Cs2)) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),Pa,A3),C3)),vEBT_List_list_assn(C,D,Pa,As2,Cs2)) ).

% list_assn.simps(2)
tff(fact_56_one__reorient,axiom,
    ! [C: $tType] :
      ( one(C)
     => ! [X: C] :
          ( ( one_one(C) = X )
        <=> ( X = one_one(C) ) ) ) ).

% one_reorient
tff(fact_57_bot__fun__def,axiom,
    ! [C: $tType,D: $tType] :
      ( bot(D)
     => ! [X3: C] : aa(C,D,bot_bot(fun(C,D)),X3) = bot_bot(D) ) ).

% bot_fun_def
tff(fact_58_list__tail__coinc,axiom,
    ! [C: $tType,N1: C,R1: list(C),N2: C,R2: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),N1),R1) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),N2),R2) )
     => ( ( N1 = N2 )
        & ( R1 = R2 ) ) ) ).

% list_tail_coinc
tff(fact_59_norm__assertion__simps_I1_J,axiom,
    ! [A3: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),one_one(assn)),A3) = A3 ).

% norm_assertion_simps(1)
tff(fact_60_norm__assertion__simps_I2_J,axiom,
    ! [A3: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),one_one(assn)) = A3 ).

% norm_assertion_simps(2)
tff(fact_61_product__lists_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(list(C)),list(list(C)),product_lists(C),nil(list(C))) = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),nil(list(C))) ).

% product_lists.simps(1)
tff(fact_62_sngr__same__false,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [P3: ref(C),X: C,Y: C] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sngr_assn(C,P3,X)),sngr_assn(C,P3,Y)) = bot_bot(assn) ) ).

% sngr_same_false
tff(fact_63_subseqs_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),list(list(C)),subseqs(C),nil(C)) = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),nil(list(C))) ).

% subseqs.simps(1)
tff(fact_64_insert__Nil,axiom,
    ! [C: $tType,X: C] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),nil(C)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ).

% insert_Nil
tff(fact_65_snga__same__false,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [P3: array(C),X: list(C),Y: list(C)] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),snga_assn(C,P3,X)),snga_assn(C,P3,Y)) = bot_bot(assn) ) ).

% snga_same_false
tff(fact_66_revg_Oelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: list(C)] :
      ( ( revg(C,X,Xa) = Y )
     => ( ( ( X = nil(C) )
         => ( Y != Xa ) )
       => ~ ! [A5: C,As: list(C)] :
              ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
             => ( Y != revg(C,As,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),Xa)) ) ) ) ) ).

% revg.elims
tff(fact_67_list__collect__set__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,F: fun(D,set(C)),A3: D] : list_collect_set(D,C,F,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),nil(D))) = aa(D,set(C),F,A3) ).

% list_collect_set_simps(2)
tff(fact_68_map__tailrec__rev_Oelims,axiom,
    ! [D: $tType,C: $tType,X: fun(D,C),Xa: list(D),Xb: list(C),Y: list(C)] :
      ( ( map_tailrec_rev(D,C,X,Xa,Xb) = Y )
     => ( ( ( Xa = nil(D) )
         => ( Y != Xb ) )
       => ~ ! [A5: D,As: list(D)] :
              ( ( Xa = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),As) )
             => ( Y != map_tailrec_rev(D,C,X,As,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,X,A5)),Xb)) ) ) ) ) ).

% map_tailrec_rev.elims
tff(fact_69_arg__min__list_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C] : arg_min_list(C,D,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = X ) ).

% arg_min_list.simps(1)
tff(fact_70_ord_Olexordp__eq__simps_I3_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Xs: list(C)] : ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),nil(C)) ).

% ord.lexordp_eq_simps(3)
tff(fact_71_ord_Olexordp__eq__simps_I4_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Xs: list(C),Y: C,Ys: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))
    <=> ( aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
        | ( ~ aa(C,$o,aa(C,fun(C,$o),Less,Y),X)
          & aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs),Ys) ) ) ) ).

% ord.lexordp_eq_simps(4)
tff(fact_72_ord_Olexordp__eq__simps_I1_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Ys: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),nil(C)),Ys) ).

% ord.lexordp_eq_simps(1)
tff(fact_73_ord_Olexordp__eq__simps_I2_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Xs: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs),nil(C))
    <=> ( Xs = nil(C) ) ) ).

% ord.lexordp_eq_simps(2)
tff(fact_74_list__collect__set__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,set(C))] : list_collect_set(D,C,F,nil(D)) = bot_bot(set(C)) ).

% list_collect_set_simps(1)
tff(fact_75_ord_Olexordp__eq__refl,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Xs: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs),Xs) ).

% ord.lexordp_eq_refl
tff(fact_76_ord_Olexordp__eq_Ocong,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o))] : lexordp_eq(C,Less) = lexordp_eq(C,Less) ).

% ord.lexordp_eq.cong
tff(fact_77_ord_Olexordp__eq_OCons,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Y: C,Xs: list(C),Ys: list(C)] :
      ( aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ).

% ord.lexordp_eq.Cons
tff(fact_78_ord_Olexordp__eq_OCons__eq,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Y: C,Xs: list(C),Ys: list(C)] :
      ( ~ aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
     => ( ~ aa(C,$o,aa(C,fun(C,$o),Less,Y),X)
       => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs),Ys)
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ) ).

% ord.lexordp_eq.Cons_eq
tff(fact_79_ord_Olexordp__eq_ONil,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Ys: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),nil(C)),Ys) ).

% ord.lexordp_eq.Nil
tff(fact_80_map__tailrec__rev_Osimps_I2_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A3: D,As2: list(D),Bs: list(C)] : map_tailrec_rev(D,C,F,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),As2),Bs) = map_tailrec_rev(D,C,F,As2,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,F,A3)),Bs)) ).

% map_tailrec_rev.simps(2)
tff(fact_81_map__tailrec__rev_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Bs: list(C)] : map_tailrec_rev(D,C,F,nil(D),Bs) = Bs ).

% map_tailrec_rev.simps(1)
tff(fact_82_revg_Osimps_I2_J,axiom,
    ! [C: $tType,A3: C,As2: list(C),B2: list(C)] : revg(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),As2),B2) = revg(C,As2,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),B2)) ).

% revg.simps(2)
tff(fact_83_revg_Osimps_I1_J,axiom,
    ! [C: $tType,B2: list(C)] : revg(C,nil(C),B2) = B2 ).

% revg.simps(1)
tff(fact_84_ord_Olexordp__eq_Ocases,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),A1: list(C),A22: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),A1),A22)
     => ( ( A1 != nil(C) )
       => ( ! [X2: C] :
              ( ? [Xs2: list(C)] : A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)
             => ! [Y2: C] :
                  ( ? [Ys2: list(C)] : A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)
                 => ~ aa(C,$o,aa(C,fun(C,$o),Less,X2),Y2) ) )
         => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ! [Ys2: list(C)] :
                    ( ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                   => ( ~ aa(C,$o,aa(C,fun(C,$o),Less,X2),Y2)
                     => ( ~ aa(C,$o,aa(C,fun(C,$o),Less,Y2),X2)
                       => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs2),Ys2) ) ) ) ) ) ) ) ).

% ord.lexordp_eq.cases
tff(fact_85_ord_Olexordp__eq_Osimps,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),A1: list(C),A22: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),A1),A22)
    <=> ( ? [Ys3: list(C)] :
            ( ( A1 = nil(C) )
            & ( A22 = Ys3 ) )
        | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
            ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
            & aa(C,$o,aa(C,fun(C,$o),Less,X4),Y3) )
        | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
            ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
            & ~ aa(C,$o,aa(C,fun(C,$o),Less,X4),Y3)
            & ~ aa(C,$o,aa(C,fun(C,$o),Less,Y3),X4)
            & aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs3),Ys3) ) ) ) ).

% ord.lexordp_eq.simps
tff(fact_86_assn__aci_I10_J,axiom,
    ! [A3: assn,B2: assn,C3: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),B2)),C3) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),C3)),B2) ).

% assn_aci(10)
tff(fact_87_star__aci_I3_J,axiom,
    ! [A3: assn,B2: assn,C3: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B2),C3)) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B2),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),C3)) ).

% star_aci(3)
tff(fact_88_star__aci_I2_J,axiom,
    ! [A3: assn,B2: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),B2) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B2),A3) ).

% star_aci(2)
tff(fact_89_star__assoc,axiom,
    ! [A3: assn,B2: assn,C3: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),B2)),C3) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B2),C3)) ).

% star_assoc
tff(fact_90_and__extract__pure__left__iff,axiom,
    ! [B2: $o,Q: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),pure_assn((B2))),Q) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),one_one(assn)),Q)),pure_assn((B2))) ).

% and_extract_pure_left_iff
tff(fact_91_and__extract__pure__right__iff,axiom,
    ! [Pa: assn,B2: $o] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),pure_assn((B2))) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),one_one(assn)),Pa)),pure_assn((B2))) ).

% and_extract_pure_right_iff
tff(fact_92_list__collect__set__map__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F: fun(D,set(C)),X: fun(E2,D),A3: E2] : list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),A3),nil(E2)))) = aa(D,set(C),F,aa(E2,D,X,A3)) ).

% list_collect_set_map_simps(2)
tff(fact_93_listrelp_Ocases,axiom,
    ! [C: $tType,D: $tType,R3: fun(C,fun(D,$o)),A1: list(C),A22: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),A1),A22)
     => ( ( ( A1 = nil(C) )
         => ( A22 != nil(D) ) )
       => ~ ! [X2: C,Y2: D,Xs2: list(C)] :
              ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
             => ! [Ys2: list(D)] :
                  ( ( A22 = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2) )
                 => ( aa(D,$o,aa(C,fun(D,$o),R3,X2),Y2)
                   => ~ aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),Xs2),Ys2) ) ) ) ) ) ).

% listrelp.cases
tff(fact_94_listrelp_Osimps,axiom,
    ! [C: $tType,D: $tType,R3: fun(C,fun(D,$o)),A1: list(C),A22: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),A1),A22)
    <=> ( ( ( A1 = nil(C) )
          & ( A22 = nil(D) ) )
        | ? [X4: C,Y3: D,Xs3: list(C),Ys3: list(D)] :
            ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( A22 = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y3),Ys3) )
            & aa(D,$o,aa(C,fun(D,$o),R3,X4),Y3)
            & aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),Xs3),Ys3) ) ) ) ).

% listrelp.simps
tff(fact_95_mergesort__by__rel__simps_I2_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),X: C] : aa(list(C),list(C),mergesort_by_rel(C,R),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ).

% mergesort_by_rel_simps(2)
tff(fact_96_lexordp__eq__simps_I3_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Xs: list(C)] : ~ ord_lexordp_eq(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),nil(C)) ) ).

% lexordp_eq_simps(3)
tff(fact_97_entails__solve__finalize_I2_J,axiom,
    ! [M: list(product_prod(assn,assn))] : fI_RESULT(M,one_one(assn),one_one(assn),one_one(assn)) ).

% entails_solve_finalize(2)
tff(fact_98_frame__inference__finalize,axiom,
    ! [M: list(product_prod(assn,assn)),F2: assn] : fI_RESULT(M,F2,one_one(assn),F2) ).

% frame_inference_finalize
tff(fact_99_mult_Oright__assoc,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% mult.right_assoc
tff(fact_100_mult_Oright__commute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2) ) ).

% mult.right_commute
tff(fact_101_list_Omap__disc__iff,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A3: list(D)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),A3) = nil(C) )
    <=> ( A3 = nil(D) ) ) ).

% list.map_disc_iff
tff(fact_102_Nil__is__map__conv,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] :
      ( ( nil(C) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) )
    <=> ( Xs = nil(D) ) ) ).

% Nil_is_map_conv
tff(fact_103_map__is__Nil__conv,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = nil(C) )
    <=> ( Xs = nil(D) ) ) ).

% map_is_Nil_conv
tff(fact_104_lexordp__eq__simps_I2_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Xs: list(C)] :
          ( ord_lexordp_eq(C,Xs,nil(C))
        <=> ( Xs = nil(C) ) ) ) ).

% lexordp_eq_simps(2)
tff(fact_105_lexordp__eq__simps_I1_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Ys: list(C)] : ord_lexordp_eq(C,nil(C),Ys) ) ).

% lexordp_eq_simps(1)
tff(fact_106_mergesort__by__rel__simps_I1_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o))] : aa(list(C),list(C),mergesort_by_rel(C,R),nil(C)) = nil(C) ).

% mergesort_by_rel_simps(1)
tff(fact_107_merge__pure__and,axiom,
    ! [A3: $o,B2: $o] :
      aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),pure_assn((A3))),pure_assn((B2))) = pure_assn(( (A3)
        & (B2) )) ).

% merge_pure_and
tff(fact_108_and__extract__pure__right__ctx__iff,axiom,
    ! [Pa: assn,Q: assn,B2: $o] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),pure_assn((B2)))) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),Q)),pure_assn((B2))) ).

% and_extract_pure_right_ctx_iff
tff(fact_109_and__extract__pure__left__ctx__iff,axiom,
    ! [Pa: assn,B2: $o,Q: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),pure_assn((B2)))),Q) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),Q)),pure_assn((B2))) ).

% and_extract_pure_left_ctx_iff
tff(fact_110_list__collect__set__map__simps_I1_J,axiom,
    ! [E2: $tType,D: $tType,C: $tType,F: fun(D,set(C)),X: fun(E2,D)] : list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),nil(E2))) = bot_bot(set(C)) ).

% list_collect_set_map_simps(1)
tff(fact_111_assn__aci_I4_J,axiom,
    ! [X: assn,Y: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),Y)) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),Y) ).

% assn_aci(4)
tff(fact_112_assn__aci_I3_J,axiom,
    ! [X: assn,Y: assn,Z2: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Y),Z2)) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Y),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),Z2)) ).

% assn_aci(3)
tff(fact_113_assn__aci_I1_J,axiom,
    ! [X: assn,Y: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),Y) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Y),X) ).

% assn_aci(1)
tff(fact_114_norm__assertion__simps_I31_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),X) = X ).

% norm_assertion_simps(31)
tff(fact_115_norm__assertion__simps_I14_J,axiom,
    ! [X: assn,Y: assn,Z2: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),Y)),Z2) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Y),Z2)) ).

% norm_assertion_simps(14)
tff(fact_116_lexordp__eq__refl,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Xs: list(C)] : ord_lexordp_eq(C,Xs,Xs) ) ).

% lexordp_eq_refl
tff(fact_117_lexordp__eq__trans,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C),Zs: list(C)] :
          ( ord_lexordp_eq(C,Xs,Ys)
         => ( ord_lexordp_eq(C,Ys,Zs)
           => ord_lexordp_eq(C,Xs,Zs) ) ) ) ).

% lexordp_eq_trans
tff(fact_118_lexordp__eq__linear,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( ord_lexordp_eq(C,Xs,Ys)
          | ord_lexordp_eq(C,Ys,Xs) ) ) ).

% lexordp_eq_linear
tff(fact_119_lexordp__eq__antisym,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( ord_lexordp_eq(C,Xs,Ys)
         => ( ord_lexordp_eq(C,Ys,Xs)
           => ( Xs = Ys ) ) ) ) ).

% lexordp_eq_antisym
tff(fact_120_memb__imp__not__empty,axiom,
    ! [C: $tType,X: C,S: set(C)] :
      ( member2(C,X,S)
     => ( S != bot_bot(set(C)) ) ) ).

% memb_imp_not_empty
tff(fact_121_set__notEmptyE,axiom,
    ! [C: $tType,S: set(C)] :
      ( ( S != bot_bot(set(C)) )
     => ~ ! [X2: C] : ~ member2(C,X2,S) ) ).

% set_notEmptyE
tff(fact_122_map__eq__consE,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Ls: list(D),Fa: C,Fl: list(C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ls) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Fa),Fl) )
     => ~ ! [A5: D,L: list(D)] :
            ( ( Ls = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),L) )
           => ( ( aa(D,C,F,A5) = Fa )
             => ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L) != Fl ) ) ) ) ).

% map_eq_consE
tff(fact_123_map__consI_I1_J,axiom,
    ! [C: $tType,D: $tType,W: list(C),F: fun(D,C),Ww: list(D),A3: D] :
      ( ( W = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ww) )
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,F,A3)),W) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),Ww)) ) ) ).

% map_consI(1)
tff(fact_124_map__eq__Cons__conv,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Xs: list(D),Y: C,Ys: list(C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys) )
    <=> ? [Z3: D,Zs2: list(D)] :
          ( ( Xs = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Z3),Zs2) )
          & ( aa(D,C,F,Z3) = Y )
          & ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Zs2) = Ys ) ) ) ).

% map_eq_Cons_conv
tff(fact_125_Cons__eq__map__conv,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(C),F: fun(D,C),Ys: list(D)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ys) )
    <=> ? [Z3: D,Zs2: list(D)] :
          ( ( Ys = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Z3),Zs2) )
          & ( X = aa(D,C,F,Z3) )
          & ( Xs = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Zs2) ) ) ) ).

% Cons_eq_map_conv
tff(fact_126_map__eq__Cons__D,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Xs: list(D),Y: C,Ys: list(C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys) )
     => ? [Z4: D,Zs3: list(D)] :
          ( ( Xs = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Z4),Zs3) )
          & ( aa(D,C,F,Z4) = Y )
          & ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Zs3) = Ys ) ) ) ).

% map_eq_Cons_D
tff(fact_127_Cons__eq__map__D,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(C),F: fun(D,C),Ys: list(D)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ys) )
     => ? [Z4: D,Zs3: list(D)] :
          ( ( Ys = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Z4),Zs3) )
          & ( X = aa(D,C,F,Z4) )
          & ( Xs = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Zs3) ) ) ) ).

% Cons_eq_map_D
tff(fact_128_list_Osimps_I9_J,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),X21: D,X22: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X21),X22)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,F,X21)),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),X22)) ).

% list.simps(9)
tff(fact_129_list_Osimps_I8_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),nil(D)) = nil(C) ).

% list.simps(8)
tff(fact_130_norm__assertion__simps_I9_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),bot_bot(assn)),X) = bot_bot(assn) ).

% norm_assertion_simps(9)
tff(fact_131_norm__assertion__simps_I10_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),bot_bot(assn)) = bot_bot(assn) ).

% norm_assertion_simps(10)
tff(fact_132_lexordp__eq_ONil,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Ys: list(C)] : ord_lexordp_eq(C,nil(C),Ys) ) ).

% lexordp_eq.Nil
tff(fact_133_listrelp_OCons,axiom,
    ! [C: $tType,D: $tType,R3: fun(C,fun(D,$o)),X: C,Y: D,Xs: list(C),Ys: list(D)] :
      ( aa(D,$o,aa(C,fun(D,$o),R3,X),Y)
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),Xs),Ys)
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys)) ) ) ).

% listrelp.Cons
tff(fact_134_listrelp_ONil,axiom,
    ! [C: $tType,D: $tType,R3: fun(C,fun(D,$o))] : aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,R3),nil(C)),nil(D)) ).

% listrelp.Nil
tff(fact_135_boolean__algebra_Oconj__zero__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),bot_bot(C)) = bot_bot(C) ) ).

% boolean_algebra.conj_zero_right
tff(fact_136_boolean__algebra_Oconj__zero__left,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),bot_bot(C)),X) = bot_bot(C) ) ).

% boolean_algebra.conj_zero_left
tff(fact_137_inf__bot__right,axiom,
    ! [C: $tType] :
      ( bounded_lattice_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),bot_bot(C)) = bot_bot(C) ) ).

% inf_bot_right
tff(fact_138_inf__bot__left,axiom,
    ! [C: $tType] :
      ( bounded_lattice_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),bot_bot(C)),X) = bot_bot(C) ) ).

% inf_bot_left
tff(fact_139_inf__apply,axiom,
    ! [C: $tType,D: $tType] :
      ( semilattice_inf(C)
     => ! [F: fun(D,C),G: fun(D,C),X: D] : aa(D,C,aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),inf_inf(fun(D,C)),F),G),X) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(D,C,F,X)),aa(D,C,G,X)) ) ).

% inf_apply
tff(fact_140_inf__right__idem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),Y) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) ) ).

% inf_right_idem
tff(fact_141_inf_Oright__idem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),B2) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) ) ).

% inf.right_idem
tff(fact_142_inf__left__idem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) ) ).

% inf_left_idem
tff(fact_143_inf_Oleft__idem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) ) ).

% inf.left_idem
tff(fact_144_inf__idem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),X) = X ) ).

% inf_idem
tff(fact_145_inf_Oidem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),A3) = A3 ) ).

% inf.idem
tff(fact_146_empty__Collect__eq,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ( bot_bot(set(C)) = collect(C,Pa) )
    <=> ! [X4: C] : ~ aa(C,$o,Pa,X4) ) ).

% empty_Collect_eq
tff(fact_147_empty__iff,axiom,
    ! [C: $tType,C3: C] : ~ member2(C,C3,bot_bot(set(C))) ).

% empty_iff
tff(fact_148_all__not__in__conv,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ! [X4: C] : ~ member2(C,X4,A4)
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% all_not_in_conv
tff(fact_149_Collect__empty__eq,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ( collect(C,Pa) = bot_bot(set(C)) )
    <=> ! [X4: C] : ~ aa(C,$o,Pa,X4) ) ).

% Collect_empty_eq
tff(fact_150_Int__emptyI,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,A4)
         => ~ member2(C,X2,B3) )
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) ) ) ).

% Int_emptyI
tff(fact_151_disjoint__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
    <=> ! [X4: C] :
          ( member2(C,X4,A4)
         => ~ member2(C,X4,B3) ) ) ).

% disjoint_iff
tff(fact_152_Int__empty__left,axiom,
    ! [C: $tType,B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),bot_bot(set(C))),B3) = bot_bot(set(C)) ).

% Int_empty_left
tff(fact_153_Int__empty__right,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),bot_bot(set(C))) = bot_bot(set(C)) ).

% Int_empty_right
tff(fact_154_disjoint__iff__not__equal,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
    <=> ! [X4: C] :
          ( member2(C,X4,A4)
         => ! [Xa2: C] :
              ( member2(C,Xa2,B3)
             => ( X4 != Xa2 ) ) ) ) ).

% disjoint_iff_not_equal
tff(fact_155_disjointI,axiom,
    ! [C: $tType,A3: set(C),B2: set(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,A3)
         => ~ member2(C,X2,B2) )
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A3),B2) = bot_bot(set(C)) ) ) ).

% disjointI
tff(fact_156_emptyE,axiom,
    ! [C: $tType,A3: C] : ~ member2(C,A3,bot_bot(set(C))) ).

% emptyE
tff(fact_157_equals0D,axiom,
    ! [C: $tType,A4: set(C),A3: C] :
      ( ( A4 = bot_bot(set(C)) )
     => ~ member2(C,A3,A4) ) ).

% equals0D
tff(fact_158_equals0I,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ! [Y2: C] : ~ member2(C,Y2,A4)
     => ( A4 = bot_bot(set(C)) ) ) ).

% equals0I
tff(fact_159_ex__in__conv,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ? [X4: C] : member2(C,X4,A4)
    <=> ( A4 != bot_bot(set(C)) ) ) ).

% ex_in_conv
tff(fact_160_bot__set__def,axiom,
    ! [C: $tType] : bot_bot(set(C)) = collect(C,bot_bot(fun(C,$o))) ).

% bot_set_def
tff(fact_161_inf__sup__aci_I4_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) ) ).

% inf_sup_aci(4)
tff(fact_162_inf__sup__aci_I3_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Z2)) ) ).

% inf_sup_aci(3)
tff(fact_163_inf__sup__aci_I2_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),Z2) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) ) ).

% inf_sup_aci(2)
tff(fact_164_inf__sup__aci_I1_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),X) ) ).

% inf_sup_aci(1)
tff(fact_165_inf_Oassoc,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),C3)) ) ).

% inf.assoc
tff(fact_166_inf__assoc,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),Z2) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) ) ).

% inf_assoc
tff(fact_167_inf_Ocommute,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),A3) ) ).

% inf.commute
tff(fact_168_inf__commute,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),X) ) ).

% inf_commute
tff(fact_169_boolean__algebra__cancel_Oinf1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: C,K: C,A3: C,B2: C] :
          ( ( A4 = aa(C,C,aa(C,fun(C,C),inf_inf(C),K),A3) )
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A4),B2) = aa(C,C,aa(C,fun(C,C),inf_inf(C),K),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)) ) ) ) ).

% boolean_algebra_cancel.inf1
tff(fact_170_boolean__algebra__cancel_Oinf2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B3: C,K: C,B2: C,A3: C] :
          ( ( B3 = aa(C,C,aa(C,fun(C,C),inf_inf(C),K),B2) )
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B3) = aa(C,C,aa(C,fun(C,C),inf_inf(C),K),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)) ) ) ) ).

% boolean_algebra_cancel.inf2
tff(fact_171_inf_Oleft__commute,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),C3)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),C3)) ) ).

% inf.left_commute
tff(fact_172_inf__left__commute,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Z2)) ) ).

% inf_left_commute
tff(fact_173_inf__fun__def,axiom,
    ! [D: $tType,C: $tType] :
      ( semilattice_inf(D)
     => ! [F: fun(C,D),G: fun(C,D),X3: C] : aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),inf_inf(fun(C,D)),F),G),X3) = aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(C,D,F,X3)),aa(C,D,G,X3)) ) ).

% inf_fun_def
tff(fact_174_FI__finalize,axiom,
    ! [M2: list(product_prod(assn,assn)),P3: assn,Up: assn,Q2: assn,Uq: assn,F: assn] :
      ( fI_RESULT(M2,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),P3),Up),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q2),Uq),F)
     => fi(M2,P3,Q2,Up,Uq,F) ) ).

% FI_finalize
tff(fact_175_Set_Ois__empty__def,axiom,
    ! [C: $tType,A4: set(C)] :
      ( is_empty(C,A4)
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% Set.is_empty_def
tff(fact_176_map__eq__map__tailrec,axiom,
    ! [D: $tType,C: $tType] : map(C,D) = map_tailrec(C,D) ).

% map_eq_map_tailrec
tff(fact_177_list__collect__set__map__simps_I3_J,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F: fun(D,set(C)),X: fun(E2,D),A3: E2,La: list(E2)] : list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),A3),La))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(D,set(C),F,aa(E2,D,X,A3))),list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),La))) ).

% list_collect_set_map_simps(3)
tff(fact_178_sorted__list__of__set_Osorted__key__list__of__set__empty,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( aa(set(C),list(C),linord4507533701916653071of_set(C),bot_bot(set(C))) = nil(C) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_empty
tff(fact_179_lexordp__eq_Ocases,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A1: list(C),A22: list(C)] :
          ( ord_lexordp_eq(C,A1,A22)
         => ( ( A1 != nil(C) )
           => ( ! [X2: C] :
                  ( ? [Xs2: list(C)] : A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)
                 => ! [Y2: C] :
                      ( ? [Ys2: list(C)] : A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)
                     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2) ) )
             => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                    ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                   => ! [Ys2: list(C)] :
                        ( ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                       => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2)
                         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y2),X2)
                           => ~ ord_lexordp_eq(C,Xs2,Ys2) ) ) ) ) ) ) ) ) ).

% lexordp_eq.cases
tff(fact_180_lexordp__eq_Osimps,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A1: list(C),A22: list(C)] :
          ( ord_lexordp_eq(C,A1,A22)
        <=> ( ? [Ys3: list(C)] :
                ( ( A1 = nil(C) )
                & ( A22 = Ys3 ) )
            | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
                ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
                & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
                & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y3) )
            | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
                ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
                & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
                & ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y3)
                & ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y3),X4)
                & ord_lexordp_eq(C,Xs3,Ys3) ) ) ) ) ).

% lexordp_eq.simps
tff(fact_181_bot__empty__eq,axiom,
    ! [C: $tType,X3: C] :
      ( aa(C,$o,bot_bot(fun(C,$o)),X3)
    <=> member2(C,X3,bot_bot(set(C))) ) ).

% bot_empty_eq
tff(fact_182_Collect__empty__eq__bot,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ( collect(C,Pa) = bot_bot(set(C)) )
    <=> ( Pa = bot_bot(fun(C,$o)) ) ) ).

% Collect_empty_eq_bot
tff(fact_183_mult_Osafe__commute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => ! [X: C,Y: C,A3: C,B2: C] :
          ( syntax7388354845996824322omatch(C,C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Y),A3)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3) ) ) ) ).

% mult.safe_commute
tff(fact_184_sup_Oidem,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),A3) = A3 ) ).

% sup.idem
tff(fact_185_sup__idem,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),X) = X ) ).

% sup_idem
tff(fact_186_sup_Oleft__idem,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) ) ).

% sup.left_idem
tff(fact_187_sup__left__idem,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) ) ).

% sup_left_idem
tff(fact_188_sup_Oright__idem,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)),B2) = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) ) ).

% sup.right_idem
tff(fact_189_sup__apply,axiom,
    ! [C: $tType,D: $tType] :
      ( semilattice_sup(C)
     => ! [F: fun(D,C),G: fun(D,C),X: D] : aa(D,C,aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),sup_sup(fun(D,C)),F),G),X) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(D,C,F,X)),aa(D,C,G,X)) ) ).

% sup_apply
tff(fact_190_Int__iff,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
    <=> ( member2(C,C3,A4)
        & member2(C,C3,B3) ) ) ).

% Int_iff
tff(fact_191_IntI,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,A4)
     => ( member2(C,C3,B3)
       => member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% IntI
tff(fact_192_UnCI,axiom,
    ! [C: $tType,C3: C,B3: set(C),A4: set(C)] :
      ( ( ~ member2(C,C3,B3)
       => member2(C,C3,A4) )
     => member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ) ).

% UnCI
tff(fact_193_Un__iff,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
    <=> ( member2(C,C3,A4)
        | member2(C,C3,B3) ) ) ).

% Un_iff
tff(fact_194_sup__bot_Oright__neutral,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),bot_bot(C)) = A3 ) ).

% sup_bot.right_neutral
tff(fact_195_sup__bot_Oneutr__eq__iff,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [A3: C,B2: C] :
          ( ( bot_bot(C) = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) )
        <=> ( ( A3 = bot_bot(C) )
            & ( B2 = bot_bot(C) ) ) ) ) ).

% sup_bot.neutr_eq_iff
tff(fact_196_sup__bot_Oleft__neutral,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),bot_bot(C)),A3) = A3 ) ).

% sup_bot.left_neutral
tff(fact_197_sup__bot_Oeq__neutr__iff,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = bot_bot(C) )
        <=> ( ( A3 = bot_bot(C) )
            & ( B2 = bot_bot(C) ) ) ) ) ).

% sup_bot.eq_neutr_iff
tff(fact_198_sup__eq__bot__iff,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = bot_bot(C) )
        <=> ( ( X = bot_bot(C) )
            & ( Y = bot_bot(C) ) ) ) ) ).

% sup_eq_bot_iff
tff(fact_199_bot__eq__sup__iff,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [X: C,Y: C] :
          ( ( bot_bot(C) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) )
        <=> ( ( X = bot_bot(C) )
            & ( Y = bot_bot(C) ) ) ) ) ).

% bot_eq_sup_iff
tff(fact_200_sup__bot__right,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),bot_bot(C)) = X ) ).

% sup_bot_right
tff(fact_201_sup__bot__left,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),bot_bot(C)),X) = X ) ).

% sup_bot_left
tff(fact_202_sup__inf__absorb,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)) = X ) ).

% sup_inf_absorb
tff(fact_203_inf__sup__absorb,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) = X ) ).

% inf_sup_absorb
tff(fact_204_Un__empty,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = bot_bot(set(C)) )
    <=> ( ( A4 = bot_bot(set(C)) )
        & ( B3 = bot_bot(set(C)) ) ) ) ).

% Un_empty
tff(fact_205_Un__Int__eq_I1_J,axiom,
    ! [C: $tType,S: set(C),T: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),S),T)),S) = S ).

% Un_Int_eq(1)
tff(fact_206_Un__Int__eq_I2_J,axiom,
    ! [C: $tType,S: set(C),T: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),S),T)),T) = T ).

% Un_Int_eq(2)
tff(fact_207_Un__Int__eq_I3_J,axiom,
    ! [C: $tType,S: set(C),T: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),S),T)) = S ).

% Un_Int_eq(3)
tff(fact_208_Un__Int__eq_I4_J,axiom,
    ! [C: $tType,T: set(C),S: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),T),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),S),T)) = T ).

% Un_Int_eq(4)
tff(fact_209_Int__Un__eq_I1_J,axiom,
    ! [C: $tType,S: set(C),T: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),T)),S) = S ).

% Int_Un_eq(1)
tff(fact_210_Int__Un__eq_I2_J,axiom,
    ! [C: $tType,S: set(C),T: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),T)),T) = T ).

% Int_Un_eq(2)
tff(fact_211_Int__Un__eq_I3_J,axiom,
    ! [C: $tType,S: set(C),T: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),S),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),T)) = S ).

% Int_Un_eq(3)
tff(fact_212_Int__Un__eq_I4_J,axiom,
    ! [C: $tType,T: set(C),S: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),T),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),T)) = T ).

% Int_Un_eq(4)
tff(fact_213_lexordp__eq__simps_I4_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Xs: list(C),Y: C,Ys: list(C)] :
          ( ord_lexordp_eq(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
            | ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
              & ord_lexordp_eq(C,Xs,Ys) ) ) ) ) ).

% lexordp_eq_simps(4)
tff(fact_214_list__collect__set__simps_I3_J,axiom,
    ! [C: $tType,D: $tType,F: fun(D,set(C)),A3: D,La: list(D)] : list_collect_set(D,C,F,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),La)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(D,set(C),F,A3)),list_collect_set(D,C,F,La)) ).

% list_collect_set_simps(3)
tff(fact_215_Int__left__commute,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4)) ).

% Int_left_commute
tff(fact_216_Un__Int__distrib2,axiom,
    ! [C: $tType,B3: set(C),C4: set(C),A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)),A4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),A4)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),C4),A4)) ).

% Un_Int_distrib2
tff(fact_217_Int__left__absorb,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ).

% Int_left_absorb
tff(fact_218_Int__Un__distrib2,axiom,
    ! [C: $tType,B3: set(C),C4: set(C),A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)),A4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),A4)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C4),A4)) ).

% Int_Un_distrib2
tff(fact_219_Un__Int__distrib,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),C4)) ).

% Un_Int_distrib
tff(fact_220_Int__Un__distrib,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4)) ).

% Int_Un_distrib
tff(fact_221_Un__Int__crazy,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C4),A4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),C4),A4)) ).

% Un_Int_crazy
tff(fact_222_Int__commute,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),A4) ).

% Int_commute
tff(fact_223_Int__absorb,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),A4) = A4 ).

% Int_absorb
tff(fact_224_Int__assoc,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),C4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) ).

% Int_assoc
tff(fact_225_IntD2,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
     => member2(C,C3,B3) ) ).

% IntD2
tff(fact_226_IntD1,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
     => member2(C,C3,A4) ) ).

% IntD1
tff(fact_227_IntE,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
     => ~ ( member2(C,C3,A4)
         => ~ member2(C,C3,B3) ) ) ).

% IntE
tff(fact_228_inf__sup__aci_I8_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) ) ).

% inf_sup_aci(8)
tff(fact_229_inf__sup__aci_I7_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Z2)) ) ).

% inf_sup_aci(7)
tff(fact_230_inf__sup__aci_I6_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),Z2) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) ) ).

% inf_sup_aci(6)
tff(fact_231_inf__sup__aci_I5_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),X) ) ).

% inf_sup_aci(5)
tff(fact_232_sup_Oassoc,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),C3)) ) ).

% sup.assoc
tff(fact_233_sup__assoc,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),Z2) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) ) ).

% sup_assoc
tff(fact_234_less__supI1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% less_supI1
tff(fact_235_less__supI2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% less_supI2
tff(fact_236_sup_Oabsorb3,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = A3 ) ) ) ).

% sup.absorb3
tff(fact_237_sup_Oabsorb4,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = B2 ) ) ) ).

% sup.absorb4
tff(fact_238_sup_Ocommute,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),A3) ) ).

% sup.commute
tff(fact_239_sup__commute,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),X) ) ).

% sup_commute
tff(fact_240_boolean__algebra__cancel_Osup1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: C,K: C,A3: C,B2: C] :
          ( ( A4 = aa(C,C,aa(C,fun(C,C),sup_sup(C),K),A3) )
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A4),B2) = aa(C,C,aa(C,fun(C,C),sup_sup(C),K),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ) ).

% boolean_algebra_cancel.sup1
tff(fact_241_boolean__algebra__cancel_Osup2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B3: C,K: C,B2: C,A3: C] :
          ( ( B3 = aa(C,C,aa(C,fun(C,C),sup_sup(C),K),B2) )
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B3) = aa(C,C,aa(C,fun(C,C),sup_sup(C),K),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ) ).

% boolean_algebra_cancel.sup2
tff(fact_242_sup_Oleft__commute,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),C3)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),C3)) ) ).

% sup.left_commute
tff(fact_243_sup__left__commute,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Z2)) ) ).

% sup_left_commute
tff(fact_244_sup_Ostrict__boundedE,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),C3)),A3)
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3) ) ) ) ).

% sup.strict_boundedE
tff(fact_245_sup_Ostrict__order__iff,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
        <=> ( ( A3 = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) )
            & ( A3 != B2 ) ) ) ) ).

% sup.strict_order_iff
tff(fact_246_sup_Ostrict__coboundedI1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% sup.strict_coboundedI1
tff(fact_247_sup_Ostrict__coboundedI2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% sup.strict_coboundedI2
tff(fact_248_UnE,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
     => ( ~ member2(C,C3,A4)
       => member2(C,C3,B3) ) ) ).

% UnE
tff(fact_249_UnI1,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,A4)
     => member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ) ).

% UnI1
tff(fact_250_UnI2,axiom,
    ! [C: $tType,C3: C,B3: set(C),A4: set(C)] :
      ( member2(C,C3,B3)
     => member2(C,C3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ) ).

% UnI2
tff(fact_251_bex__Un,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( member2(C,X4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
          & aa(C,$o,Pa,X4) )
    <=> ( ? [X4: C] :
            ( member2(C,X4,A4)
            & aa(C,$o,Pa,X4) )
        | ? [X4: C] :
            ( member2(C,X4,B3)
            & aa(C,$o,Pa,X4) ) ) ) ).

% bex_Un
tff(fact_252_ball__Un,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),Pa: fun(C,$o)] :
      ( ! [X4: C] :
          ( member2(C,X4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
         => aa(C,$o,Pa,X4) )
    <=> ( ! [X4: C] :
            ( member2(C,X4,A4)
           => aa(C,$o,Pa,X4) )
        & ! [X4: C] :
            ( member2(C,X4,B3)
           => aa(C,$o,Pa,X4) ) ) ) ).

% ball_Un
tff(fact_253_Un__assoc,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),C4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) ).

% Un_assoc
tff(fact_254_Un__absorb,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),A4) = A4 ).

% Un_absorb
tff(fact_255_Un__commute,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),A4) ).

% Un_commute
tff(fact_256_Un__left__absorb,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) ).

% Un_left_absorb
tff(fact_257_Un__left__commute,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),C4)) ).

% Un_left_commute
tff(fact_258_sup__fun__def,axiom,
    ! [D: $tType,C: $tType] :
      ( semilattice_sup(D)
     => ! [F: fun(C,D),G: fun(C,D),X3: C] : aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),sup_sup(fun(C,D)),F),G),X3) = aa(D,D,aa(D,fun(D,D),sup_sup(D),aa(C,D,F,X3)),aa(C,D,G,X3)) ) ).

% sup_fun_def
tff(fact_259_lt__ex,axiom,
    ! [C: $tType] :
      ( no_bot(C)
     => ! [X: C] :
        ? [Y2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y2),X) ) ).

% lt_ex
tff(fact_260_gt__ex,axiom,
    ! [C: $tType] :
      ( no_top(C)
     => ! [X: C] :
        ? [X_1: C] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),X_1) ) ).

% gt_ex
tff(fact_261_dense,axiom,
    ! [C: $tType] :
      ( dense_order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ? [Z4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Z4)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z4),Y) ) ) ) ).

% dense
tff(fact_262_less__imp__neq,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( X != Y ) ) ) ).

% less_imp_neq
tff(fact_263_order_Oasym,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ).

% order.asym
tff(fact_264_ord__eq__less__trans,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 = B2 )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% ord_eq_less_trans
tff(fact_265_ord__less__eq__trans,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( ( B2 = C3 )
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% ord_less_eq_trans
tff(fact_266_less__induct,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),A3: C] :
          ( ! [X2: C] :
              ( ! [Y4: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y4),X2)
                 => aa(C,$o,Pa,Y4) )
             => aa(C,$o,Pa,X2) )
         => aa(C,$o,Pa,A3) ) ) ).

% less_induct
tff(fact_267_antisym__conv3,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Y: C,X: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
          <=> ( X = Y ) ) ) ) ).

% antisym_conv3
tff(fact_268_linorder__cases,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( ( X != Y )
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ) ).

% linorder_cases
tff(fact_269_dual__order_Oasym,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% dual_order.asym
tff(fact_270_dual__order_Oirrefl,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),A3) ) ).

% dual_order.irrefl
tff(fact_271_exists__least__iff,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o)] :
          ( ? [X_12: C] : aa(C,$o,Pa,X_12)
        <=> ? [N3: C] :
              ( aa(C,$o,Pa,N3)
              & ! [M3: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),M3),N3)
                 => ~ aa(C,$o,Pa,M3) ) ) ) ) ).

% exists_least_iff
tff(fact_272_linorder__less__wlog,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Pa: fun(C,fun(C,$o)),A3: C,B2: C] :
          ( ! [A5: C,B4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A5),B4)
             => aa(C,$o,aa(C,fun(C,$o),Pa,A5),B4) )
         => ( ! [A5: C] : aa(C,$o,aa(C,fun(C,$o),Pa,A5),A5)
           => ( ! [A5: C,B4: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),Pa,B4),A5)
                 => aa(C,$o,aa(C,fun(C,$o),Pa,A5),B4) )
             => aa(C,$o,aa(C,fun(C,$o),Pa,A3),B2) ) ) ) ) ).

% linorder_less_wlog
tff(fact_273_order_Ostrict__trans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% order.strict_trans
tff(fact_274_not__less__iff__gr__or__eq,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
            | ( X = Y ) ) ) ) ).

% not_less_iff_gr_or_eq
tff(fact_275_dual__order_Ostrict__trans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3) ) ) ) ).

% dual_order.strict_trans
tff(fact_276_order_Ostrict__implies__not__eq,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( A3 != B2 ) ) ) ).

% order.strict_implies_not_eq
tff(fact_277_dual__order_Ostrict__implies__not__eq,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( A3 != B2 ) ) ) ).

% dual_order.strict_implies_not_eq
tff(fact_278_linorder__neqE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ( X != Y )
         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ) ).

% linorder_neqE
tff(fact_279_order__less__asym,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% order_less_asym
tff(fact_280_linorder__neq__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ( X != Y )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
            | aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ) ).

% linorder_neq_iff
tff(fact_281_order__less__asym_H,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ).

% order_less_asym'
tff(fact_282_order__less__trans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),Z2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Z2) ) ) ) ).

% order_less_trans
tff(fact_283_ord__eq__less__subst,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ord(D)
        & ord(C) )
     => ! [A3: C,F: fun(D,C),B2: D,C3: D] :
          ( ( A3 = aa(D,C,F,B2) )
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),B2),C3)
           => ( ! [X2: D,Y2: D] :
                  ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),X2),Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(D,C,F,X2)),aa(D,C,F,Y2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(D,C,F,C3)) ) ) ) ) ).

% ord_eq_less_subst
tff(fact_284_ord__less__eq__subst,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ord(D)
        & ord(C) )
     => ! [A3: C,B2: C,F: fun(C,D),C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( ( aa(C,D,F,B2) = C3 )
           => ( ! [X2: C,Y2: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,A3)),C3) ) ) ) ) ).

% ord_less_eq_subst
tff(fact_285_order__less__irrefl,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),X) ) ).

% order_less_irrefl
tff(fact_286_order__less__subst1,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,F: fun(D,C),B2: D,C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(D,C,F,B2))
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),B2),C3)
           => ( ! [X2: D,Y2: D] :
                  ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),X2),Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(D,C,F,X2)),aa(D,C,F,Y2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(D,C,F,C3)) ) ) ) ) ).

% order_less_subst1
tff(fact_287_order__less__subst2,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,B2: C,F: fun(C,D),C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,B2)),C3)
           => ( ! [X2: C,Y2: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,A3)),C3) ) ) ) ) ).

% order_less_subst2
tff(fact_288_order__less__not__sym,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% order_less_not_sym
tff(fact_289_order__less__imp__triv,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C,Pa: $o] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
           => (Pa) ) ) ) ).

% order_less_imp_triv
tff(fact_290_linorder__less__linear,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
          | ( X = Y )
          | aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% linorder_less_linear
tff(fact_291_order__less__imp__not__eq,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( X != Y ) ) ) ).

% order_less_imp_not_eq
tff(fact_292_order__less__imp__not__eq2,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( Y != X ) ) ) ).

% order_less_imp_not_eq2
tff(fact_293_order__less__imp__not__less,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% order_less_imp_not_less
tff(fact_294_syntax__fo__nomatch__def,axiom,
    ! [C: $tType,D: $tType,Pat: C,Obj: D] : syntax7388354845996824322omatch(C,D,Pat,Obj) ).

% syntax_fo_nomatch_def
tff(fact_295_boolean__algebra_Odisj__zero__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),bot_bot(C)) = X ) ).

% boolean_algebra.disj_zero_right
tff(fact_296_boolean__algebra_Odisj__conj__distrib2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [Y: C,Z2: C,X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),X)),aa(C,C,aa(C,fun(C,C),sup_sup(C),Z2),X)) ) ).

% boolean_algebra.disj_conj_distrib2
tff(fact_297_boolean__algebra_Oconj__disj__distrib2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [Y: C,Z2: C,X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),X)),aa(C,C,aa(C,fun(C,C),inf_inf(C),Z2),X)) ) ).

% boolean_algebra.conj_disj_distrib2
tff(fact_298_boolean__algebra_Odisj__conj__distrib,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Z2)) ) ).

% boolean_algebra.disj_conj_distrib
tff(fact_299_boolean__algebra_Oconj__disj__distrib,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Z2)) ) ).

% boolean_algebra.conj_disj_distrib
tff(fact_300_sup__inf__distrib2,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [Y: C,Z2: C,X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),X)),aa(C,C,aa(C,fun(C,C),sup_sup(C),Z2),X)) ) ).

% sup_inf_distrib2
tff(fact_301_sup__inf__distrib1,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Z2)) ) ).

% sup_inf_distrib1
tff(fact_302_inf__sup__distrib2,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [Y: C,Z2: C,X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),X)),aa(C,C,aa(C,fun(C,C),inf_inf(C),Z2),X)) ) ).

% inf_sup_distrib2
tff(fact_303_inf__sup__distrib1,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Z2)) ) ).

% inf_sup_distrib1
tff(fact_304_distrib__imp2,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] :
          ( ! [X2: C,Y2: C,Z4: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X2),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y2),Z4)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X2),Y2)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X2),Z4))
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Z2)) ) ) ) ).

% distrib_imp2
tff(fact_305_distrib__imp1,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] :
          ( ! [X2: C,Y2: C,Z4: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X2),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y2),Z4)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X2),Y2)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X2),Z4))
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Z2)) ) ) ) ).

% distrib_imp1
tff(fact_306_Un__empty__right,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),bot_bot(set(C))) = A4 ).

% Un_empty_right
tff(fact_307_Un__empty__left,axiom,
    ! [C: $tType,B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),bot_bot(set(C))),B3) = B3 ).

% Un_empty_left
tff(fact_308_bot_Onot__eq__extremum,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [A3: C] :
          ( ( A3 != bot_bot(C) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),bot_bot(C)),A3) ) ) ).

% bot.not_eq_extremum
tff(fact_309_bot_Oextremum__strict,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [A3: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),bot_bot(C)) ) ).

% bot.extremum_strict
tff(fact_310_not__psubset__empty,axiom,
    ! [C: $tType,A4: set(C)] : ~ aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),bot_bot(set(C))) ).

% not_psubset_empty
tff(fact_311_inf_Ostrict__coboundedI2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),C3) ) ) ).

% inf.strict_coboundedI2
tff(fact_312_inf_Ostrict__coboundedI1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),C3) ) ) ).

% inf.strict_coboundedI1
tff(fact_313_inf_Ostrict__order__iff,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> ( ( A3 = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) )
            & ( A3 != B2 ) ) ) ) ).

% inf.strict_order_iff
tff(fact_314_inf_Ostrict__boundedE,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),C3))
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% inf.strict_boundedE
tff(fact_315_inf_Oabsorb4,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = B2 ) ) ) ).

% inf.absorb4
tff(fact_316_inf_Oabsorb3,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = A3 ) ) ) ).

% inf.absorb3
tff(fact_317_less__infI2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,X: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),X) ) ) ).

% less_infI2
tff(fact_318_less__infI1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,X: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),X) ) ) ).

% less_infI1
tff(fact_319_FI__p__nomatch,axiom,
    ! [M2: list(product_prod(assn,assn)),Ps: assn,Qs: assn,Q2: assn,P3: assn,Up: assn,Uq: assn,F: assn] :
      ( fi(M2,Ps,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Qs),Q2),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),P3),Up),Uq,F)
     => fi(M2,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Ps),P3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Qs),Q2),Up,Uq,F) ) ).

% FI_p_nomatch
tff(fact_320_lexordp__eq_OCons__eq,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C,Xs: list(C),Ys: list(C)] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
           => ( ord_lexordp_eq(C,Xs,Ys)
             => ord_lexordp_eq(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ) ) ).

% lexordp_eq.Cons_eq
tff(fact_321_lexordp__eq_OCons,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C,Xs: list(C),Ys: list(C)] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ord_lexordp_eq(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ).

% lexordp_eq.Cons
tff(fact_322_assn__aci_I11_J,axiom,
    ! [X: assn,Y: assn,A3: assn,B2: assn] :
      ( syntax7388354845996824322omatch(assn,assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),X),Y),A3)
     => ( aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),B2) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B2),A3) ) ) ).

% assn_aci(11)
tff(fact_323_less__1__mult,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [M2: C,N: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),M2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),N)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),M2),N)) ) ) ) ).

% less_1_mult
tff(fact_324_less__numeral__extra_I4_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),one_one(C)) ) ).

% less_numeral_extra(4)
tff(fact_325_FI__q__nomatch,axiom,
    ! [M2: list(product_prod(assn,assn)),Up: assn,Qs: assn,Q2: assn,Uq: assn,F: assn] :
      ( fi(M2,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sln),Up),Qs,sln,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q2),Uq),F)
     => fi(M2,sln,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Qs),Q2),Up,Uq,F) ) ).

% FI_q_nomatch
tff(fact_326_map__tailrec__def,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),As2: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map_tailrec(D,C),F),As2) = aa(list(C),list(C),rev(C),map_tailrec_rev(D,C,F,As2,nil(C))) ).

% map_tailrec_def
tff(fact_327_merge_Oelims,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(C),Xa: list(C),Y: list(C)] :
          ( ( merge(C,X,Xa) = Y )
         => ( ( ( X = nil(C) )
             => ( Y != Xa ) )
           => ( ! [V2: C,Va2: list(C)] :
                  ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                 => ( ( Xa = nil(C) )
                   => ( Y != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) ) ) )
             => ~ ! [X1: C,L1: list(C)] :
                    ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),L1) )
                   => ! [X23: C,L2: list(C)] :
                        ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),L2) )
                       => ( Y != $ite(
                              aa(C,$o,aa(C,fun(C,$o),ord_less(C),X1),X23),
                              aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),merge(C,L1,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),L2))),
                              $ite(X1 = X23,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),merge(C,L1,L2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),merge(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),L1),L2))) ) ) ) ) ) ) ) ) ).

% merge.elims
tff(fact_328_list__collect__set__map__simps_I4_J,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F: fun(D,set(C)),X: fun(E2,D),La: list(E2),L_a: list(E2)] : list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),aa(list(E2),list(E2),aa(list(E2),fun(list(E2),list(E2)),append(E2),La),L_a))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),La))),list_collect_set(D,C,F,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),X),L_a))) ).

% list_collect_set_map_simps(4)
tff(fact_329_sorted__list__of__set_Osorted__key__list__of__set__eq__Nil__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = nil(C) )
          <=> ( A4 = bot_bot(set(C)) ) ) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_eq_Nil_iff
tff(fact_330_lexordp__induct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C),Pa: fun(list(C),fun(list(C),$o))] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
         => ( ! [Y2: C,Ys2: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,nil(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2))
           => ( ! [X2: C,Xs2: list(C),Y2: C,Ys2: list(C)] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2)
                 => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)) )
             => ( ! [X2: C,Xs2: list(C),Ys2: list(C)] :
                    ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs2),Ys2)
                   => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,Xs2),Ys2)
                     => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2)) ) )
               => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,Xs),Ys) ) ) ) ) ) ).

% lexordp_induct
tff(fact_331_lexordp__cases,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
         => ( ( ( Xs = nil(C) )
             => ! [Y2: C,Ys4: list(C)] : Ys != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys4) )
           => ( ! [X2: C] :
                  ( ? [Xs4: list(C)] : Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs4)
                 => ! [Y2: C] :
                      ( ? [Ys4: list(C)] : Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys4)
                     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2) ) )
             => ~ ! [X2: C,Xs4: list(C)] :
                    ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs4) )
                   => ! [Ys4: list(C)] :
                        ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys4) )
                       => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs4),Ys4) ) ) ) ) ) ) ).

% lexordp_cases
tff(fact_332_lexordp_Osimps,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A1: list(C),A22: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),A1),A22)
        <=> ( ? [Y3: C,Ys3: list(C)] :
                ( ( A1 = nil(C) )
                & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) ) )
            | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
                ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
                & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
                & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y3) )
            | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
                ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
                & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
                & ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y3)
                & ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y3),X4)
                & aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs3),Ys3) ) ) ) ) ).

% lexordp.simps
tff(fact_333_same__append__eq,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs) )
    <=> ( Ys = Zs ) ) ).

% same_append_eq
tff(fact_334_append__same__eq,axiom,
    ! [C: $tType,Ys: list(C),Xs: list(C),Zs: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Zs),Xs) )
    <=> ( Ys = Zs ) ) ).

% append_same_eq
tff(fact_335_append__assoc,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),Zs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs)) ).

% append_assoc
tff(fact_336_append_Oassoc,axiom,
    ! [C: $tType,A3: list(C),B2: list(C),C3: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),A3),B2)),C3) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),A3),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),B2),C3)) ).

% append.assoc
tff(fact_337_rev__is__rev__conv,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),rev(C),Xs) = aa(list(C),list(C),rev(C),Ys) )
    <=> ( Xs = Ys ) ) ).

% rev_is_rev_conv
tff(fact_338_rev__rev__ident,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),rev(C),Xs)) = Xs ).

% rev_rev_ident
tff(fact_339_merge__pure__or,axiom,
    ! [A3: $o,B2: $o] :
      aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),pure_assn((A3))),pure_assn((B2))) = pure_assn(( (A3)
        | (B2) )) ).

% merge_pure_or
tff(fact_340_append__is__Nil__conv,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = nil(C) )
    <=> ( ( Xs = nil(C) )
        & ( Ys = nil(C) ) ) ) ).

% append_is_Nil_conv
tff(fact_341_Nil__is__append__conv,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) )
    <=> ( ( Xs = nil(C) )
        & ( Ys = nil(C) ) ) ) ).

% Nil_is_append_conv
tff(fact_342_self__append__conv2,axiom,
    ! [C: $tType,Y: list(C),Xs: list(C)] :
      ( ( Y = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Y) )
    <=> ( Xs = nil(C) ) ) ).

% self_append_conv2
tff(fact_343_append__self__conv2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = Ys )
    <=> ( Xs = nil(C) ) ) ).

% append_self_conv2
tff(fact_344_self__append__conv,axiom,
    ! [C: $tType,Y: list(C),Ys: list(C)] :
      ( ( Y = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Y),Ys) )
    <=> ( Ys = nil(C) ) ) ).

% self_append_conv
tff(fact_345_append__self__conv,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = Xs )
    <=> ( Ys = nil(C) ) ) ).

% append_self_conv
tff(fact_346_append__Nil2,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),nil(C)) = Xs ).

% append_Nil2
tff(fact_347_append_Oright__neutral,axiom,
    ! [C: $tType,A3: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),A3),nil(C)) = A3 ).

% append.right_neutral
tff(fact_348_empty__append__eq__id,axiom,
    ! [C: $tType,X3: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),nil(C)),X3) = X3 ).

% empty_append_eq_id
tff(fact_349_map__append,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),Ys: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ys)) ).

% map_append
tff(fact_350_rev__is__Nil__conv,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),list(C),rev(C),Xs) = nil(C) )
    <=> ( Xs = nil(C) ) ) ).

% rev_is_Nil_conv
tff(fact_351_Nil__is__rev__conv,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),rev(C),Xs) )
    <=> ( Xs = nil(C) ) ) ).

% Nil_is_rev_conv
tff(fact_352_rev__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),Ys)),aa(list(C),list(C),rev(C),Xs)) ).

% rev_append
tff(fact_353_lexordp__simps_I1_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),nil(C)),Ys)
        <=> ( Ys != nil(C) ) ) ) ).

% lexordp_simps(1)
tff(fact_354_lexordp__simps_I2_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Xs: list(C)] : ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),nil(C)) ) ).

% lexordp_simps(2)
tff(fact_355_append1__eq__conv,axiom,
    ! [C: $tType,Xs: list(C),X: C,Ys: list(C),Y: C] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C))) )
    <=> ( ( Xs = Ys )
        & ( X = Y ) ) ) ).

% append1_eq_conv
tff(fact_356_list__e__eq__lel_I2_J,axiom,
    ! [C: $tType,L12: list(C),E3: C,L22: list(C),E4: C] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E3),L22)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),nil(C)) )
    <=> ( ( L12 = nil(C) )
        & ( E3 = E4 )
        & ( L22 = nil(C) ) ) ) ).

% list_e_eq_lel(2)
tff(fact_357_list__e__eq__lel_I1_J,axiom,
    ! [C: $tType,E4: C,L12: list(C),E3: C,L22: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),nil(C)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E3),L22)) )
    <=> ( ( L12 = nil(C) )
        & ( E3 = E4 )
        & ( L22 = nil(C) ) ) ) ).

% list_e_eq_lel(1)
tff(fact_358_list__se__match_I4_J,axiom,
    ! [C: $tType,L22: list(C),A3: C,L12: list(C)] :
      ( ( L22 != nil(C) )
     => ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),L22) )
      <=> ( ( L12 = nil(C) )
          & ( L22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) ) ) ) ) ).

% list_se_match(4)
tff(fact_359_list__se__match_I3_J,axiom,
    ! [C: $tType,L12: list(C),A3: C,L22: list(C)] :
      ( ( L12 != nil(C) )
     => ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),L22) )
      <=> ( ( L12 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) )
          & ( L22 = nil(C) ) ) ) ) ).

% list_se_match(3)
tff(fact_360_list__se__match_I2_J,axiom,
    ! [C: $tType,L22: list(C),L12: list(C),A3: C] :
      ( ( L22 != nil(C) )
     => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),L22) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) )
      <=> ( ( L12 = nil(C) )
          & ( L22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) ) ) ) ) ).

% list_se_match(2)
tff(fact_361_list__se__match_I1_J,axiom,
    ! [C: $tType,L12: list(C),L22: list(C),A3: C] :
      ( ( L12 != nil(C) )
     => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),L22) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) )
      <=> ( ( L12 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C)) )
          & ( L22 = nil(C) ) ) ) ) ).

% list_se_match(1)
tff(fact_362_list__ee__eq__leel_I2_J,axiom,
    ! [C: $tType,L12: list(C),E1: C,E22: C,L22: list(C),E12: C,E23: C] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E22),L22))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E23),nil(C))) )
    <=> ( ( L12 = nil(C) )
        & ( E12 = E1 )
        & ( E23 = E22 )
        & ( L22 = nil(C) ) ) ) ).

% list_ee_eq_leel(2)
tff(fact_363_list__ee__eq__leel_I1_J,axiom,
    ! [C: $tType,E12: C,E23: C,L12: list(C),E1: C,E22: C,L22: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E23),nil(C))) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E22),L22))) )
    <=> ( ( L12 = nil(C) )
        & ( E12 = E1 )
        & ( E23 = E22 )
        & ( L22 = nil(C) ) ) ) ).

% list_ee_eq_leel(1)
tff(fact_364_rev__singleton__conv,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( ( aa(list(C),list(C),rev(C),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) )
    <=> ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ) ) ).

% rev_singleton_conv
tff(fact_365_singleton__rev__conv,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) = aa(list(C),list(C),rev(C),Xs) )
    <=> ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) = Xs ) ) ).

% singleton_rev_conv
tff(fact_366_lexordp__simps_I3_J,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Xs: list(C),Y: C,Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
            | ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
              & aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys) ) ) ) ) ).

% lexordp_simps(3)
tff(fact_367_sorted__list__of__set_Ofold__insort__key_Oinfinite,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( ~ aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = nil(C) ) ) ) ).

% sorted_list_of_set.fold_insort_key.infinite
tff(fact_368_list__collect__set__simps_I4_J,axiom,
    ! [C: $tType,D: $tType,F: fun(D,set(C)),La: list(D),L_a: list(D)] : list_collect_set(D,C,F,aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),La),L_a)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),list_collect_set(D,C,F,La)),list_collect_set(D,C,F,L_a)) ).

% list_collect_set_simps(4)
tff(fact_369_bind__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,X: D,Xs: list(D),F: fun(D,list(C))] : bind(D,C,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs),F) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(D,list(C),F,X)),bind(D,C,Xs,F)) ).

% bind_simps(2)
tff(fact_370_revg__fun,axiom,
    ! [C: $tType,A3: list(C),B2: list(C)] : revg(C,A3,B2) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),A3)),B2) ).

% revg_fun
tff(fact_371_rev__eq__Cons__iff,axiom,
    ! [C: $tType,Xs: list(C),Y: C,Ys: list(C)] :
      ( ( aa(list(C),list(C),rev(C),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys) )
    <=> ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),Ys)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C))) ) ) ).

% rev_eq_Cons_iff
tff(fact_372_psubsetD,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C3: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
     => ( member2(C,C3,A4)
       => member2(C,C3,B3) ) ) ).

% psubsetD
tff(fact_373_psubset__trans,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),B3),C4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),C4) ) ) ).

% psubset_trans
tff(fact_374_append__eq__append__conv2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C),Ts: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Zs),Ts) )
    <=> ? [Us: list(C)] :
          ( ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Zs),Us) )
            & ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),Ys) = Ts ) )
          | ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us) = Zs )
            & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),Ts) ) ) ) ) ).

% append_eq_append_conv2
tff(fact_375_append__eq__appendI,axiom,
    ! [C: $tType,Xs: list(C),Xs1: list(C),Zs: list(C),Ys: list(C),Us2: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Xs1) = Zs )
     => ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs1),Us2) )
       => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Zs),Us2) ) ) ) ).

% append_eq_appendI
tff(fact_376_rev__swap,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),rev(C),Xs) = Ys )
    <=> ( Xs = aa(list(C),list(C),rev(C),Ys) ) ) ).

% rev_swap
tff(fact_377_lexordp__irreflexive_H,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Xs: list(C)] : ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Xs) ) ).

% lexordp_irreflexive'
tff(fact_378_lexordp__append__leftI,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Us2: list(C),Vs: list(C),Xs: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Us2),Vs)
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Vs)) ) ) ).

% lexordp_append_leftI
tff(fact_379_lexordp__linear,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
          | ( Xs = Ys )
          | aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Ys),Xs) ) ) ).

% lexordp_linear
tff(fact_380_lexordp__trans,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C),Zs: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
         => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Ys),Zs)
           => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Zs) ) ) ) ).

% lexordp_trans
tff(fact_381_lexordp__antisym,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
         => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Ys),Xs) ) ) ).

% lexordp_antisym
tff(fact_382_lexordp__append__leftD,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Xs: list(C),Us2: list(C),Vs: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Vs))
         => ( ! [A5: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A5),A5)
           => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Us2),Vs) ) ) ) ).

% lexordp_append_leftD
tff(fact_383_lexordp__append__rightI,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Ys: list(C),Xs: list(C)] :
          ( ( Ys != nil(C) )
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) ) ) ).

% lexordp_append_rightI
tff(fact_384_rev_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% rev.simps(2)
tff(fact_385_lexordp__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
        <=> ( ? [X4: C,Vs2: list(C)] : Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Vs2))
            | ? [Us: list(C),A6: C,B5: C,Vs2: list(C),Ws: list(C)] :
                ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A6),B5)
                & ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A6),Vs2)) )
                & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B5),Ws)) ) ) ) ) ) ).

% lexordp_iff
tff(fact_386_lexordp__append__left__rightI,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C,Us2: list(C),Xs: list(C),Ys: list(C)] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))) ) ) ).

% lexordp_append_left_rightI
tff(fact_387_rev_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),list(C),rev(C),nil(C)) = nil(C) ).

% rev.simps(1)
tff(fact_388_rev__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),rev(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),rev(D),Xs)) ).

% rev_map
tff(fact_389_append__Cons,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) ).

% append_Cons
tff(fact_390_Cons__eq__appendI,axiom,
    ! [C: $tType,X: C,Xs1: list(C),Ys: list(C),Xs: list(C),Zs: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs1) = Ys )
     => ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs1),Zs) )
       => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) ) ) ) ).

% Cons_eq_appendI
tff(fact_391_list__match__lel__lel,axiom,
    ! [C: $tType,C1: list(C),Qs: C,C22: list(C),C12: list(C),Qs2: C,C23: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),C1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Qs),C22)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),C12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Qs2),C23)) )
     => ( ! [C21: list(C)] :
            ( ( C1 = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),C12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Qs2),C21)) )
           => ( C23 != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),C21),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Qs),C22)) ) )
       => ( ( ( C12 = C1 )
           => ( ( Qs2 = Qs )
             => ( C23 != C22 ) ) )
         => ~ ! [C212: list(C)] :
                ( ( C12 = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),C1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Qs),C212)) )
               => ( C22 != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),C212),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Qs2),C23)) ) ) ) ) ) ).

% list_match_lel_lel
tff(fact_392_eq__Nil__appendI,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs = Ys )
     => ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),nil(C)),Ys) ) ) ).

% eq_Nil_appendI
tff(fact_393_append_Oleft__neutral,axiom,
    ! [C: $tType,A3: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),nil(C)),A3) = A3 ).

% append.left_neutral
tff(fact_394_append__Nil,axiom,
    ! [C: $tType,Ys: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),nil(C)),Ys) = Ys ).

% append_Nil
tff(fact_395_map__tailrec__rev,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),As2: list(D),Bs: list(C)] : map_tailrec_rev(D,C,F,As2,Bs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),As2))),Bs) ).

% map_tailrec_rev
tff(fact_396_Misc_Omap__eq__append__conv,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Ls: list(D),Fl: list(C),Fl2: list(C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ls) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Fl),Fl2) )
    <=> ? [L3: list(D),L4: list(D)] :
          ( ( Ls = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L3),L4) )
          & ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L3) = Fl )
          & ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L4) = Fl2 ) ) ) ).

% Misc.map_eq_append_conv
tff(fact_397_Misc_Oappend__eq__map__conv,axiom,
    ! [D: $tType,C: $tType,Fl: list(C),Fl2: list(C),F: fun(D,C),Ls: list(D)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Fl),Fl2) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ls) )
    <=> ? [L3: list(D),L4: list(D)] :
          ( ( Ls = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L3),L4) )
          & ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L3) = Fl )
          & ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L4) = Fl2 ) ) ) ).

% Misc.append_eq_map_conv
tff(fact_398_map__eq__appendE,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Ls: list(D),Fl: list(C),Fl2: list(C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ls) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Fl),Fl2) )
     => ~ ! [L: list(D),L5: list(D)] :
            ( ( Ls = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L),L5) )
           => ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L) = Fl )
             => ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L5) != Fl2 ) ) ) ) ).

% map_eq_appendE
tff(fact_399_append__eq__mapE,axiom,
    ! [D: $tType,C: $tType,Fl: list(C),Fl2: list(C),F: fun(D,C),Ls: list(D)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Fl),Fl2) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ls) )
     => ~ ! [L: list(D),L5: list(D)] :
            ( ( Ls = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L),L5) )
           => ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L) = Fl )
             => ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L5) != Fl2 ) ) ) ) ).

% append_eq_mapE
tff(fact_400_List_Omap__eq__append__conv,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) )
    <=> ? [Us: list(D),Vs2: list(D)] :
          ( ( Xs = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Us),Vs2) )
          & ( Ys = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Us) )
          & ( Zs = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Vs2) ) ) ) ).

% List.map_eq_append_conv
tff(fact_401_List_Oappend__eq__map__conv,axiom,
    ! [C: $tType,D: $tType,Ys: list(C),Zs: list(C),F: fun(D,C),Xs: list(D)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) )
    <=> ? [Us: list(D),Vs2: list(D)] :
          ( ( Xs = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Us),Vs2) )
          & ( Ys = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Us) )
          & ( Zs = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Vs2) ) ) ) ).

% List.append_eq_map_conv
tff(fact_402_star__or__dist2,axiom,
    ! [C4: assn,A4: assn,B3: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),C4),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),C4),A4)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),C4),B3)) ).

% star_or_dist2
tff(fact_403_star__or__dist1,axiom,
    ! [A4: assn,B3: assn,C4: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)),C4) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),C4)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),C4)) ).

% star_or_dist1
tff(fact_404_ord_Olexordp__eq__pref,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),U: list(C),V: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),U),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U),V)) ).

% ord.lexordp_eq_pref
tff(fact_405_lexordp__irreflexive,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Xs: list(C)] :
          ( ! [X2: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),X2)
         => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Xs) ) ) ).

% lexordp_irreflexive
tff(fact_406_norm__assertion__simps_I6_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),bot_bot(assn)) = X ).

% norm_assertion_simps(6)
tff(fact_407_norm__assertion__simps_I5_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),bot_bot(assn)),X) = X ).

% norm_assertion_simps(5)
tff(fact_408_lexordp__eq__pref,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [U: list(C),V: list(C)] : ord_lexordp_eq(C,U,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U),V)) ) ).

% lexordp_eq_pref
tff(fact_409_sorted__list__of__set_Osorted__key__list__of__set__inject,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( ( aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = aa(set(C),list(C),linord4507533701916653071of_set(C),B3) )
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( A4 = B3 ) ) ) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_inject
tff(fact_410_merge_Osimps_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [L22: list(C)] : merge(C,nil(C),L22) = L22 ) ).

% merge.simps(1)
tff(fact_411_lexordp__conv__lexordp__eq,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
        <=> ( ord_lexordp_eq(C,Xs,Ys)
            & ~ ord_lexordp_eq(C,Ys,Xs) ) ) ) ).

% lexordp_conv_lexordp_eq
tff(fact_412_lexordp__eq__conv__lexord,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( ord_lexordp_eq(C,Xs,Ys)
        <=> ( ( Xs = Ys )
            | aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys) ) ) ) ).

% lexordp_eq_conv_lexord
tff(fact_413_lexordp__into__lexordp__eq,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
         => ord_lexordp_eq(C,Xs,Ys) ) ) ).

% lexordp_into_lexordp_eq
tff(fact_414_rev__induct,axiom,
    ! [C: $tType,Pa: fun(list(C),$o),Xs: list(C)] :
      ( aa(list(C),$o,Pa,nil(C))
     => ( ! [X2: C,Xs2: list(C)] :
            ( aa(list(C),$o,Pa,Xs2)
           => aa(list(C),$o,Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))) )
       => aa(list(C),$o,Pa,Xs) ) ) ).

% rev_induct
tff(fact_415_rev__exhaust,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ~ ! [Ys2: list(C),Y2: C] : Xs != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),nil(C))) ) ).

% rev_exhaust
tff(fact_416_Cons__eq__append__conv,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) )
    <=> ( ( ( Ys = nil(C) )
          & ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = Zs ) )
        | ? [Ys5: list(C)] :
            ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys5) = Ys )
            & ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys5),Zs) ) ) ) ) ).

% Cons_eq_append_conv
tff(fact_417_append__eq__Cons__conv,axiom,
    ! [C: $tType,Ys: list(C),Zs: list(C),X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) )
    <=> ( ( ( Ys = nil(C) )
          & ( Zs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) ) )
        | ? [Ys5: list(C)] :
            ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys5) )
            & ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys5),Zs) = Xs ) ) ) ) ).

% append_eq_Cons_conv
tff(fact_418_rev__nonempty__induct,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(list(C),$o)] :
      ( ( Xs != nil(C) )
     => ( ! [X2: C] : aa(list(C),$o,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))
       => ( ! [X2: C,Xs2: list(C)] :
              ( ( Xs2 != nil(C) )
             => ( aa(list(C),$o,Pa,Xs2)
               => aa(list(C),$o,Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))) ) )
         => aa(list(C),$o,Pa,Xs) ) ) ) ).

% rev_nonempty_induct
tff(fact_419_neq__Nil__revE,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( La != nil(C) )
     => ~ ! [Ll: list(C),E: C] : La != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ll),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E),nil(C))) ) ).

% neq_Nil_revE
tff(fact_420_rev__induct2_H,axiom,
    ! [C: $tType,D: $tType,Pa: fun(list(C),fun(list(D),$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),nil(D))
     => ( ! [X2: C,Xs2: list(C)] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))),nil(D))
       => ( ! [Y2: D,Ys2: list(D)] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),nil(D))))
         => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
                ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs2),Ys2)
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),nil(D)))) )
           => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs),Ys) ) ) ) ) ).

% rev_induct2'
tff(fact_421_neq__Nil__rev__conv,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( La != nil(C) )
    <=> ? [Xs3: list(C),X4: C] : La = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),nil(C))) ) ).

% neq_Nil_rev_conv
tff(fact_422_rev__nonempty__induct2_H,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Pa: fun(list(C),fun(list(D),$o))] :
      ( ( Xs != nil(C) )
     => ( ( Ys != nil(D) )
       => ( ! [X2: C,Y2: D] : aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),nil(D)))
         => ( ! [X2: C,Xs2: list(C),Y2: D] :
                ( ( Xs2 != nil(C) )
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),nil(D))) )
           => ( ! [X2: C,Y2: D,Ys2: list(D)] :
                  ( ( Ys2 != nil(D) )
                 => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),nil(D)))) )
             => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
                    ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs2),Ys2)
                   => ( ( Xs2 != nil(C) )
                     => ( ( Ys2 != nil(D) )
                       => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),nil(D)))) ) ) )
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs),Ys) ) ) ) ) ) ) ).

% rev_nonempty_induct2'
tff(fact_423_list__Cons__eq__append__cases,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) )
     => ( ( ( Ys = nil(C) )
         => ( Zs != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) ) )
       => ~ ! [Ys4: list(C)] :
              ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys4) )
             => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys4),Zs) != Xs ) ) ) ) ).

% list_Cons_eq_append_cases
tff(fact_424_list__append__eq__Cons__cases,axiom,
    ! [C: $tType,Ys: list(C),Zs: list(C),X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) )
     => ( ( ( Ys = nil(C) )
         => ( Zs != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) ) )
       => ~ ! [Ys4: list(C)] :
              ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys4) )
             => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys4),Zs) != Xs ) ) ) ) ).

% list_append_eq_Cons_cases
tff(fact_425_map__consI_I2_J,axiom,
    ! [D: $tType,C: $tType,W: list(C),La: list(C),F: fun(D,C),Ww: list(D),A3: D] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),W),La) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ww)),La) )
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,F,A3)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),W),La)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),Ww))),La) ) ) ).

% map_consI(2)
tff(fact_426_SLN__left,axiom,
    ! [Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sln),Pa) = Pa ).

% SLN_left
tff(fact_427_SLN__right,axiom,
    ! [Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),sln) = Pa ).

% SLN_right
tff(fact_428_lexordp_OCons,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C,Xs: list(C),Ys: list(C)] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ).

% lexordp.Cons
tff(fact_429_lexordp_OCons__eq,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C,Xs: list(C),Ys: list(C)] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X)
           => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
             => aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ) ) ).

% lexordp.Cons_eq
tff(fact_430_lexordp_ONil,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Y: C,Ys: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),nil(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ).

% lexordp.Nil
tff(fact_431_SLN__def,axiom,
    sln = one_one(assn) ).

% SLN_def
tff(fact_432_merge_Osimps_I3_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X12: C,L12: list(C),X24: C,L22: list(C)] :
          merge(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),L22)) = $ite(
            aa(C,$o,aa(C,fun(C,$o),ord_less(C),X12),X24),
            aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),merge(C,L12,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),L22))),
            $ite(X12 = X24,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),merge(C,L12,L22)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),merge(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),L12),L22))) ) ) ).

% merge.simps(3)
tff(fact_433_merge_Osimps_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [V: C,Va: list(C)] : merge(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va),nil(C)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va) ) ).

% merge.simps(2)
tff(fact_434_lexordp_Ocases,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A1: list(C),A22: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),A1),A22)
         => ( ( ( A1 = nil(C) )
             => ! [Y2: C,Ys2: list(C)] : A22 != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
           => ( ! [X2: C] :
                  ( ? [Xs2: list(C)] : A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)
                 => ! [Y2: C] :
                      ( ? [Ys2: list(C)] : A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)
                     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2) ) )
             => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                    ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                   => ! [Ys2: list(C)] :
                        ( ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                       => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2)
                         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y2),X2)
                           => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs2),Ys2) ) ) ) ) ) ) ) ) ).

% lexordp.cases
tff(fact_435_finite__Int,axiom,
    ! [C: $tType,F2: set(C),G2: set(C)] :
      ( ( aa(set(C),$o,finite_finite2(C),F2)
        | aa(set(C),$o,finite_finite2(C),G2) )
     => aa(set(C),$o,finite_finite2(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),F2),G2)) ) ).

% finite_Int
tff(fact_436_ex__min__if__finite,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [S: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ? [X2: C] :
                ( member2(C,X2,S)
                & ~ ? [Xa3: C] :
                      ( member2(C,Xa3,S)
                      & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Xa3),X2) ) ) ) ) ) ).

% ex_min_if_finite
tff(fact_437_infinite__growing,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X5: set(C)] :
          ( ( X5 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,X5)
               => ? [Xa3: C] :
                    ( member2(C,Xa3,X5)
                    & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Xa3) ) )
           => ~ aa(set(C),$o,finite_finite2(C),X5) ) ) ) ).

% infinite_growing
tff(fact_438_FI__init,axiom,
    ! [Pa: assn,Q: assn,F2: assn] :
      ( fi(nil(product_prod(assn,assn)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sln),Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sln),Q),sln,sln,F2)
     => fI_QUERY(Pa,Q,F2) ) ).

% FI_init
tff(fact_439_finite_OemptyI,axiom,
    ! [C: $tType] : aa(set(C),$o,finite_finite2(C),bot_bot(set(C))) ).

% finite.emptyI
tff(fact_440_infinite__imp__nonempty,axiom,
    ! [C: $tType,S: set(C)] :
      ( ~ aa(set(C),$o,finite_finite2(C),S)
     => ( S != bot_bot(set(C)) ) ) ).

% infinite_imp_nonempty
tff(fact_441_finite__transitivity__chain,axiom,
    ! [C: $tType,A4: set(C),R: fun(C,fun(C,$o))] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( ! [X2: C] : ~ aa(C,$o,aa(C,fun(C,$o),R,X2),X2)
       => ( ! [X2: C,Y2: C,Z4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
             => ( aa(C,$o,aa(C,fun(C,$o),R,Y2),Z4)
               => aa(C,$o,aa(C,fun(C,$o),R,X2),Z4) ) )
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => ? [Y4: C] :
                    ( member2(C,Y4,A4)
                    & aa(C,$o,aa(C,fun(C,$o),R,X2),Y4) ) )
           => ( A4 = bot_bot(set(C)) ) ) ) ) ) ).

% finite_transitivity_chain
tff(fact_442_merge__list_Oelims,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(list(C)),Xa: list(list(C)),Y: list(C)] :
          ( ( merge_list(C,X,Xa) = Y )
         => ( ( ( X = nil(list(C)) )
             => ( ( Xa = nil(list(C)) )
               => ( Y != nil(C) ) ) )
           => ( ( ( X = nil(list(C)) )
               => ! [L: list(C)] :
                    ( ( Xa = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))) )
                   => ( Y != L ) ) )
             => ( ! [La2: list(C),Acc2: list(list(C))] :
                    ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2) )
                   => ( ( Xa = nil(list(C)) )
                     => ( Y != merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)) ) ) )
               => ( ! [La2: list(C),Acc2: list(list(C))] :
                      ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2) )
                     => ! [L: list(C)] :
                          ( ( Xa = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))) )
                         => ( Y != merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2))) ) ) )
                 => ~ ! [L1: list(C),L2: list(C),Ls2: list(list(C))] :
                        ( ( Xa = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L2),Ls2)) )
                       => ( Y != merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),merge(C,L1,L2)),X),Ls2) ) ) ) ) ) ) ) ) ).

% merge_list.elims
tff(fact_443_maps__simps_I1_J,axiom,
    ! [C: $tType,D: $tType,F: fun(D,list(C)),X: D,Xs: list(D)] : maps(D,C,F,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(D,list(C),F,X)),maps(D,C,F,Xs)) ).

% maps_simps(1)
tff(fact_444_rotate1_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),rotate1(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% rotate1.simps(2)
tff(fact_445_concat__eq__append__conv,axiom,
    ! [C: $tType,Xss2: list(list(C)),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(list(C)),list(C),concat(C),Xss2) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) )
    <=> $ite(
          Xss2 = nil(list(C)),
          ( ( Ys = nil(C) )
          & ( Zs = nil(C) ) ),
          ? [Xss1: list(list(C)),Xs3: list(C),Xs5: list(C),Xss22: list(list(C))] :
            ( ( Xss2 = aa(list(list(C)),list(list(C)),aa(list(list(C)),fun(list(list(C)),list(list(C))),append(list(C)),Xss1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs3),Xs5)),Xss22)) )
            & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(list(C)),list(C),concat(C),Xss1)),Xs3) )
            & ( Zs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs5),aa(list(list(C)),list(C),concat(C),Xss22)) ) ) ) ) ).

% concat_eq_append_conv
tff(fact_446_rotate1__is__Nil__conv,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),list(C),rotate1(C),Xs) = nil(C) )
    <=> ( Xs = nil(C) ) ) ).

% rotate1_is_Nil_conv
tff(fact_447_concat__append,axiom,
    ! [C: $tType,Xs: list(list(C)),Ys: list(list(C))] : aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(list(list(C)),fun(list(list(C)),list(list(C))),append(list(C)),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(list(C)),list(C),concat(C),Xs)),aa(list(list(C)),list(C),concat(C),Ys)) ).

% concat_append
tff(fact_448_assn__aci_I8_J,axiom,
    ! [X: assn,Y: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),Y)) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),Y) ).

% assn_aci(8)
tff(fact_449_assn__aci_I7_J,axiom,
    ! [X: assn,Y: assn,Z2: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Y),Z2)) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Y),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),Z2)) ).

% assn_aci(7)
tff(fact_450_assn__aci_I5_J,axiom,
    ! [X: assn,Y: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),Y) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Y),X) ).

% assn_aci(5)
tff(fact_451_norm__assertion__simps_I32_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),X) = X ).

% norm_assertion_simps(32)
tff(fact_452_norm__assertion__simps_I15_J,axiom,
    ! [X: assn,Y: assn,Z2: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),Y)),Z2) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Y),Z2)) ).

% norm_assertion_simps(15)
tff(fact_453_concat__map__maps,axiom,
    ! [C: $tType,D: $tType,F: fun(D,list(C)),Xs: list(D)] : aa(list(list(C)),list(C),concat(C),aa(list(D),list(list(C)),aa(fun(D,list(C)),fun(list(D),list(list(C))),map(D,list(C)),F),Xs)) = maps(D,C,F,Xs) ).

% concat_map_maps
tff(fact_454_maps__def,axiom,
    ! [C: $tType,D: $tType,F: fun(D,list(C)),Xs: list(D)] : maps(D,C,F,Xs) = aa(list(list(C)),list(C),concat(C),aa(list(D),list(list(C)),aa(fun(D,list(C)),fun(list(D),list(list(C))),map(D,list(C)),F),Xs)) ).

% maps_def
tff(fact_455_map__concat,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(list(D))] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(list(D)),list(D),concat(D),Xs)) = aa(list(list(C)),list(C),concat(C),aa(list(list(D)),list(list(C)),aa(fun(list(D),list(C)),fun(list(list(D)),list(list(C))),map(list(D),list(C)),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F)),Xs)) ).

% map_concat
tff(fact_456_rev__concat,axiom,
    ! [C: $tType,Xs: list(list(C))] : aa(list(C),list(C),rev(C),aa(list(list(C)),list(C),concat(C),Xs)) = aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),rev(C)),aa(list(list(C)),list(list(C)),rev(list(C)),Xs))) ).

% rev_concat
tff(fact_457_List_Obind__def,axiom,
    ! [C: $tType,D: $tType,Xs: list(D),F: fun(D,list(C))] : bind(D,C,Xs,F) = aa(list(list(C)),list(C),concat(C),aa(list(D),list(list(C)),aa(fun(D,list(C)),fun(list(D),list(list(C))),map(D,list(C)),F),Xs)) ).

% List.bind_def
tff(fact_458_rotate1_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),list(C),rotate1(C),nil(C)) = nil(C) ).

% rotate1.simps(1)
tff(fact_459_rotate1__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),rotate1(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),rotate1(D),Xs)) ).

% rotate1_map
tff(fact_460_concat_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(list(C)),list(C),concat(C),nil(list(C))) = nil(C) ).

% concat.simps(1)
tff(fact_461_concat_Osimps_I2_J,axiom,
    ! [C: $tType,X: list(C),Xs: list(list(C))] : aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),X),Xs)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),X),aa(list(list(C)),list(C),concat(C),Xs)) ).

% concat.simps(2)
tff(fact_462_maps__simps_I2_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,list(C))] : maps(D,C,F,nil(D)) = nil(C) ).

% maps_simps(2)
tff(fact_463_merge__list_Osimps_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( merge_list(C,nil(list(C)),nil(list(C))) = nil(C) ) ) ).

% merge_list.simps(1)
tff(fact_464_merge__list_Osimps_I4_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),Acc22: list(list(C)),Lb: list(C)] : merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Lb),nil(list(C)))) = merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Lb),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22))) ) ).

% merge_list.simps(4)
tff(fact_465_merge__list_Osimps_I3_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),Acc22: list(list(C))] : merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22),nil(list(C))) = merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22)) ) ).

% merge_list.simps(3)
tff(fact_466_merge__list_Osimps_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C)] : merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),nil(list(C)))) = La ) ).

% merge_list.simps(2)
tff(fact_467_merge__list_Osimps_I5_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Acc22: list(list(C)),L12: list(C),L22: list(C),Ls: list(list(C))] : merge_list(C,Acc22,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L12),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L22),Ls))) = merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),merge(C,L12,L22)),Acc22),Ls) ) ).

% merge_list.simps(5)
tff(fact_468_concat__eq__appendD,axiom,
    ! [C: $tType,Xss2: list(list(C)),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(list(C)),list(C),concat(C),Xss2) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Zs) )
     => ( ( Xss2 != nil(list(C)) )
       => ? [Xss12: list(list(C)),Xs2: list(C),Xs4: list(C),Xss23: list(list(C))] :
            ( ( Xss2 = aa(list(list(C)),list(list(C)),aa(list(list(C)),fun(list(list(C)),list(list(C))),append(list(C)),Xss12),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),Xs4)),Xss23)) )
            & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(list(C)),list(C),concat(C),Xss12)),Xs2) )
            & ( Zs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs4),aa(list(list(C)),list(C),concat(C),Xss23)) ) ) ) ) ).

% concat_eq_appendD
tff(fact_469_arg__min__if__finite_I2_J,axiom,
    ! [D: $tType,C: $tType] :
      ( order(D)
     => ! [S: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ~ ? [X3: C] :
                  ( member2(C,X3,S)
                  & aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X3)),aa(C,D,F,lattic7623131987881927897min_on(C,D,F,S))) ) ) ) ) ).

% arg_min_if_finite(2)
tff(fact_470_arg__min__if__finite_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( order(D)
     => ! [S: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => member2(C,lattic7623131987881927897min_on(C,D,F,S),S) ) ) ) ).

% arg_min_if_finite(1)
tff(fact_471_Sup__fin_Ounion,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( B3 != bot_bot(set(C)) )
               => ( lattic5882676163264333800up_fin(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),lattic5882676163264333800up_fin(C,A4)),lattic5882676163264333800up_fin(C,B3)) ) ) ) ) ) ) ).

% Sup_fin.union
tff(fact_472_Inf__fin_Ounion,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( B3 != bot_bot(set(C)) )
               => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)),aa(set(C),C,lattic7752659483105999362nf_fin(C),B3)) ) ) ) ) ) ) ).

% Inf_fin.union
tff(fact_473_product_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType,Uu: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),nil(C)),Uu) = nil(product_prod(C,D)) ).

% product.simps(1)
tff(fact_474_butlast__snoc,axiom,
    ! [C: $tType,Xs: list(C),X: C] : aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)))) = Xs ).

% butlast_snoc
tff(fact_475_last__snoc,axiom,
    ! [C: $tType,Xs: list(C),X: C] : last(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)))) = X ).

% last_snoc
tff(fact_476_Max__less__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),lattic643756798349783984er_Max(C,A4)),X)
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),X) ) ) ) ) ) ).

% Max_less_iff
tff(fact_477_concat__conv__foldr,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(list(C)),list(C),concat(C),Xss2) = aa(list(C),list(C),aa(list(list(C)),fun(list(C),list(C)),aa(fun(list(C),fun(list(C),list(C))),fun(list(list(C)),fun(list(C),list(C))),foldr(list(C),list(C)),append(C)),Xss2),nil(C)) ).

% concat_conv_foldr
tff(fact_478_Min__gr__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),lattic643756798350308766er_Min(C,A4))
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),X4) ) ) ) ) ) ).

% Min_gr_iff
tff(fact_479_SuccI,axiom,
    ! [C: $tType,Kl: list(C),K: C,Kl2: set(list(C))] :
      ( member2(list(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Kl),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),K),nil(C))),Kl2)
     => member2(C,K,bNF_Greatest_Succ(C,Kl2,Kl)) ) ).

% SuccI
tff(fact_480_foldr__append,axiom,
    ! [D: $tType,C: $tType,F: fun(D,fun(C,C)),Xs: list(D),Ys: list(D),A3: C] : aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Xs),Ys)),A3) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),Xs),aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),Ys),A3)) ).

% foldr_append
tff(fact_481_last__appendL,axiom,
    ! [C: $tType,Ys: list(C),Xs: list(C)] :
      ( ( Ys = nil(C) )
     => ( last(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = last(C,Xs) ) ) ).

% last_appendL
tff(fact_482_last__appendR,axiom,
    ! [C: $tType,Ys: list(C),Xs: list(C)] :
      ( ( Ys != nil(C) )
     => ( last(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = last(C,Ys) ) ) ).

% last_appendR
tff(fact_483_inf__Sup__absorb,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [A4: set(C),A3: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,A3,A4)
           => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),lattic5882676163264333800up_fin(C,A4)) = A3 ) ) ) ) ).

% inf_Sup_absorb
tff(fact_484_append__butlast__last__id,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),butlast(C),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),last(C,Xs)),nil(C))) = Xs ) ) ).

% append_butlast_last_id
tff(fact_485_butlast_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),list(C),butlast(C),nil(C)) = nil(C) ).

% butlast.simps(1)
tff(fact_486_map__butlast,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),butlast(D),Xs)) = aa(list(C),list(C),butlast(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) ).

% map_butlast
tff(fact_487_snoc__eq__iff__butlast,axiom,
    ! [C: $tType,Xs: list(C),X: C,Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = Ys )
    <=> ( ( Ys != nil(C) )
        & ( aa(list(C),list(C),butlast(C),Ys) = Xs )
        & ( last(C,Ys) = X ) ) ) ).

% snoc_eq_iff_butlast
tff(fact_488_snoc__eq__iff__butlast_H,axiom,
    ! [C: $tType,Ys: list(C),Xs: list(C),X: C] :
      ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) )
    <=> ( ( Ys != nil(C) )
        & ( aa(list(C),list(C),butlast(C),Ys) = Xs )
        & ( last(C,Ys) = X ) ) ) ).

% snoc_eq_iff_butlast'
tff(fact_489_Min__in,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => member2(C,lattic643756798350308766er_Min(C,A4),A4) ) ) ) ).

% Min_in
tff(fact_490_Max__in,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => member2(C,lattic643756798349783984er_Max(C,A4),A4) ) ) ) ).

% Max_in
tff(fact_491_last_Osimps,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      last(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(Xs = nil(C),X,last(C,Xs)) ).

% last.simps
tff(fact_492_last__ConsL,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( ( Xs = nil(C) )
     => ( last(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = X ) ) ).

% last_ConsL
tff(fact_493_last__ConsR,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( ( Xs != nil(C) )
     => ( last(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = last(C,Xs) ) ) ).

% last_ConsR
tff(fact_494_last__map,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,D)] :
      ( ( Xs != nil(C) )
     => ( last(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) = aa(C,D,F,last(C,Xs)) ) ) ).

% last_map
tff(fact_495_last__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      last(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = $ite(Ys = nil(C),last(C,Xs),last(C,Ys)) ).

% last_append
tff(fact_496_longest__common__suffix,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
    ? [Ss: list(C),Xs4: list(C),Ys4: list(C)] :
      ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs4),Ss) )
      & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys4),Ss) )
      & ( ( Xs4 = nil(C) )
        | ( Ys4 = nil(C) )
        | ( last(C,Xs4) != last(C,Ys4) ) ) ) ).

% longest_common_suffix
tff(fact_497_butlast_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(Xs = nil(C),nil(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),butlast(C),Xs))) ).

% butlast.simps(2)
tff(fact_498_butlast__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = $ite(Ys = nil(C),aa(list(C),list(C),butlast(C),Xs),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),butlast(C),Ys))) ).

% butlast_append
tff(fact_499_Inf__fin_Oin__idem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) = aa(set(C),C,lattic7752659483105999362nf_fin(C),A4) ) ) ) ) ).

% Inf_fin.in_idem
tff(fact_500_Misc_Ofoldr__Cons,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),foldr(C,list(C)),cons(C)),Xs),nil(C)) = Xs ).

% Misc.foldr_Cons
tff(fact_501_Min__less__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),lattic643756798350308766er_Min(C,A4)),X)
            <=> ? [X4: C] :
                  ( member2(C,X4,A4)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),X) ) ) ) ) ) ).

% Min_less_iff
tff(fact_502_Max__gr__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),lattic643756798349783984er_Max(C,A4))
            <=> ? [X4: C] :
                  ( member2(C,X4,A4)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),X4) ) ) ) ) ) ).

% Max_gr_iff
tff(fact_503_butlast__eq__consE,axiom,
    ! [C: $tType,La: list(C),X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),butlast(C),La) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) )
     => ~ ! [Xl: C] : La != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Xl),nil(C)))) ) ).

% butlast_eq_consE
tff(fact_504_butlast__eq__cons__conv,axiom,
    ! [C: $tType,La: list(C),X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),butlast(C),La) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) )
    <=> ? [Xl2: C] : La = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Xl2),nil(C)))) ) ).

% butlast_eq_cons_conv
tff(fact_505_SuccD,axiom,
    ! [C: $tType,K: C,Kl2: set(list(C)),Kl: list(C)] :
      ( member2(C,K,bNF_Greatest_Succ(C,Kl2,Kl))
     => member2(list(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Kl),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),K),nil(C))),Kl2) ) ).

% SuccD
tff(fact_506_shift__def,axiom,
    ! [D: $tType,C: $tType,Lab: fun(list(C),D),K: C,X3: list(C)] : bNF_Greatest_shift(C,D,Lab,K,X3) = aa(list(C),D,Lab,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),K),X3)) ).

% shift_def
tff(fact_507_empty__Shift,axiom,
    ! [C: $tType,Kl2: set(list(C)),K: C] :
      ( member2(list(C),nil(C),Kl2)
     => ( member2(C,K,bNF_Greatest_Succ(C,Kl2,nil(C)))
       => member2(list(C),nil(C),bNF_Greatest_Shift(C,Kl2,K)) ) ) ).

% empty_Shift
tff(fact_508_Succ__Shift,axiom,
    ! [C: $tType,Kl2: set(list(C)),K: C,Kl: list(C)] : bNF_Greatest_Succ(C,bNF_Greatest_Shift(C,Kl2,K),Kl) = bNF_Greatest_Succ(C,Kl2,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),K),Kl)) ).

% Succ_Shift
tff(fact_509_Sup__fin_Oinsert,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic5882676163264333800up_fin(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),lattic5882676163264333800up_fin(C,A4)) ) ) ) ) ).

% Sup_fin.insert
tff(fact_510_Inf__fin_Oinsert,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) ) ) ) ) ).

% Inf_fin.insert
tff(fact_511_Inf__fin__le__Sup__fin,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)),lattic5882676163264333800up_fin(C,A4)) ) ) ) ).

% Inf_fin_le_Sup_fin
tff(fact_512_Sup__fin_Osubset,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( B3 != bot_bot(set(C)) )
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
             => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),lattic5882676163264333800up_fin(C,B3)),lattic5882676163264333800up_fin(C,A4)) = lattic5882676163264333800up_fin(C,A4) ) ) ) ) ) ).

% Sup_fin.subset
tff(fact_513_Inf__fin_Osubset,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( B3 != bot_bot(set(C)) )
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
             => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,lattic7752659483105999362nf_fin(C),B3)),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) = aa(set(C),C,lattic7752659483105999362nf_fin(C),A4) ) ) ) ) ) ).

% Inf_fin.subset
tff(fact_514_Sup__fin_Oinsert__not__elem,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ~ member2(C,X,A4)
           => ( ( A4 != bot_bot(set(C)) )
             => ( lattic5882676163264333800up_fin(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),X),lattic5882676163264333800up_fin(C,A4)) ) ) ) ) ) ).

% Sup_fin.insert_not_elem
tff(fact_515_Sup__fin_Oclosed,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C,Y2: C] : member2(C,aa(C,C,aa(C,fun(C,C),sup_sup(C),X2),Y2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C)))))
             => member2(C,lattic5882676163264333800up_fin(C,A4),A4) ) ) ) ) ).

% Sup_fin.closed
tff(fact_516_order__refl,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),X) ) ).

% order_refl
tff(fact_517_dual__order_Orefl,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),A3) ) ).

% dual_order.refl
tff(fact_518_subsetI,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,A4)
         => member2(C,X2,B3) )
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ).

% subsetI
tff(fact_519_subset__antisym,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
       => ( A4 = B3 ) ) ) ).

% subset_antisym
tff(fact_520_insertCI,axiom,
    ! [C: $tType,A3: C,B3: set(C),B2: C] :
      ( ( ~ member2(C,A3,B3)
       => ( A3 = B2 ) )
     => member2(C,A3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),B3)) ) ).

% insertCI
tff(fact_521_insert__iff,axiom,
    ! [C: $tType,A3: C,B2: C,A4: set(C)] :
      ( member2(C,A3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),A4))
    <=> ( ( A3 = B2 )
        | member2(C,A3,A4) ) ) ).

% insert_iff
tff(fact_522_insert__absorb2,axiom,
    ! [C: $tType,X: C,A4: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4) ).

% insert_absorb2
tff(fact_523_inf_Obounded__iff,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),C3))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% inf.bounded_iff
tff(fact_524_le__inf__iff,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2) ) ) ) ).

% le_inf_iff
tff(fact_525_le__sup__iff,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),Z2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) ) ) ) ).

% le_sup_iff
tff(fact_526_sup_Obounded__iff,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),C3)),A3)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3) ) ) ) ).

% sup.bounded_iff
tff(fact_527_empty__subsetI,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),bot_bot(set(C))),A4) ).

% empty_subsetI
tff(fact_528_subset__empty,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),bot_bot(set(C)))
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% subset_empty
tff(fact_529_singletonI,axiom,
    ! [C: $tType,A3: C] : member2(C,A3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ).

% singletonI
tff(fact_530_insert__subset,axiom,
    ! [C: $tType,X: C,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)),B3)
    <=> ( member2(C,X,B3)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ) ).

% insert_subset
tff(fact_531_Int__subset__iff,axiom,
    ! [C: $tType,C4: set(C),A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),A4)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),B3) ) ) ).

% Int_subset_iff
tff(fact_532_Int__insert__right__if1,axiom,
    ! [C: $tType,A3: C,A4: set(C),B3: set(C)] :
      ( member2(C,A3,A4)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% Int_insert_right_if1
tff(fact_533_Int__insert__right__if0,axiom,
    ! [C: $tType,A3: C,A4: set(C),B3: set(C)] :
      ( ~ member2(C,A3,A4)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ) ) ).

% Int_insert_right_if0
tff(fact_534_insert__inter__insert,axiom,
    ! [C: $tType,A3: C,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ).

% insert_inter_insert
tff(fact_535_Int__insert__left__if1,axiom,
    ! [C: $tType,A3: C,C4: set(C),B3: set(C)] :
      ( member2(C,A3,C4)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)),C4) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) ) ) ).

% Int_insert_left_if1
tff(fact_536_Int__insert__left__if0,axiom,
    ! [C: $tType,A3: C,C4: set(C),B3: set(C)] :
      ( ~ member2(C,A3,C4)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)),C4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4) ) ) ).

% Int_insert_left_if0
tff(fact_537_Un__subset__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),C4)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4) ) ) ).

% Un_subset_iff
tff(fact_538_Un__insert__left,axiom,
    ! [C: $tType,A3: C,B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)),C4) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) ).

% Un_insert_left
tff(fact_539_Un__insert__right,axiom,
    ! [C: $tType,A4: set(C),A3: C,B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ).

% Un_insert_right
tff(fact_540_psubsetI,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( ( A4 != B3 )
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3) ) ) ).

% psubsetI
tff(fact_541_singleton__insert__inj__eq,axiom,
    ! [C: $tType,B2: C,A3: C,A4: set(C)] :
      ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) )
    <=> ( ( A3 = B2 )
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) ) ) ).

% singleton_insert_inj_eq
tff(fact_542_singleton__insert__inj__eq_H,axiom,
    ! [C: $tType,A3: C,A4: set(C),B2: C] :
      ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))) )
    <=> ( ( A3 = B2 )
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) ) ) ).

% singleton_insert_inj_eq'
tff(fact_543_disjoint__insert_I2_J,axiom,
    ! [C: $tType,A4: set(C),B2: C,B3: set(C)] :
      ( ( bot_bot(set(C)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),B3)) )
    <=> ( ~ member2(C,B2,A4)
        & ( bot_bot(set(C)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ) ) ) ).

% disjoint_insert(2)
tff(fact_544_disjoint__insert_I1_J,axiom,
    ! [C: $tType,B3: set(C),A3: C,A4: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = bot_bot(set(C)) )
    <=> ( ~ member2(C,A3,B3)
        & ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),A4) = bot_bot(set(C)) ) ) ) ).

% disjoint_insert(1)
tff(fact_545_insert__disjoint_I2_J,axiom,
    ! [C: $tType,A3: C,A4: set(C),B3: set(C)] :
      ( ( bot_bot(set(C)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)),B3) )
    <=> ( ~ member2(C,A3,B3)
        & ( bot_bot(set(C)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ) ) ) ).

% insert_disjoint(2)
tff(fact_546_insert__disjoint_I1_J,axiom,
    ! [C: $tType,A3: C,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)),B3) = bot_bot(set(C)) )
    <=> ( ~ member2(C,A3,B3)
        & ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) ) ) ) ).

% insert_disjoint(1)
tff(fact_547_Max__singleton,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C] : lattic643756798349783984er_Max(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% Max_singleton
tff(fact_548_Min__singleton,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C] : lattic643756798350308766er_Min(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% Min_singleton
tff(fact_549_Sup__fin_Osingleton,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C] : lattic5882676163264333800up_fin(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% Sup_fin.singleton
tff(fact_550_Inf__fin_Osingleton,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C] : aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% Inf_fin.singleton
tff(fact_551_Max_Obounded__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798349783984er_Max(C,A4)),X)
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),X) ) ) ) ) ) ).

% Max.bounded_iff
tff(fact_552_Min_Obounded__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),lattic643756798350308766er_Min(C,A4))
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),X4) ) ) ) ) ) ).

% Min.bounded_iff
tff(fact_553_in__mono,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),X: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( member2(C,X,A4)
       => member2(C,X,B3) ) ) ).

% in_mono
tff(fact_554_insertE,axiom,
    ! [C: $tType,A3: C,B2: C,A4: set(C)] :
      ( member2(C,A3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),A4))
     => ( ( A3 != B2 )
       => member2(C,A3,A4) ) ) ).

% insertE
tff(fact_555_subsetD,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C3: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( member2(C,C3,A4)
       => member2(C,C3,B3) ) ) ).

% subsetD
tff(fact_556_insertI1,axiom,
    ! [C: $tType,A3: C,B3: set(C)] : member2(C,A3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) ).

% insertI1
tff(fact_557_insertI2,axiom,
    ! [C: $tType,A3: C,B3: set(C),B2: C] :
      ( member2(C,A3,B3)
     => member2(C,A3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),B3)) ) ).

% insertI2
tff(fact_558_equalityE,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( A4 = B3 )
     => ~ ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ~ aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4) ) ) ).

% equalityE
tff(fact_559_subset__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
    <=> ! [X4: C] :
          ( member2(C,X4,A4)
         => member2(C,X4,B3) ) ) ).

% subset_eq
tff(fact_560_equalityD1,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( A4 = B3 )
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ).

% equalityD1
tff(fact_561_equalityD2,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( A4 = B3 )
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4) ) ).

% equalityD2
tff(fact_562_Set_Oset__insert,axiom,
    ! [C: $tType,X: C,A4: set(C)] :
      ( member2(C,X,A4)
     => ~ ! [B6: set(C)] :
            ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B6) )
           => member2(C,X,B6) ) ) ).

% Set.set_insert
tff(fact_563_subset__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
    <=> ! [T2: C] :
          ( member2(C,T2,A4)
         => member2(C,T2,B3) ) ) ).

% subset_iff
tff(fact_564_insert__mono,axiom,
    ! [C: $tType,C4: set(C),D2: set(C),A3: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),D2)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),C4)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),D2)) ) ).

% insert_mono
tff(fact_565_subset__refl,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),A4) ).

% subset_refl
tff(fact_566_Collect__mono,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ! [X2: C] :
          ( aa(C,$o,Pa,X2)
         => aa(C,$o,Q,X2) )
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),collect(C,Pa)),collect(C,Q)) ) ).

% Collect_mono
tff(fact_567_insert__ident,axiom,
    ! [C: $tType,X: C,A4: set(C),B3: set(C)] :
      ( ~ member2(C,X,A4)
     => ( ~ member2(C,X,B3)
       => ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B3) )
        <=> ( A4 = B3 ) ) ) ) ).

% insert_ident
tff(fact_568_subset__trans,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4) ) ) ).

% subset_trans
tff(fact_569_insert__absorb,axiom,
    ! [C: $tType,A3: C,A4: set(C)] :
      ( member2(C,A3,A4)
     => ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) = A4 ) ) ).

% insert_absorb
tff(fact_570_insert__eq__iff,axiom,
    ! [C: $tType,A3: C,A4: set(C),B2: C,B3: set(C)] :
      ( ~ member2(C,A3,A4)
     => ( ~ member2(C,B2,B3)
       => ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),B3) )
        <=> $ite(
              A3 = B2,
              A4 = B3,
              ? [C5: set(C)] :
                ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),C5) )
                & ~ member2(C,B2,C5)
                & ( B3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),C5) )
                & ~ member2(C,A3,C5) ) ) ) ) ) ).

% insert_eq_iff
tff(fact_571_set__eq__subset,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( A4 = B3 )
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4) ) ) ).

% set_eq_subset
tff(fact_572_subset__insert,axiom,
    ! [C: $tType,X: C,A4: set(C),B3: set(C)] :
      ( ~ member2(C,X,A4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B3))
      <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ) ).

% subset_insert
tff(fact_573_insert__commute,axiom,
    ! [C: $tType,X: C,Y: C,A4: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),A4)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) ).

% insert_commute
tff(fact_574_subset__insertI,axiom,
    ! [C: $tType,B3: set(C),A3: C] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) ).

% subset_insertI
tff(fact_575_subset__insertI2,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),B2: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),B3)) ) ).

% subset_insertI2
tff(fact_576_Collect__mono__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),collect(C,Pa)),collect(C,Q))
    <=> ! [X4: C] :
          ( aa(C,$o,Pa,X4)
         => aa(C,$o,Q,X4) ) ) ).

% Collect_mono_iff
tff(fact_577_mk__disjoint__insert,axiom,
    ! [C: $tType,A3: C,A4: set(C)] :
      ( member2(C,A3,A4)
     => ? [B6: set(C)] :
          ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B6) )
          & ~ member2(C,A3,B6) ) ) ).

% mk_disjoint_insert
tff(fact_578_nle__le,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            & ( B2 != A3 ) ) ) ) ).

% nle_le
tff(fact_579_le__cases3,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
           => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) )
         => ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2) )
           => ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2)
               => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),Y) )
             => ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),Y)
                 => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) )
               => ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2)
                   => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),X) )
                 => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),X)
                     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ) ) ) ) ) ).

% le_cases3
tff(fact_580_order__class_Oorder__eq__iff,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( ( X = Y )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ) ).

% order_class.order_eq_iff
tff(fact_581_ord__eq__le__trans,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 = B2 )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% ord_eq_le_trans
tff(fact_582_ord__le__eq__trans,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( ( B2 = C3 )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% ord_le_eq_trans
tff(fact_583_order__antisym,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
           => ( X = Y ) ) ) ) ).

% order_antisym
tff(fact_584_order_Otrans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% order.trans
tff(fact_585_order__trans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2) ) ) ) ).

% order_trans
tff(fact_586_linorder__wlog,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Pa: fun(C,fun(C,$o)),A3: C,B2: C] :
          ( ! [A5: C,B4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A5),B4)
             => aa(C,$o,aa(C,fun(C,$o),Pa,A5),B4) )
         => ( ! [A5: C,B4: C] :
                ( aa(C,$o,aa(C,fun(C,$o),Pa,B4),A5)
               => aa(C,$o,aa(C,fun(C,$o),Pa,A5),B4) )
           => aa(C,$o,aa(C,fun(C,$o),Pa,A3),B2) ) ) ) ).

% linorder_wlog
tff(fact_587_dual__order_Oeq__iff,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = B2 )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% dual_order.eq_iff
tff(fact_588_dual__order_Oantisym,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
           => ( A3 = B2 ) ) ) ) ).

% dual_order.antisym
tff(fact_589_dual__order_Otrans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3) ) ) ) ).

% dual_order.trans
tff(fact_590_antisym,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
           => ( A3 = B2 ) ) ) ) ).

% antisym
tff(fact_591_le__funD,axiom,
    ! [D: $tType,C: $tType] :
      ( ord(D)
     => ! [F: fun(C,D),G: fun(C,D),X: C] :
          ( aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less_eq(fun(C,D)),F),G)
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X)),aa(C,D,G,X)) ) ) ).

% le_funD
tff(fact_592_le__funE,axiom,
    ! [D: $tType,C: $tType] :
      ( ord(D)
     => ! [F: fun(C,D),G: fun(C,D),X: C] :
          ( aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less_eq(fun(C,D)),F),G)
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X)),aa(C,D,G,X)) ) ) ).

% le_funE
tff(fact_593_le__funI,axiom,
    ! [D: $tType,C: $tType] :
      ( ord(D)
     => ! [F: fun(C,D),G: fun(C,D)] :
          ( ! [X2: C] : aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,G,X2))
         => aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less_eq(fun(C,D)),F),G) ) ) ).

% le_funI
tff(fact_594_le__fun__def,axiom,
    ! [D: $tType,C: $tType] :
      ( ord(D)
     => ! [F: fun(C,D),G: fun(C,D)] :
          ( aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less_eq(fun(C,D)),F),G)
        <=> ! [X4: C] : aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X4)),aa(C,D,G,X4)) ) ) ).

% le_fun_def
tff(fact_595_Orderings_Oorder__eq__iff,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = B2 )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ).

% Orderings.order_eq_iff
tff(fact_596_order__subst1,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,F: fun(D,C),B2: D,C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(D,C,F,B2))
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),B2),C3)
           => ( ! [X2: D,Y2: D] :
                  ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),X2),Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(D,C,F,X2)),aa(D,C,F,Y2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(D,C,F,C3)) ) ) ) ) ).

% order_subst1
tff(fact_597_order__subst2,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,B2: C,F: fun(C,D),C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,B2)),C3)
           => ( ! [X2: C,Y2: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y2)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,A3)),C3) ) ) ) ) ).

% order_subst2
tff(fact_598_ord__eq__le__eq__trans,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( ( A3 = B2 )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
           => ( ( C3 = D3 )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),D3) ) ) ) ) ).

% ord_eq_le_eq_trans
tff(fact_599_order__eq__refl,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C] :
          ( ( X = Y )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ).

% order_eq_refl
tff(fact_600_subset__Collect__conv,axiom,
    ! [C: $tType,S: set(C),Pa: fun(C,$o)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),collect(C,Pa))
    <=> ! [X4: C] :
          ( member2(C,X4,S)
         => aa(C,$o,Pa,X4) ) ) ).

% subset_Collect_conv
tff(fact_601_linorder__linear,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
          | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ).

% linorder_linear
tff(fact_602_ord__eq__le__subst,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ord(D)
        & ord(C) )
     => ! [A3: C,F: fun(D,C),B2: D,C3: D] :
          ( ( A3 = aa(D,C,F,B2) )
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),B2),C3)
           => ( ! [X2: D,Y2: D] :
                  ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),X2),Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(D,C,F,X2)),aa(D,C,F,Y2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(D,C,F,C3)) ) ) ) ) ).

% ord_eq_le_subst
tff(fact_603_ord__le__eq__subst,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ord(D)
        & ord(C) )
     => ! [A3: C,B2: C,F: fun(C,D),C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( ( aa(C,D,F,B2) = C3 )
           => ( ! [X2: C,Y2: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y2)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,A3)),C3) ) ) ) ) ).

% ord_le_eq_subst
tff(fact_604_linorder__le__cases,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ).

% linorder_le_cases
tff(fact_605_order__antisym__conv,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
          <=> ( X = Y ) ) ) ) ).

% order_antisym_conv
tff(fact_606_subset__singletonD,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))
     => ( ( A4 = bot_bot(set(C)) )
        | ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) ) ) ).

% subset_singletonD
tff(fact_607_subset__singleton__iff,axiom,
    ! [C: $tType,X5: set(C),A3: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),X5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))
    <=> ( ( X5 = bot_bot(set(C)) )
        | ( X5 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) ) ) ) ).

% subset_singleton_iff
tff(fact_608_finite__ranking__induct,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [S: set(C),Pa: fun(set(C),$o),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),$o,Pa,bot_bot(set(C)))
           => ( ! [X2: C,S2: set(C)] :
                  ( aa(set(C),$o,finite_finite2(C),S2)
                 => ( ! [Y4: C] :
                        ( member2(C,Y4,S2)
                       => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,Y4)),aa(C,D,F,X2)) )
                   => ( aa(set(C),$o,Pa,S2)
                     => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),S2)) ) ) )
             => aa(set(C),$o,Pa,S) ) ) ) ) ).

% finite_ranking_induct
tff(fact_609_finite__subset__induct_H,axiom,
    ! [C: $tType,F2: set(C),A4: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),F2)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),F2),A4)
       => ( aa(set(C),$o,Pa,bot_bot(set(C)))
         => ( ! [A5: C,F3: set(C)] :
                ( aa(set(C),$o,finite_finite2(C),F3)
               => ( member2(C,A5,A4)
                 => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),F3),A4)
                   => ( ~ member2(C,A5,F3)
                     => ( aa(set(C),$o,Pa,F3)
                       => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A5),F3)) ) ) ) ) )
           => aa(set(C),$o,Pa,F2) ) ) ) ) ).

% finite_subset_induct'
tff(fact_610_finite__subset__induct,axiom,
    ! [C: $tType,F2: set(C),A4: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),F2)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),F2),A4)
       => ( aa(set(C),$o,Pa,bot_bot(set(C)))
         => ( ! [A5: C,F3: set(C)] :
                ( aa(set(C),$o,finite_finite2(C),F3)
               => ( member2(C,A5,A4)
                 => ( ~ member2(C,A5,F3)
                   => ( aa(set(C),$o,Pa,F3)
                     => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A5),F3)) ) ) ) )
           => aa(set(C),$o,Pa,F2) ) ) ) ) ).

% finite_subset_induct
tff(fact_611_singleton__inject,axiom,
    ! [C: $tType,A3: C,B2: C] :
      ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))) )
     => ( A3 = B2 ) ) ).

% singleton_inject
tff(fact_612_insert__not__empty,axiom,
    ! [C: $tType,A3: C,A4: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) != bot_bot(set(C)) ).

% insert_not_empty
tff(fact_613_doubleton__eq__iff,axiom,
    ! [C: $tType,A3: C,B2: C,C3: C,D3: C] :
      ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),C3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),D3),bot_bot(set(C)))) )
    <=> ( ( ( A3 = C3 )
          & ( B2 = D3 ) )
        | ( ( A3 = D3 )
          & ( B2 = C3 ) ) ) ) ).

% doubleton_eq_iff
tff(fact_614_singleton__iff,axiom,
    ! [C: $tType,B2: C,A3: C] :
      ( member2(C,B2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))
    <=> ( B2 = A3 ) ) ).

% singleton_iff
tff(fact_615_singletonD,axiom,
    ! [C: $tType,B2: C,A3: C] :
      ( member2(C,B2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))
     => ( B2 = A3 ) ) ).

% singletonD
tff(fact_616_leD,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y) ) ) ).

% leD
tff(fact_617_leI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ).

% leI
tff(fact_618_nless__le,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            | ( A3 = B2 ) ) ) ) ).

% nless_le
tff(fact_619_antisym__conv1,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
          <=> ( X = Y ) ) ) ) ).

% antisym_conv1
tff(fact_620_antisym__conv2,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
          <=> ( X = Y ) ) ) ) ).

% antisym_conv2
tff(fact_621_dense__ge,axiom,
    ! [C: $tType] :
      ( dense_linorder(C)
     => ! [Z2: C,Y: C] :
          ( ! [X2: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),X2)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X2) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) ) ) ).

% dense_ge
tff(fact_622_dense__le,axiom,
    ! [C: $tType] :
      ( dense_linorder(C)
     => ! [Y: C,Z2: C] :
          ( ! [X2: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Z2) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) ) ) ).

% dense_le
tff(fact_623_less__le__not__le,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
            & ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ) ).

% less_le_not_le
tff(fact_624_not__le__imp__less,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Y: C,X: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y) ) ) ).

% not_le_imp_less
tff(fact_625_order_Oorder__iff__strict,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
            | ( A3 = B2 ) ) ) ) ).

% order.order_iff_strict
tff(fact_626_order_Ostrict__iff__order,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            & ( A3 != B2 ) ) ) ) ).

% order.strict_iff_order
tff(fact_627_order_Ostrict__trans1,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% order.strict_trans1
tff(fact_628_order_Ostrict__trans2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% order.strict_trans2
tff(fact_629_order_Ostrict__iff__not,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            & ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ).

% order.strict_iff_not
tff(fact_630_dense__ge__bounded,axiom,
    ! [C: $tType] :
      ( dense_linorder(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),X)
         => ( ! [W3: C] :
                ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),W3)
               => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),W3),X)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),W3) ) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) ) ) ) ).

% dense_ge_bounded
tff(fact_631_dense__le__bounded,axiom,
    ! [C: $tType] :
      ( dense_linorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( ! [W3: C] :
                ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),W3)
               => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),W3),Y)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),W3),Z2) ) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) ) ) ) ).

% dense_le_bounded
tff(fact_632_dual__order_Oorder__iff__strict,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
            | ( A3 = B2 ) ) ) ) ).

% dual_order.order_iff_strict
tff(fact_633_dual__order_Ostrict__iff__order,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            & ( A3 != B2 ) ) ) ) ).

% dual_order.strict_iff_order
tff(fact_634_dual__order_Ostrict__trans1,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3) ) ) ) ).

% dual_order.strict_trans1
tff(fact_635_dual__order_Ostrict__trans2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3) ) ) ) ).

% dual_order.strict_trans2
tff(fact_636_dual__order_Ostrict__iff__not,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            & ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% dual_order.strict_iff_not
tff(fact_637_order_Ostrict__implies__order,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% order.strict_implies_order
tff(fact_638_dual__order_Ostrict__implies__order,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% dual_order.strict_implies_order
tff(fact_639_order__le__less,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
            | ( X = Y ) ) ) ) ).

% order_le_less
tff(fact_640_order__less__le,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
            & ( X != Y ) ) ) ) ).

% order_less_le
tff(fact_641_linorder__not__le,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% linorder_not_le
tff(fact_642_linorder__not__less,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ).

% linorder_not_less
tff(fact_643_order__less__imp__le,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ).

% order_less_imp_le
tff(fact_644_order__le__neq__trans,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( ( A3 != B2 )
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% order_le_neq_trans
tff(fact_645_order__neq__le__trans,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != B2 )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% order_neq_le_trans
tff(fact_646_order__le__less__trans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),Z2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Z2) ) ) ) ).

% order_le_less_trans
tff(fact_647_order__less__le__trans,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Z2) ) ) ) ).

% order_less_le_trans
tff(fact_648_order__le__less__subst1,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,F: fun(D,C),B2: D,C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(D,C,F,B2))
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),B2),C3)
           => ( ! [X2: D,Y2: D] :
                  ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),X2),Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(D,C,F,X2)),aa(D,C,F,Y2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(D,C,F,C3)) ) ) ) ) ).

% order_le_less_subst1
tff(fact_649_order__le__less__subst2,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,B2: C,F: fun(C,D),C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,B2)),C3)
           => ( ! [X2: C,Y2: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y2)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,A3)),C3) ) ) ) ) ).

% order_le_less_subst2
tff(fact_650_order__less__le__subst1,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,F: fun(D,C),B2: D,C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(D,C,F,B2))
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),B2),C3)
           => ( ! [X2: D,Y2: D] :
                  ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),X2),Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(D,C,F,X2)),aa(D,C,F,Y2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(D,C,F,C3)) ) ) ) ) ).

% order_less_le_subst1
tff(fact_651_order__less__le__subst2,axiom,
    ! [C: $tType,D: $tType] :
      ( ( order(D)
        & order(C) )
     => ! [A3: C,B2: C,F: fun(C,D),C3: D] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,B2)),C3)
           => ( ! [X2: C,Y2: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Y2)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,A3)),C3) ) ) ) ) ).

% order_less_le_subst2
tff(fact_652_linorder__le__less__linear,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
          | aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% linorder_le_less_linear
tff(fact_653_order__le__imp__less__or__eq,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y)
            | ( X = Y ) ) ) ) ).

% order_le_imp_less_or_eq
tff(fact_654_Int__insert__right,axiom,
    ! [C: $tType,A4: set(C),A3: C,B3: set(C)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = $ite(member2(C,A3,A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ).

% Int_insert_right
tff(fact_655_Int__insert__left,axiom,
    ! [C: $tType,A3: C,B3: set(C),C4: set(C)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)),C4) = $ite(member2(C,A3,C4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) ).

% Int_insert_left
tff(fact_656_le__numeral__extra_I4_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),one_one(C)) ) ).

% le_numeral_extra(4)
tff(fact_657_bot_Oextremum__uniqueI,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),bot_bot(C))
         => ( A3 = bot_bot(C) ) ) ) ).

% bot.extremum_uniqueI
tff(fact_658_bot_Oextremum__unique,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),bot_bot(C))
        <=> ( A3 = bot_bot(C) ) ) ) ).

% bot.extremum_unique
tff(fact_659_bot_Oextremum,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),bot_bot(C)),A3) ) ).

% bot.extremum
tff(fact_660_inf_OcoboundedI2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),C3) ) ) ).

% inf.coboundedI2
tff(fact_661_inf_OcoboundedI1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),C3) ) ) ).

% inf.coboundedI1
tff(fact_662_inf_Oabsorb__iff2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = B2 ) ) ) ).

% inf.absorb_iff2
tff(fact_663_inf_Oabsorb__iff1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = A3 ) ) ) ).

% inf.absorb_iff1
tff(fact_664_inf_Ocobounded2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),B2) ) ).

% inf.cobounded2
tff(fact_665_inf_Ocobounded1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),A3) ) ).

% inf.cobounded1
tff(fact_666_inf_Oorder__iff,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( A3 = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) ) ) ) ).

% inf.order_iff
tff(fact_667_inf__greatest,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2)) ) ) ) ).

% inf_greatest
tff(fact_668_inf_OboundedI,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),C3)) ) ) ) ).

% inf.boundedI
tff(fact_669_inf_OboundedE,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),inf_inf(C),B2),C3))
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% inf.boundedE
tff(fact_670_inf__absorb2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = Y ) ) ) ).

% inf_absorb2
tff(fact_671_inf__absorb1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = X ) ) ) ).

% inf_absorb1
tff(fact_672_inf_Oabsorb2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = B2 ) ) ) ).

% inf.absorb2
tff(fact_673_inf_Oabsorb1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = A3 ) ) ) ).

% inf.absorb1
tff(fact_674_le__iff__inf,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
        <=> ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = X ) ) ) ).

% le_iff_inf
tff(fact_675_inf__unique,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [F: fun(C,fun(C,C)),X: C,Y: C] :
          ( ! [X2: C,Y2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),F,X2),Y2)),X2)
         => ( ! [X2: C,Y2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),F,X2),Y2)),Y2)
           => ( ! [X2: C,Y2: C,Z4: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y2)
                 => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Z4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),aa(C,C,aa(C,fun(C,C),F,Y2),Z4)) ) )
             => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = aa(C,C,aa(C,fun(C,C),F,X),Y) ) ) ) ) ) ).

% inf_unique
tff(fact_676_inf_OorderI,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% inf.orderI
tff(fact_677_inf_OorderE,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( A3 = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) ) ) ) ).

% inf.orderE
tff(fact_678_le__infI2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [B2: C,X: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),X) ) ) ).

% le_infI2
tff(fact_679_le__infI1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,X: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),X) ) ) ).

% le_infI1
tff(fact_680_inf__mono,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A3: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)),aa(C,C,aa(C,fun(C,C),inf_inf(C),C3),D3)) ) ) ) ).

% inf_mono
tff(fact_681_le__infI,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2)) ) ) ) ).

% le_infI
tff(fact_682_le__infE,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2))
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A3)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),B2) ) ) ) ).

% le_infE
tff(fact_683_inf__le2,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),Y) ) ).

% inf_le2
tff(fact_684_inf__le1,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),X) ) ).

% inf_le1
tff(fact_685_inf__sup__ord_I1_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),X) ) ).

% inf_sup_ord(1)
tff(fact_686_inf__sup__ord_I2_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),Y) ) ).

% inf_sup_ord(2)
tff(fact_687_inf__sup__ord_I4_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [Y: C,X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) ) ).

% inf_sup_ord(4)
tff(fact_688_inf__sup__ord_I3_J,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) ) ).

% inf_sup_ord(3)
tff(fact_689_le__supE,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)),X)
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),X)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),X) ) ) ) ).

% le_supE
tff(fact_690_le__supI,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,X: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),X)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)),X) ) ) ) ).

% le_supI
tff(fact_691_sup__ge1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) ) ).

% sup_ge1
tff(fact_692_sup__ge2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [Y: C,X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) ) ).

% sup_ge2
tff(fact_693_le__supI1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% le_supI1
tff(fact_694_le__supI2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% le_supI2
tff(fact_695_sup_Omono,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [C3: C,A3: C,D3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),D3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),C3),D3)),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ) ).

% sup.mono
tff(fact_696_sup__mono,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)),aa(C,C,aa(C,fun(C,C),sup_sup(C),C3),D3)) ) ) ) ).

% sup_mono
tff(fact_697_sup__least,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [Y: C,X: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),X)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)),X) ) ) ) ).

% sup_least
tff(fact_698_le__iff__sup,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
        <=> ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = Y ) ) ) ).

% le_iff_sup
tff(fact_699_sup_OorderE,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( A3 = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) ) ) ) ).

% sup.orderE
tff(fact_700_sup_OorderI,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% sup.orderI
tff(fact_701_sup__unique,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [F: fun(C,fun(C,C)),X: C,Y: C] :
          ( ! [X2: C,Y2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),aa(C,C,aa(C,fun(C,C),F,X2),Y2))
         => ( ! [X2: C,Y2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),aa(C,C,aa(C,fun(C,C),F,X2),Y2))
           => ( ! [X2: C,Y2: C,Z4: C] :
                  ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),X2)
                 => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z4),X2)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),F,Y2),Z4)),X2) ) )
             => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = aa(C,C,aa(C,fun(C,C),F,X),Y) ) ) ) ) ) ).

% sup_unique
tff(fact_702_sup_Oabsorb1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = A3 ) ) ) ).

% sup.absorb1
tff(fact_703_sup_Oabsorb2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = B2 ) ) ) ).

% sup.absorb2
tff(fact_704_sup__absorb1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = X ) ) ) ).

% sup_absorb1
tff(fact_705_sup__absorb2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = Y ) ) ) ).

% sup_absorb2
tff(fact_706_sup_OboundedE,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),C3)),A3)
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3) ) ) ) ).

% sup.boundedE
tff(fact_707_sup_OboundedI,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),B2),C3)),A3) ) ) ) ).

% sup.boundedI
tff(fact_708_sup_Oorder__iff,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( A3 = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) ) ) ) ).

% sup.order_iff
tff(fact_709_sup_Ocobounded1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ).

% sup.cobounded1
tff(fact_710_sup_Ocobounded2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ).

% sup.cobounded2
tff(fact_711_sup_Oabsorb__iff1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = A3 ) ) ) ).

% sup.absorb_iff1
tff(fact_712_sup_Oabsorb__iff2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2) = B2 ) ) ) ).

% sup.absorb_iff2
tff(fact_713_sup_OcoboundedI1,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% sup.coboundedI1
tff(fact_714_sup_OcoboundedI2,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),B2)) ) ) ).

% sup.coboundedI2
tff(fact_715_Int__Collect__mono,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),Pa: fun(C,$o),Q: fun(C,$o)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( ! [X2: C] :
            ( member2(C,X2,A4)
           => ( aa(C,$o,Pa,X2)
             => aa(C,$o,Q,X2) ) )
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),collect(C,Q))) ) ) ).

% Int_Collect_mono
tff(fact_716_Int__greatest,axiom,
    ! [C: $tType,C4: set(C),A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),A4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),B3)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% Int_greatest
tff(fact_717_Int__absorb2,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = A4 ) ) ).

% Int_absorb2
tff(fact_718_Int__absorb1,axiom,
    ! [C: $tType,B3: set(C),A4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = B3 ) ) ).

% Int_absorb1
tff(fact_719_Int__lower2,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),B3) ).

% Int_lower2
tff(fact_720_Int__lower1,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),A4) ).

% Int_lower1
tff(fact_721_Int__mono,axiom,
    ! [C: $tType,A4: set(C),C4: set(C),B3: set(C),D2: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),D2)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C4),D2)) ) ) ).

% Int_mono
tff(fact_722_inter__eq__subsetI,axiom,
    ! [C: $tType,S: set(C),S3: set(C),A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),S3)
     => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),S3) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),S3) )
       => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),S) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),S) ) ) ) ).

% inter_eq_subsetI
tff(fact_723_Un__mono,axiom,
    ! [C: $tType,A4: set(C),C4: set(C),B3: set(C),D2: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),D2)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),C4),D2)) ) ) ).

% Un_mono
tff(fact_724_Un__least,axiom,
    ! [C: $tType,A4: set(C),C4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),C4) ) ) ).

% Un_least
tff(fact_725_Un__upper1,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ).

% Un_upper1
tff(fact_726_Un__upper2,axiom,
    ! [C: $tType,B3: set(C),A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ).

% Un_upper2
tff(fact_727_Un__absorb1,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = B3 ) ) ).

% Un_absorb1
tff(fact_728_Un__absorb2,axiom,
    ! [C: $tType,B3: set(C),A4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = A4 ) ) ).

% Un_absorb2
tff(fact_729_subset__UnE,axiom,
    ! [C: $tType,C4: set(C),A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
     => ~ ! [A7: set(C)] :
            ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A7),A4)
           => ! [B7: set(C)] :
                ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B7),B3)
               => ( C4 != aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A7),B7) ) ) ) ) ).

% subset_UnE
tff(fact_730_subset__Un__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
    <=> ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = B3 ) ) ).

% subset_Un_eq
tff(fact_731_subset__iff__psubset__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
        | ( A4 = B3 ) ) ) ).

% subset_iff_psubset_eq
tff(fact_732_subset__psubset__trans,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),B3),C4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),C4) ) ) ).

% subset_psubset_trans
tff(fact_733_subset__not__subset__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
        & ~ aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4) ) ) ).

% subset_not_subset_eq
tff(fact_734_psubset__subset__trans,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),C4) ) ) ).

% psubset_subset_trans
tff(fact_735_psubset__imp__subset,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ).

% psubset_imp_subset
tff(fact_736_psubset__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
        & ( A4 != B3 ) ) ) ).

% psubset_eq
tff(fact_737_psubsetE,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
     => ~ ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4) ) ) ).

% psubsetE
tff(fact_738_less__eq__assn__def,axiom,
    ! [A3: assn,B2: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),ord_less_eq(assn),A3),B2)
    <=> ( A3 = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),A3),B2) ) ) ).

% less_eq_assn_def
tff(fact_739_Max__mono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M: set(C),N4: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),M),N4)
         => ( ( M != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),N4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798349783984er_Max(C,M)),lattic643756798349783984er_Max(C,N4)) ) ) ) ) ).

% Max_mono
tff(fact_740_Max_Osubset__imp,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798349783984er_Max(C,A4)),lattic643756798349783984er_Max(C,B3)) ) ) ) ) ).

% Max.subset_imp
tff(fact_741_Min__antimono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M: set(C),N4: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),M),N4)
         => ( ( M != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),N4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798350308766er_Min(C,N4)),lattic643756798350308766er_Min(C,M)) ) ) ) ) ).

% Min_antimono
tff(fact_742_Min_Osubset__imp,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798350308766er_Min(C,B3)),lattic643756798350308766er_Min(C,A4)) ) ) ) ) ).

% Min.subset_imp
tff(fact_743_Inf__fin_Osubset__imp,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,lattic7752659483105999362nf_fin(C),B3)),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) ) ) ) ) ).

% Inf_fin.subset_imp
tff(fact_744_Sup__fin_Osubset__imp,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic5882676163264333800up_fin(C,A4)),lattic5882676163264333800up_fin(C,B3)) ) ) ) ) ).

% Sup_fin.subset_imp
tff(fact_745_infinite__finite__induct,axiom,
    ! [C: $tType,Pa: fun(set(C),$o),A4: set(C)] :
      ( ! [A8: set(C)] :
          ( ~ aa(set(C),$o,finite_finite2(C),A8)
         => aa(set(C),$o,Pa,A8) )
     => ( aa(set(C),$o,Pa,bot_bot(set(C)))
       => ( ! [X2: C,F3: set(C)] :
              ( aa(set(C),$o,finite_finite2(C),F3)
             => ( ~ member2(C,X2,F3)
               => ( aa(set(C),$o,Pa,F3)
                 => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),F3)) ) ) )
         => aa(set(C),$o,Pa,A4) ) ) ) ).

% infinite_finite_induct
tff(fact_746_finite__ne__induct,axiom,
    ! [C: $tType,F2: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),F2)
     => ( ( F2 != bot_bot(set(C)) )
       => ( ! [X2: C] : aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C))))
         => ( ! [X2: C,F3: set(C)] :
                ( aa(set(C),$o,finite_finite2(C),F3)
               => ( ( F3 != bot_bot(set(C)) )
                 => ( ~ member2(C,X2,F3)
                   => ( aa(set(C),$o,Pa,F3)
                     => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),F3)) ) ) ) )
           => aa(set(C),$o,Pa,F2) ) ) ) ) ).

% finite_ne_induct
tff(fact_747_finite__induct,axiom,
    ! [C: $tType,F2: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),F2)
     => ( aa(set(C),$o,Pa,bot_bot(set(C)))
       => ( ! [X2: C,F3: set(C)] :
              ( aa(set(C),$o,finite_finite2(C),F3)
             => ( ~ member2(C,X2,F3)
               => ( aa(set(C),$o,Pa,F3)
                 => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),F3)) ) ) )
         => aa(set(C),$o,Pa,F2) ) ) ) ).

% finite_induct
tff(fact_748_finite_Osimps,axiom,
    ! [C: $tType,A3: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A3)
    <=> ( ( A3 = bot_bot(set(C)) )
        | ? [A9: set(C),A6: C] :
            ( ( A3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A6),A9) )
            & aa(set(C),$o,finite_finite2(C),A9) ) ) ) ).

% finite.simps
tff(fact_749_finite_Ocases,axiom,
    ! [C: $tType,A3: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A3)
     => ( ( A3 != bot_bot(set(C)) )
       => ~ ! [A8: set(C)] :
              ( ? [A5: C] : A3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A5),A8)
             => ~ aa(set(C),$o,finite_finite2(C),A8) ) ) ) ).

% finite.cases
tff(fact_750_insert__is__Un,axiom,
    ! [C: $tType,A3: C,A4: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))),A4) ).

% insert_is_Un
tff(fact_751_Un__singleton__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),X: C] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) )
    <=> ( ( ( A4 = bot_bot(set(C)) )
          & ( B3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) )
        | ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) )
          & ( B3 = bot_bot(set(C)) ) )
        | ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) )
          & ( B3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) ) ) ) ).

% Un_singleton_iff
tff(fact_752_singleton__Un__iff,axiom,
    ! [C: $tType,X: C,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) )
    <=> ( ( ( A4 = bot_bot(set(C)) )
          & ( B3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) )
        | ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) )
          & ( B3 = bot_bot(set(C)) ) )
        | ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) )
          & ( B3 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) ) ) ) ).

% singleton_Un_iff
tff(fact_753_finite__has__minimal,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ? [X2: C] :
                ( member2(C,X2,A4)
                & ! [Xa3: C] :
                    ( member2(C,Xa3,A4)
                   => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Xa3),X2)
                     => ( X2 = Xa3 ) ) ) ) ) ) ) ).

% finite_has_minimal
tff(fact_754_finite__has__maximal,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ? [X2: C] :
                ( member2(C,X2,A4)
                & ! [Xa3: C] :
                    ( member2(C,Xa3,A4)
                   => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Xa3)
                     => ( X2 = Xa3 ) ) ) ) ) ) ) ).

% finite_has_maximal
tff(fact_755_distrib__inf__le,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Z2))),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2))) ) ).

% distrib_inf_le
tff(fact_756_distrib__sup__le,axiom,
    ! [C: $tType] :
      ( lattice(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),Z2))),aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Z2))) ) ).

% distrib_sup_le
tff(fact_757_disjoint__mono,axiom,
    ! [C: $tType,A3: set(C),A10: set(C),B2: set(C),B8: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A3),A10)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B2),B8)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A10),B8) = bot_bot(set(C)) )
         => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A3),B2) = bot_bot(set(C)) ) ) ) ) ).

% disjoint_mono
tff(fact_758_Un__Int__assoc__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),C4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) )
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),A4) ) ).

% Un_Int_assoc_eq
tff(fact_759_finite__linorder__max__induct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),Pa: fun(set(C),$o)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,Pa,bot_bot(set(C)))
           => ( ! [B4: C,A8: set(C)] :
                  ( aa(set(C),$o,finite_finite2(C),A8)
                 => ( ! [X3: C] :
                        ( member2(C,X3,A8)
                       => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X3),B4) )
                   => ( aa(set(C),$o,Pa,A8)
                     => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B4),A8)) ) ) )
             => aa(set(C),$o,Pa,A4) ) ) ) ) ).

% finite_linorder_max_induct
tff(fact_760_finite__linorder__min__induct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),Pa: fun(set(C),$o)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,Pa,bot_bot(set(C)))
           => ( ! [B4: C,A8: set(C)] :
                  ( aa(set(C),$o,finite_finite2(C),A8)
                 => ( ! [X3: C] :
                        ( member2(C,X3,A8)
                       => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B4),X3) )
                   => ( aa(set(C),$o,Pa,A8)
                     => aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B4),A8)) ) ) )
             => aa(set(C),$o,Pa,A4) ) ) ) ) ).

% finite_linorder_min_induct
tff(fact_761_ShiftD,axiom,
    ! [C: $tType,Kl: list(C),Kl2: set(list(C)),K: C] :
      ( member2(list(C),Kl,bNF_Greatest_Shift(C,Kl2,K))
     => member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),K),Kl),Kl2) ) ).

% ShiftD
tff(fact_762_Max_OboundedI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [A5: C] :
                  ( member2(C,A5,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A5),X) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798349783984er_Max(C,A4)),X) ) ) ) ) ).

% Max.boundedI
tff(fact_763_Max_OboundedE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798349783984er_Max(C,A4)),X)
             => ! [A11: C] :
                  ( member2(C,A11,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A11),X) ) ) ) ) ) ).

% Max.boundedE
tff(fact_764_eq__Max__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),M2: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ( M2 = lattic643756798349783984er_Max(C,A4) )
            <=> ( member2(C,M2,A4)
                & ! [X4: C] :
                    ( member2(C,X4,A4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),M2) ) ) ) ) ) ) ).

% eq_Max_iff
tff(fact_765_Max__ge__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),lattic643756798349783984er_Max(C,A4))
            <=> ? [X4: C] :
                  ( member2(C,X4,A4)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),X4) ) ) ) ) ) ).

% Max_ge_iff
tff(fact_766_Max__eq__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),M2: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ( lattic643756798349783984er_Max(C,A4) = M2 )
            <=> ( member2(C,M2,A4)
                & ! [X4: C] :
                    ( member2(C,X4,A4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),M2) ) ) ) ) ) ) ).

% Max_eq_iff
tff(fact_767_Min_OboundedI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [A5: C] :
                  ( member2(C,A5,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A5) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),lattic643756798350308766er_Min(C,A4)) ) ) ) ) ).

% Min.boundedI
tff(fact_768_Min_OboundedE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),lattic643756798350308766er_Min(C,A4))
             => ! [A11: C] :
                  ( member2(C,A11,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A11) ) ) ) ) ) ).

% Min.boundedE
tff(fact_769_eq__Min__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),M2: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ( M2 = lattic643756798350308766er_Min(C,A4) )
            <=> ( member2(C,M2,A4)
                & ! [X4: C] :
                    ( member2(C,X4,A4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),M2),X4) ) ) ) ) ) ) ).

% eq_Min_iff
tff(fact_770_Min__le__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic643756798350308766er_Min(C,A4)),X)
            <=> ? [X4: C] :
                  ( member2(C,X4,A4)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),X) ) ) ) ) ) ).

% Min_le_iff
tff(fact_771_Min__eq__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),M2: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ( lattic643756798350308766er_Min(C,A4) = M2 )
            <=> ( member2(C,M2,A4)
                & ! [X4: C] :
                    ( member2(C,X4,A4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),M2),X4) ) ) ) ) ) ) ).

% Min_eq_iff
tff(fact_772_Sup__fin_Obounded__iff,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic5882676163264333800up_fin(C,A4)),X)
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),X) ) ) ) ) ) ).

% Sup_fin.bounded_iff
tff(fact_773_Inf__fin_Obounded__iff,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4))
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),X4) ) ) ) ) ) ).

% Inf_fin.bounded_iff
tff(fact_774_Sup__fin_OboundedI,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [A5: C] :
                  ( member2(C,A5,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A5),X) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic5882676163264333800up_fin(C,A4)),X) ) ) ) ) ).

% Sup_fin.boundedI
tff(fact_775_Sup__fin_OboundedE,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),lattic5882676163264333800up_fin(C,A4)),X)
             => ! [A11: C] :
                  ( member2(C,A11,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A11),X) ) ) ) ) ) ).

% Sup_fin.boundedE
tff(fact_776_Inf__fin_OboundedI,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [A5: C] :
                  ( member2(C,A5,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A5) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) ) ) ) ) ).

% Inf_fin.boundedI
tff(fact_777_Inf__fin_OboundedE,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4))
             => ! [A11: C] :
                  ( member2(C,A11,A4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A11) ) ) ) ) ) ).

% Inf_fin.boundedE
tff(fact_778_arg__min__least,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [S: set(C),Y: C,F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ( member2(C,Y,S)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,lattic7623131987881927897min_on(C,D,F,S))),aa(C,D,F,Y)) ) ) ) ) ).

% arg_min_least
tff(fact_779_Inf__fin_Oinsert__not__elem,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ~ member2(C,X,A4)
           => ( ( A4 != bot_bot(set(C)) )
             => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) ) ) ) ) ) ).

% Inf_fin.insert_not_elem
tff(fact_780_Inf__fin_Oclosed,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C,Y2: C] : member2(C,aa(C,C,aa(C,fun(C,C),inf_inf(C),X2),Y2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C)))))
             => member2(C,aa(set(C),C,lattic7752659483105999362nf_fin(C),A4),A4) ) ) ) ) ).

% Inf_fin.closed
tff(fact_781_mergesort__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ( mergesort(C) = mergesort_by_rel(C,ord_less_eq(C)) ) ) ).

% mergesort_def
tff(fact_782_the__elem__eq,axiom,
    ! [C: $tType,X: C] : the_elem(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ).

% the_elem_eq
tff(fact_783_is__singletonI,axiom,
    ! [C: $tType,X: C] : is_singleton(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ).

% is_singletonI
tff(fact_784_subset__emptyI,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ! [X2: C] : ~ member2(C,X2,A4)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),bot_bot(set(C))) ) ).

% subset_emptyI
tff(fact_785_sorted__list__of__set__nonempty,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),lattic643756798350308766er_Min(C,A4)),aa(set(C),list(C),linord4507533701916653071of_set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),lattic643756798350308766er_Min(C,A4)),bot_bot(set(C)))))) ) ) ) ) ).

% sorted_list_of_set_nonempty
tff(fact_786_Sup__fin_Oinsert__remove,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( lattic5882676163264333800up_fin(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),sup_sup(C),X),lattic5882676163264333800up_fin(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ).

% Sup_fin.insert_remove
tff(fact_787_Sup__fin_Oremove,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( lattic5882676163264333800up_fin(C,A4) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),sup_sup(C),X),lattic5882676163264333800up_fin(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ) ).

% Sup_fin.remove
tff(fact_788_Inf__fin_Oremove,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),A4) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ) ).

% Inf_fin.remove
tff(fact_789_Inf__fin_Oinsert__remove,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ).

% Inf_fin.insert_remove
tff(fact_790_is__singletonE,axiom,
    ! [C: $tType,A4: set(C)] :
      ( is_singleton(C,A4)
     => ~ ! [X2: C] : A4 != aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C))) ) ).

% is_singletonE
tff(fact_791_minus__apply,axiom,
    ! [C: $tType,D: $tType] :
      ( minus(C)
     => ! [A4: fun(D,C),B3: fun(D,C),X: D] : aa(D,C,minus_minus(fun(D,C),A4,B3),X) = minus_minus(C,aa(D,C,A4,X),aa(D,C,B3,X)) ) ).

% minus_apply
tff(fact_792_Diff__idemp,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : minus_minus(set(C),minus_minus(set(C),A4,B3),B3) = minus_minus(set(C),A4,B3) ).

% Diff_idemp
tff(fact_793_Diff__iff,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,minus_minus(set(C),A4,B3))
    <=> ( member2(C,C3,A4)
        & ~ member2(C,C3,B3) ) ) ).

% Diff_iff
tff(fact_794_DiffI,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,A4)
     => ( ~ member2(C,C3,B3)
       => member2(C,C3,minus_minus(set(C),A4,B3)) ) ) ).

% DiffI
tff(fact_795_Diff__empty,axiom,
    ! [C: $tType,A4: set(C)] : minus_minus(set(C),A4,bot_bot(set(C))) = A4 ).

% Diff_empty
tff(fact_796_empty__Diff,axiom,
    ! [C: $tType,A4: set(C)] : minus_minus(set(C),bot_bot(set(C)),A4) = bot_bot(set(C)) ).

% empty_Diff
tff(fact_797_Diff__cancel,axiom,
    ! [C: $tType,A4: set(C)] : minus_minus(set(C),A4,A4) = bot_bot(set(C)) ).

% Diff_cancel
tff(fact_798_insert__Diff1,axiom,
    ! [C: $tType,X: C,B3: set(C),A4: set(C)] :
      ( member2(C,X,B3)
     => ( minus_minus(set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4),B3) = minus_minus(set(C),A4,B3) ) ) ).

% insert_Diff1
tff(fact_799_Diff__insert0,axiom,
    ! [C: $tType,X: C,A4: set(C),B3: set(C)] :
      ( ~ member2(C,X,A4)
     => ( minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B3)) = minus_minus(set(C),A4,B3) ) ) ).

% Diff_insert0
tff(fact_800_Un__Diff__cancel2,axiom,
    ! [C: $tType,B3: set(C),A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),minus_minus(set(C),B3,A4)),A4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),A4) ).

% Un_Diff_cancel2
tff(fact_801_Un__Diff__cancel,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),minus_minus(set(C),B3,A4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) ).

% Un_Diff_cancel
tff(fact_802_Diff__eq__empty__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( minus_minus(set(C),A4,B3) = bot_bot(set(C)) )
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ).

% Diff_eq_empty_iff
tff(fact_803_insert__Diff__single,axiom,
    ! [C: $tType,A3: C,A4: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4) ).

% insert_Diff_single
tff(fact_804_Diff__disjoint,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),minus_minus(set(C),B3,A4)) = bot_bot(set(C)) ).

% Diff_disjoint
tff(fact_805_less__assn__def,axiom,
    ! [A3: assn,B2: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),ord_less(assn),A3),B2)
    <=> ( aa(assn,$o,aa(assn,fun(assn,$o),ord_less_eq(assn),A3),B2)
        & ( A3 != B2 ) ) ) ).

% less_assn_def
tff(fact_806_less__fun__def,axiom,
    ! [D: $tType,C: $tType] :
      ( ord(D)
     => ! [F: fun(C,D),G: fun(C,D)] :
          ( aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less(fun(C,D)),F),G)
        <=> ( aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less_eq(fun(C,D)),F),G)
            & ~ aa(fun(C,D),$o,aa(fun(C,D),fun(fun(C,D),$o),ord_less_eq(fun(C,D)),G),F) ) ) ) ).

% less_fun_def
tff(fact_807_cancel__ab__semigroup__add__class_Odiff__right__commute,axiom,
    ! [C: $tType] :
      ( cancel2418104881723323429up_add(C)
     => ! [A3: C,C3: C,B2: C] : minus_minus(C,minus_minus(C,A3,C3),B2) = minus_minus(C,minus_minus(C,A3,B2),C3) ) ).

% cancel_ab_semigroup_add_class.diff_right_commute
tff(fact_808_diff__eq__diff__eq,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( ( minus_minus(C,A3,B2) = minus_minus(C,C3,D3) )
         => ( ( A3 = B2 )
          <=> ( C3 = D3 ) ) ) ) ).

% diff_eq_diff_eq
tff(fact_809_fun__diff__def,axiom,
    ! [D: $tType,C: $tType] :
      ( minus(D)
     => ! [A4: fun(C,D),B3: fun(C,D),X3: C] : aa(C,D,minus_minus(fun(C,D),A4,B3),X3) = minus_minus(D,aa(C,D,A4,X3),aa(C,D,B3,X3)) ) ).

% fun_diff_def
tff(fact_810_DiffD2,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,minus_minus(set(C),A4,B3))
     => ~ member2(C,C3,B3) ) ).

% DiffD2
tff(fact_811_DiffD1,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,minus_minus(set(C),A4,B3))
     => member2(C,C3,A4) ) ).

% DiffD1
tff(fact_812_DiffE,axiom,
    ! [C: $tType,C3: C,A4: set(C),B3: set(C)] :
      ( member2(C,C3,minus_minus(set(C),A4,B3))
     => ~ ( member2(C,C3,A4)
         => member2(C,C3,B3) ) ) ).

% DiffE
tff(fact_813_diff__eq__diff__less__eq,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( ( minus_minus(C,A3,B2) = minus_minus(C,C3,D3) )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),D3) ) ) ) ).

% diff_eq_diff_less_eq
tff(fact_814_diff__right__mono,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,A3,C3)),minus_minus(C,B2,C3)) ) ) ).

% diff_right_mono
tff(fact_815_diff__left__mono,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,C3,A3)),minus_minus(C,C3,B2)) ) ) ).

% diff_left_mono
tff(fact_816_diff__mono,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,D3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),D3),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,A3,C3)),minus_minus(C,B2,D3)) ) ) ) ).

% diff_mono
tff(fact_817_diff__strict__right__mono,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,A3,C3)),minus_minus(C,B2,C3)) ) ) ).

% diff_strict_right_mono
tff(fact_818_diff__strict__left__mono,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,C3,A3)),minus_minus(C,C3,B2)) ) ) ).

% diff_strict_left_mono
tff(fact_819_diff__eq__diff__less,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( ( minus_minus(C,A3,B2) = minus_minus(C,C3,D3) )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),D3) ) ) ) ).

% diff_eq_diff_less
tff(fact_820_diff__strict__mono,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,D3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),D3),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,A3,C3)),minus_minus(C,B2,D3)) ) ) ) ).

% diff_strict_mono
tff(fact_821_left__diff__distrib,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,A3,B2)),C3) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% left_diff_distrib
tff(fact_822_right__diff__distrib,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),minus_minus(C,B2,C3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ).

% right_diff_distrib
tff(fact_823_left__diff__distrib_H,axiom,
    ! [C: $tType] :
      ( comm_s4317794764714335236cancel(C)
     => ! [B2: C,C3: C,A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,B2,C3)),A3) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)) ) ).

% left_diff_distrib'
tff(fact_824_right__diff__distrib_H,axiom,
    ! [C: $tType] :
      ( comm_s4317794764714335236cancel(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),minus_minus(C,B2,C3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ).

% right_diff_distrib'
tff(fact_825_double__diff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
       => ( minus_minus(set(C),B3,minus_minus(set(C),C4,A4)) = A4 ) ) ) ).

% double_diff
tff(fact_826_Diff__subset,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),minus_minus(set(C),A4,B3)),A4) ).

% Diff_subset
tff(fact_827_Diff__mono,axiom,
    ! [C: $tType,A4: set(C),C4: set(C),D2: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),D2),B3)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),minus_minus(set(C),A4,B3)),minus_minus(set(C),C4,D2)) ) ) ).

% Diff_mono
tff(fact_828_insert__Diff__if,axiom,
    ! [C: $tType,X: C,A4: set(C),B3: set(C)] :
      minus_minus(set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4),B3) = $ite(member2(C,X,B3),minus_minus(set(C),A4,B3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),minus_minus(set(C),A4,B3))) ).

% insert_Diff_if
tff(fact_829_Int__Diff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : minus_minus(set(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3),C4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),minus_minus(set(C),B3,C4)) ).

% Int_Diff
tff(fact_830_Diff__Int2,axiom,
    ! [C: $tType,A4: set(C),C4: set(C),B3: set(C)] : minus_minus(set(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) = minus_minus(set(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4),B3) ).

% Diff_Int2
tff(fact_831_Diff__Diff__Int,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : minus_minus(set(C),A4,minus_minus(set(C),A4,B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ).

% Diff_Diff_Int
tff(fact_832_Diff__Int__distrib,axiom,
    ! [C: $tType,C4: set(C),A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C4),minus_minus(set(C),A4,B3)) = minus_minus(set(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C4),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C4),B3)) ).

% Diff_Int_distrib
tff(fact_833_Diff__Int__distrib2,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),minus_minus(set(C),A4,B3)),C4) = minus_minus(set(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) ).

% Diff_Int_distrib2
tff(fact_834_set__diff__diff__left,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : minus_minus(set(C),minus_minus(set(C),A4,B3),C4) = minus_minus(set(C),A4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) ).

% set_diff_diff_left
tff(fact_835_Un__Diff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : minus_minus(set(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3),C4) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),minus_minus(set(C),A4,C4)),minus_minus(set(C),B3,C4)) ).

% Un_Diff
tff(fact_836_psubset__imp__ex__mem,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
     => ? [B4: C] : member2(C,B4,minus_minus(set(C),B3,A4)) ) ).

% psubset_imp_ex_mem
tff(fact_837_diff__shunt__var,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( ( minus_minus(C,X,Y) = bot_bot(C) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ).

% diff_shunt_var
tff(fact_838_subset__minus__empty,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( minus_minus(set(C),A4,B3) = bot_bot(set(C)) ) ) ).

% subset_minus_empty
tff(fact_839_Diff__insert__absorb,axiom,
    ! [C: $tType,X: C,A4: set(C)] :
      ( ~ member2(C,X,A4)
     => ( minus_minus(set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = A4 ) ) ).

% Diff_insert_absorb
tff(fact_840_Diff__insert2,axiom,
    ! [C: $tType,A4: set(C),A3: C,B3: set(C)] : minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = minus_minus(set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))),B3) ).

% Diff_insert2
tff(fact_841_insert__Diff,axiom,
    ! [C: $tType,A3: C,A4: set(C)] :
      ( member2(C,A3,A4)
     => ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = A4 ) ) ).

% insert_Diff
tff(fact_842_Diff__insert,axiom,
    ! [C: $tType,A4: set(C),A3: C,B3: set(C)] : minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3)) = minus_minus(set(C),minus_minus(set(C),A4,B3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ).

% Diff_insert
tff(fact_843_insert__minus__eq,axiom,
    ! [C: $tType,X: C,Y: C,A4: set(C)] :
      ( ( X != Y )
     => ( minus_minus(set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C)))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C))))) ) ) ).

% insert_minus_eq
tff(fact_844_set__minus__singleton__eq,axiom,
    ! [C: $tType,X: C,X5: set(C)] :
      ( ~ member2(C,X,X5)
     => ( minus_minus(set(C),X5,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X5 ) ) ).

% set_minus_singleton_eq
tff(fact_845_subset__Diff__insert,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),X: C,C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),minus_minus(set(C),B3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),C4)))
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),minus_minus(set(C),B3,C4))
        & ~ member2(C,X,A4) ) ) ).

% subset_Diff_insert
tff(fact_846_Int__Diff__disjoint,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),minus_minus(set(C),A4,B3)) = bot_bot(set(C)) ).

% Int_Diff_disjoint
tff(fact_847_Diff__triv,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
     => ( minus_minus(set(C),A4,B3) = A4 ) ) ).

% Diff_triv
tff(fact_848_disjoint__alt__simp1,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( minus_minus(set(C),A4,B3) = A4 )
    <=> ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) ) ) ).

% disjoint_alt_simp1
tff(fact_849_disjoint__alt__simp2,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( minus_minus(set(C),A4,B3) != A4 )
    <=> ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) != bot_bot(set(C)) ) ) ).

% disjoint_alt_simp2
tff(fact_850_Diff__subset__conv,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),minus_minus(set(C),A4,B3)),C4)
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) ) ).

% Diff_subset_conv
tff(fact_851_Diff__partition,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),minus_minus(set(C),B3,A4)) = B3 ) ) ).

% Diff_partition
tff(fact_852_Diff__Un,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : minus_minus(set(C),A4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),minus_minus(set(C),A4,B3)),minus_minus(set(C),A4,C4)) ).

% Diff_Un
tff(fact_853_Diff__Int,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] : minus_minus(set(C),A4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),minus_minus(set(C),A4,B3)),minus_minus(set(C),A4,C4)) ).

% Diff_Int
tff(fact_854_Int__Diff__Un,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)),minus_minus(set(C),A4,B3)) = A4 ).

% Int_Diff_Un
tff(fact_855_Un__Diff__Int,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),minus_minus(set(C),A4,B3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = A4 ).

% Un_Diff_Int
tff(fact_856_is__singleton__the__elem,axiom,
    ! [C: $tType,A4: set(C)] :
      ( is_singleton(C,A4)
    <=> ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),the_elem(C,A4)),bot_bot(set(C))) ) ) ).

% is_singleton_the_elem
tff(fact_857_is__singletonI_H,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( ! [X2: C,Y2: C] :
            ( member2(C,X2,A4)
           => ( member2(C,Y2,A4)
             => ( X2 = Y2 ) ) )
       => is_singleton(C,A4) ) ) ).

% is_singletonI'
tff(fact_858_infinite__remove,axiom,
    ! [C: $tType,S: set(C),A3: C] :
      ( ~ aa(set(C),$o,finite_finite2(C),S)
     => ~ aa(set(C),$o,finite_finite2(C),minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) ) ).

% infinite_remove
tff(fact_859_infinite__coinduct,axiom,
    ! [C: $tType,X5: fun(set(C),$o),A4: set(C)] :
      ( aa(set(C),$o,X5,A4)
     => ( ! [A8: set(C)] :
            ( aa(set(C),$o,X5,A8)
           => ? [X3: C] :
                ( member2(C,X3,A8)
                & ( aa(set(C),$o,X5,minus_minus(set(C),A8,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X3),bot_bot(set(C)))))
                  | ~ aa(set(C),$o,finite_finite2(C),minus_minus(set(C),A8,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X3),bot_bot(set(C))))) ) ) )
       => ~ aa(set(C),$o,finite_finite2(C),A4) ) ) ).

% infinite_coinduct
tff(fact_860_finite__empty__induct,axiom,
    ! [C: $tType,A4: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),$o,Pa,A4)
       => ( ! [A5: C,A8: set(C)] :
              ( aa(set(C),$o,finite_finite2(C),A8)
             => ( member2(C,A5,A8)
               => ( aa(set(C),$o,Pa,A8)
                 => aa(set(C),$o,Pa,minus_minus(set(C),A8,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A5),bot_bot(set(C))))) ) ) )
         => aa(set(C),$o,Pa,bot_bot(set(C))) ) ) ) ).

% finite_empty_induct
tff(fact_861_Diff__single__insert,axiom,
    ! [C: $tType,A4: set(C),X: C,B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),B3)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B3)) ) ).

% Diff_single_insert
tff(fact_862_subset__insert__iff,axiom,
    ! [C: $tType,A4: set(C),X: C,B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B3))
    <=> $ite(member2(C,X,A4),aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),B3),aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)) ) ).

% subset_insert_iff
tff(fact_863_remove__subset,axiom,
    ! [C: $tType,X: C,S: set(C)] :
      ( member2(C,X,S)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),S) ) ).

% remove_subset
tff(fact_864_disjoint__alt__simp3,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),minus_minus(set(C),A4,B3)),A4)
    <=> ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) != bot_bot(set(C)) ) ) ).

% disjoint_alt_simp3
tff(fact_865_finite__remove__induct,axiom,
    ! [C: $tType,B3: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),B3)
     => ( aa(set(C),$o,Pa,bot_bot(set(C)))
       => ( ! [A8: set(C)] :
              ( aa(set(C),$o,finite_finite2(C),A8)
             => ( ( A8 != bot_bot(set(C)) )
               => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A8),B3)
                 => ( ! [X3: C] :
                        ( member2(C,X3,A8)
                       => aa(set(C),$o,Pa,minus_minus(set(C),A8,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X3),bot_bot(set(C))))) )
                   => aa(set(C),$o,Pa,A8) ) ) ) )
         => aa(set(C),$o,Pa,B3) ) ) ) ).

% finite_remove_induct
tff(fact_866_remove__induct,axiom,
    ! [C: $tType,Pa: fun(set(C),$o),B3: set(C)] :
      ( aa(set(C),$o,Pa,bot_bot(set(C)))
     => ( ( ~ aa(set(C),$o,finite_finite2(C),B3)
         => aa(set(C),$o,Pa,B3) )
       => ( ! [A8: set(C)] :
              ( aa(set(C),$o,finite_finite2(C),A8)
             => ( ( A8 != bot_bot(set(C)) )
               => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A8),B3)
                 => ( ! [X3: C] :
                        ( member2(C,X3,A8)
                       => aa(set(C),$o,Pa,minus_minus(set(C),A8,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X3),bot_bot(set(C))))) )
                   => aa(set(C),$o,Pa,A8) ) ) ) )
         => aa(set(C),$o,Pa,B3) ) ) ) ).

% remove_induct
tff(fact_867_finite__induct__select,axiom,
    ! [C: $tType,S: set(C),Pa: fun(set(C),$o)] :
      ( aa(set(C),$o,finite_finite2(C),S)
     => ( aa(set(C),$o,Pa,bot_bot(set(C)))
       => ( ! [T3: set(C)] :
              ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),T3),S)
             => ( aa(set(C),$o,Pa,T3)
               => ? [X3: C] :
                    ( member2(C,X3,minus_minus(set(C),S,T3))
                    & aa(set(C),$o,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X3),T3)) ) ) )
         => aa(set(C),$o,Pa,S) ) ) ) ).

% finite_induct_select
tff(fact_868_psubset__insert__iff,axiom,
    ! [C: $tType,A4: set(C),X: C,B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),B3))
    <=> $ite(
          member2(C,X,B3),
          aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3),
          $ite(member2(C,X,A4),aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),B3),aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)) ) ) ).

% psubset_insert_iff
tff(fact_869_is__singleton__def,axiom,
    ! [C: $tType,A4: set(C)] :
      ( is_singleton(C,A4)
    <=> ? [X4: C] : A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),bot_bot(set(C))) ) ).

% is_singleton_def
tff(fact_870_inf__period_I2_J,axiom,
    ! [C: $tType] :
      ( ( comm_ring(C)
        & dvd(C) )
     => ! [Pa: fun(C,$o),D2: C,Q: fun(C,$o)] :
          ( ! [X2: C,K2: C] :
              ( aa(C,$o,Pa,X2)
            <=> aa(C,$o,Pa,minus_minus(C,X2,aa(C,C,aa(C,fun(C,C),times_times(C),K2),D2))) )
         => ( ! [X2: C,K2: C] :
                ( aa(C,$o,Q,X2)
              <=> aa(C,$o,Q,minus_minus(C,X2,aa(C,C,aa(C,fun(C,C),times_times(C),K2),D2))) )
           => ! [X3: C,K3: C] :
                ( ( aa(C,$o,Pa,X3)
                  | aa(C,$o,Q,X3) )
              <=> ( aa(C,$o,Pa,minus_minus(C,X3,aa(C,C,aa(C,fun(C,C),times_times(C),K3),D2)))
                  | aa(C,$o,Q,minus_minus(C,X3,aa(C,C,aa(C,fun(C,C),times_times(C),K3),D2))) ) ) ) ) ) ).

% inf_period(2)
tff(fact_871_inf__period_I1_J,axiom,
    ! [C: $tType] :
      ( ( comm_ring(C)
        & dvd(C) )
     => ! [Pa: fun(C,$o),D2: C,Q: fun(C,$o)] :
          ( ! [X2: C,K2: C] :
              ( aa(C,$o,Pa,X2)
            <=> aa(C,$o,Pa,minus_minus(C,X2,aa(C,C,aa(C,fun(C,C),times_times(C),K2),D2))) )
         => ( ! [X2: C,K2: C] :
                ( aa(C,$o,Q,X2)
              <=> aa(C,$o,Q,minus_minus(C,X2,aa(C,C,aa(C,fun(C,C),times_times(C),K2),D2))) )
           => ! [X3: C,K3: C] :
                ( ( aa(C,$o,Pa,X3)
                  & aa(C,$o,Q,X3) )
              <=> ( aa(C,$o,Pa,minus_minus(C,X3,aa(C,C,aa(C,fun(C,C),times_times(C),K3),D2)))
                  & aa(C,$o,Q,minus_minus(C,X3,aa(C,C,aa(C,fun(C,C),times_times(C),K3),D2))) ) ) ) ) ) ).

% inf_period(1)
tff(fact_872_remove__def,axiom,
    ! [C: $tType,X: C,A4: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),remove(C),X),A4) = minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ).

% remove_def
tff(fact_873_sorted__list__of__set_Osorted__key__list__of__set__remove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),list(C),linord4507533701916653071of_set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) ) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_remove
tff(fact_874_Min_Oremove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( lattic643756798350308766er_Min(C,A4) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),ord_min(C),X),lattic643756798350308766er_Min(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ) ).

% Min.remove
tff(fact_875_Min_Oinsert__remove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( lattic643756798350308766er_Min(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),ord_min(C),X),lattic643756798350308766er_Min(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ).

% Min.insert_remove
tff(fact_876_Max_Oremove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( lattic643756798349783984er_Max(C,A4) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),ord_max(C),X),lattic643756798349783984er_Max(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ) ).

% Max.remove
tff(fact_877_Max_Oinsert__remove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( lattic643756798349783984er_Max(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),ord_max(C),X),lattic643756798349783984er_Max(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ).

% Max.insert_remove
tff(fact_878_Inf__fin_Osemilattice__order__set__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => lattic4895041142388067077er_set(C,inf_inf(C),ord_less_eq(C),ord_less(C)) ) ).

% Inf_fin.semilattice_order_set_axioms
tff(fact_879_Min__insert,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic643756798350308766er_Min(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),ord_min(C),X),lattic643756798350308766er_Min(C,A4)) ) ) ) ) ).

% Min_insert
tff(fact_880_min_Oidem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),A3),A3) = A3 ) ).

% min.idem
tff(fact_881_min_Oleft__idem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) ) ).

% min.left_idem
tff(fact_882_min_Oright__idem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),B2) = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) ) ).

% min.right_idem
tff(fact_883_max_Oidem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),A3),A3) = A3 ) ).

% max.idem
tff(fact_884_max_Oleft__idem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),A3),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) ) ).

% max.left_idem
tff(fact_885_max_Oright__idem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)),B2) = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) ) ).

% max.right_idem
tff(fact_886_member__remove,axiom,
    ! [C: $tType,X: C,Y: C,A4: set(C)] :
      ( member2(C,X,aa(set(C),set(C),aa(C,fun(set(C),set(C)),remove(C),Y),A4))
    <=> ( member2(C,X,A4)
        & ( X != Y ) ) ) ).

% member_remove
tff(fact_887_min_Oabsorb1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = A3 ) ) ) ).

% min.absorb1
tff(fact_888_min_Oabsorb2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = B2 ) ) ) ).

% min.absorb2
tff(fact_889_min_Obounded__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% min.bounded_iff
tff(fact_890_min__arg__le_I2_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [M2: C,N: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),M2),aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N))
        <=> ( aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N) = M2 ) ) ) ).

% min_arg_le(2)
tff(fact_891_min__arg__le_I1_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [N: C,M2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),N),aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N))
        <=> ( aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N) = N ) ) ) ).

% min_arg_le(1)
tff(fact_892_min__eq__arg_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M2: C,N: C] :
          ( ( aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N) = N )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),N),M2) ) ) ).

% min_eq_arg(2)
tff(fact_893_min__eq__arg_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M2: C,N: C] :
          ( ( aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N) = M2 )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),M2),N) ) ) ).

% min_eq_arg(1)
tff(fact_894_max_Oabsorb1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = A3 ) ) ) ).

% max.absorb1
tff(fact_895_max_Oabsorb2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = B2 ) ) ) ).

% max.absorb2
tff(fact_896_max_Obounded__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)),A3)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3) ) ) ) ).

% max.bounded_iff
tff(fact_897_min_Oabsorb3,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = A3 ) ) ) ).

% min.absorb3
tff(fact_898_min_Oabsorb4,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = B2 ) ) ) ).

% min.absorb4
tff(fact_899_min__less__iff__conj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),X)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),Y) ) ) ) ).

% min_less_iff_conj
tff(fact_900_min__simps_I2_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = B2 ) ) ) ).

% min_simps(2)
tff(fact_901_min__simps_I1_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = A3 ) ) ) ).

% min_simps(1)
tff(fact_902_min__less__self__conv_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% min_less_self_conv(2)
tff(fact_903_min__less__self__conv_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ).

% min_less_self_conv(1)
tff(fact_904_min__arg__not__ge_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M2: C,N: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N)),N)
        <=> ( aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N) = N ) ) ) ).

% min_arg_not_ge(2)
tff(fact_905_min__arg__not__ge_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M2: C,N: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N)),M2)
        <=> ( aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N) = M2 ) ) ) ).

% min_arg_not_ge(1)
tff(fact_906_max_Oabsorb3,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = A3 ) ) ) ).

% max.absorb3
tff(fact_907_max_Oabsorb4,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = B2 ) ) ) ).

% max.absorb4
tff(fact_908_max__less__iff__conj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y)),Z2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Z2)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),Z2) ) ) ) ).

% max_less_iff_conj
tff(fact_909_min__bot2,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),X),bot_bot(C)) = bot_bot(C) ) ).

% min_bot2
tff(fact_910_min__bot,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),bot_bot(C)),X) = bot_bot(C) ) ).

% min_bot
tff(fact_911_max__bot2,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),X),bot_bot(C)) = X ) ).

% max_bot2
tff(fact_912_max__bot,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),bot_bot(C)),X) = X ) ).

% max_bot
tff(fact_913_max__min__same_I4_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Y: C,X: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),Y),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)) = Y ) ).

% max_min_same(4)
tff(fact_914_max__min__same_I3_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)),Y) = Y ) ).

% max_min_same(3)
tff(fact_915_max__min__same_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)),X) = X ) ).

% max_min_same(2)
tff(fact_916_max__min__same_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),X),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)) = X ) ).

% max_min_same(1)
tff(fact_917_Max__insert,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic643756798349783984er_Max(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),ord_max(C),X),lattic643756798349783984er_Max(C,A4)) ) ) ) ) ).

% Max_insert
tff(fact_918_max_Oassoc,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)) ) ).

% max.assoc
tff(fact_919_min_Oassoc,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3)) ) ).

% min.assoc
tff(fact_920_max_Ocommute,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = aa(C,C,aa(C,fun(C,C),ord_max(C),B2),A3) ) ).

% max.commute
tff(fact_921_min_Ocommute,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = aa(C,C,aa(C,fun(C,C),ord_min(C),B2),A3) ) ).

% min.commute
tff(fact_922_max_Oleft__commute,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),B2),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3)) = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)) ) ).

% max.left_commute
tff(fact_923_max__min__distrib1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3)),A3) = aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),A3)),aa(C,C,aa(C,fun(C,C),ord_max(C),C3),A3)) ) ).

% max_min_distrib1
tff(fact_924_max__min__distrib2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3)) ) ).

% max_min_distrib2
tff(fact_925_min_Oleft__commute,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),B2),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),C3)) = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3)) ) ).

% min.left_commute
tff(fact_926_min__max__distrib1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)),A3) = aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),A3)),aa(C,C,aa(C,fun(C,C),ord_min(C),C3),A3)) ) ).

% min_max_distrib1
tff(fact_927_min__max__distrib2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),A3),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),C3)) ) ).

% min_max_distrib2
tff(fact_928_remove1__commute,axiom,
    ! [C: $tType,X: C,Y: C,Zs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),Y),Zs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),Y),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Zs)) ).

% remove1_commute
tff(fact_929_max_Omono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [C3: C,A3: C,D3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),D3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_max(C),C3),D3)),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ) ) ).

% max.mono
tff(fact_930_max_OorderE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( A3 = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) ) ) ) ).

% max.orderE
tff(fact_931_max_OorderI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% max.orderI
tff(fact_932_max_OboundedE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)),A3)
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3) ) ) ) ).

% max.boundedE
tff(fact_933_max_OboundedI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)),A3) ) ) ) ).

% max.boundedI
tff(fact_934_max_Oorder__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( A3 = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) ) ) ) ).

% max.order_iff
tff(fact_935_max_Ocobounded1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ).

% max.cobounded1
tff(fact_936_max_Ocobounded2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ).

% max.cobounded2
tff(fact_937_le__max__iff__disj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),X)
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),Y) ) ) ) ).

% le_max_iff_disj
tff(fact_938_max_Oabsorb__iff1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = A3 ) ) ) ).

% max.absorb_iff1
tff(fact_939_max_Oabsorb__iff2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = B2 ) ) ) ).

% max.absorb_iff2
tff(fact_940_max_OcoboundedI1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ) ).

% max.coboundedI1
tff(fact_941_max_OcoboundedI2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ) ).

% max.coboundedI2
tff(fact_942_max__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C] :
          aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2),B2,A3) ) ).

% max_def
tff(fact_943_max__absorb1,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ( aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y) = X ) ) ) ).

% max_absorb1
tff(fact_944_max__absorb2,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y) = Y ) ) ) ).

% max_absorb2
tff(fact_945_less__max__iff__disj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),X)
            | aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),Y) ) ) ) ).

% less_max_iff_disj
tff(fact_946_max_Ostrict__boundedE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_max(C),B2),C3)),A3)
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3) ) ) ) ).

% max.strict_boundedE
tff(fact_947_max_Ostrict__order__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
        <=> ( ( A3 = aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2) )
            & ( A3 != B2 ) ) ) ) ).

% max.strict_order_iff
tff(fact_948_max_Ostrict__coboundedI1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ) ).

% max.strict_coboundedI1
tff(fact_949_max_Ostrict__coboundedI2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ) ).

% max.strict_coboundedI2
tff(fact_950_min_Omono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),aa(C,C,aa(C,fun(C,C),ord_min(C),C3),D3)) ) ) ) ).

% min.mono
tff(fact_951_min_OorderE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( A3 = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) ) ) ) ).

% min.orderE
tff(fact_952_min_OorderI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% min.orderI
tff(fact_953_min_OboundedE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3))
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3) ) ) ) ).

% min.boundedE
tff(fact_954_min_OboundedI,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3)) ) ) ) ).

% min.boundedI
tff(fact_955_min_Oorder__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( A3 = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) ) ) ) ).

% min.order_iff
tff(fact_956_min_Ocobounded1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),A3) ) ).

% min.cobounded1
tff(fact_957_min_Ocobounded2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),B2) ) ).

% min.cobounded2
tff(fact_958_min_Oabsorb__iff1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = A3 ) ) ) ).

% min.absorb_iff1
tff(fact_959_min_Oabsorb__iff2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
        <=> ( aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = B2 ) ) ) ).

% min.absorb_iff2
tff(fact_960_min_OcoboundedI1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),C3) ) ) ).

% min.coboundedI1
tff(fact_961_min_OcoboundedI2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),C3) ) ) ).

% min.coboundedI2
tff(fact_962_min__le__iff__disj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)),Z2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Z2)
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),Z2) ) ) ) ).

% min_le_iff_disj
tff(fact_963_min__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C] :
          aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2),A3,B2) ) ).

% min_def
tff(fact_964_min__absorb1,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y) = X ) ) ) ).

% min_absorb1
tff(fact_965_min__absorb2,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X)
         => ( aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y) = Y ) ) ) ).

% min_absorb2
tff(fact_966_min__less__iff__disj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)),Z2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Z2)
            | aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),Z2) ) ) ) ).

% min_less_iff_disj
tff(fact_967_min_Ostrict__boundedE,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),C3))
         => ~ ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3) ) ) ) ).

% min.strict_boundedE
tff(fact_968_min_Ostrict__order__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> ( ( A3 = aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2) )
            & ( A3 != B2 ) ) ) ) ).

% min.strict_order_iff
tff(fact_969_min_Ostrict__coboundedI1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),C3) ) ) ).

% min.strict_coboundedI1
tff(fact_970_min_Ostrict__coboundedI2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)),C3) ) ) ).

% min.strict_coboundedI2
tff(fact_971_max__diff__distrib__left,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [X: C,Y: C,Z2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y),Z2) = aa(C,C,aa(C,fun(C,C),ord_max(C),minus_minus(C,X,Z2)),minus_minus(C,Y,Z2)) ) ).

% max_diff_distrib_left
tff(fact_972_min__diff__distrib__left,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [X: C,Y: C,Z2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y),Z2) = aa(C,C,aa(C,fun(C,C),ord_min(C),minus_minus(C,X,Z2)),minus_minus(C,Y,Z2)) ) ).

% min_diff_distrib_left
tff(fact_973_sup__max,axiom,
    ! [C: $tType] :
      ( ( semilattice_sup(C)
        & linorder(C) )
     => ( sup_sup(C) = ord_max(C) ) ) ).

% sup_max
tff(fact_974_inf__min,axiom,
    ! [C: $tType] :
      ( ( semilattice_inf(C)
        & linorder(C) )
     => ( inf_inf(C) = ord_min(C) ) ) ).

% inf_min
tff(fact_975_remove1_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Y: C,Xs: list(C)] :
      aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)) = $ite(X = Y,Xs,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs))) ).

% remove1.simps(2)
tff(fact_976_remove1_Osimps_I1_J,axiom,
    ! [C: $tType,X: C] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),nil(C)) = nil(C) ).

% remove1.simps(1)
tff(fact_977_Max_Osubset,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( B3 != bot_bot(set(C)) )
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
             => ( aa(C,C,aa(C,fun(C,C),ord_max(C),lattic643756798349783984er_Max(C,B3)),lattic643756798349783984er_Max(C,A4)) = lattic643756798349783984er_Max(C,A4) ) ) ) ) ) ).

% Max.subset
tff(fact_978_Max_Oclosed,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C,Y2: C] : member2(C,aa(C,C,aa(C,fun(C,C),ord_max(C),X2),Y2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C)))))
             => member2(C,lattic643756798349783984er_Max(C,A4),A4) ) ) ) ) ).

% Max.closed
tff(fact_979_Max_Oinsert__not__elem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ~ member2(C,X,A4)
           => ( ( A4 != bot_bot(set(C)) )
             => ( lattic643756798349783984er_Max(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),ord_max(C),X),lattic643756798349783984er_Max(C,A4)) ) ) ) ) ) ).

% Max.insert_not_elem
tff(fact_980_Max_Ounion,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( B3 != bot_bot(set(C)) )
               => ( lattic643756798349783984er_Max(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),ord_max(C),lattic643756798349783984er_Max(C,A4)),lattic643756798349783984er_Max(C,B3)) ) ) ) ) ) ) ).

% Max.union
tff(fact_981_Min_Osubset,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( B3 != bot_bot(set(C)) )
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
             => ( aa(C,C,aa(C,fun(C,C),ord_min(C),lattic643756798350308766er_Min(C,B3)),lattic643756798350308766er_Min(C,A4)) = lattic643756798350308766er_Min(C,A4) ) ) ) ) ) ).

% Min.subset
tff(fact_982_Min_Oclosed,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C,Y2: C] : member2(C,aa(C,C,aa(C,fun(C,C),ord_min(C),X2),Y2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C)))))
             => member2(C,lattic643756798350308766er_Min(C,A4),A4) ) ) ) ) ).

% Min.closed
tff(fact_983_Min_Oinsert__not__elem,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ~ member2(C,X,A4)
           => ( ( A4 != bot_bot(set(C)) )
             => ( lattic643756798350308766er_Min(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),ord_min(C),X),lattic643756798350308766er_Min(C,A4)) ) ) ) ) ) ).

% Min.insert_not_elem
tff(fact_984_Min_Ounion,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( B3 != bot_bot(set(C)) )
               => ( lattic643756798350308766er_Min(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),ord_min(C),lattic643756798350308766er_Min(C,A4)),lattic643756798350308766er_Min(C,B3)) ) ) ) ) ) ) ).

% Min.union
tff(fact_985_complete__linorder__inf__min,axiom,
    ! [C: $tType] :
      ( comple5582772986160207858norder(C)
     => ( inf_inf(C) = ord_min(C) ) ) ).

% complete_linorder_inf_min
tff(fact_986_semilattice__order__set_Osubset__imp,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A4: set(C),B3: set(C)] :
      ( lattic4895041142388067077er_set(C,F,Less_eq,Less)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
       => ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => aa(C,$o,aa(C,fun(C,$o),Less_eq,aa(set(C),C,lattic1715443433743089157tice_F(C,F),B3)),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4)) ) ) ) ) ).

% semilattice_order_set.subset_imp
tff(fact_987_remove__code_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),remove(C),X),coset(C,Xs)) = coset(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs)) ).

% remove_code(2)
tff(fact_988_mult__le__cancel__left1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),one_one(C)) ) ) ) ) ).

% mult_le_cancel_left1
tff(fact_989_mult__le__cancel__left2,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),C3)
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C)) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),A3) ) ) ) ) ).

% mult_le_cancel_left2
tff(fact_990_mult__le__cancel__right1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),one_one(C)) ) ) ) ) ).

% mult_le_cancel_right1
tff(fact_991_mult__le__cancel__right2,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),C3)
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C)) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),A3) ) ) ) ) ).

% mult_le_cancel_right2
tff(fact_992_mult__less__cancel__left1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),one_one(C)) ) ) ) ) ).

% mult_less_cancel_left1
tff(fact_993_mult__less__cancel__left2,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),C3)
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C)) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3) ) ) ) ) ).

% mult_less_cancel_left2
tff(fact_994_le__zero__eq,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [N: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),N),zero_zero(C))
        <=> ( N = zero_zero(C) ) ) ) ).

% le_zero_eq
tff(fact_995_not__gr__zero,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [N: C] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),N)
        <=> ( N = zero_zero(C) ) ) ) ).

% not_gr_zero
tff(fact_996_mult__zero__left,axiom,
    ! [C: $tType] :
      ( mult_zero(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),zero_zero(C)),A3) = zero_zero(C) ) ).

% mult_zero_left
tff(fact_997_mult__zero__right,axiom,
    ! [C: $tType] :
      ( mult_zero(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),zero_zero(C)) = zero_zero(C) ) ).

% mult_zero_right
tff(fact_998_mult__eq__0__iff,axiom,
    ! [C: $tType] :
      ( semiri3467727345109120633visors(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = zero_zero(C) )
        <=> ( ( A3 = zero_zero(C) )
            | ( B2 = zero_zero(C) ) ) ) ) ).

% mult_eq_0_iff
tff(fact_999_mult__cancel__left,axiom,
    ! [C: $tType] :
      ( semiri6575147826004484403cancel(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2) )
        <=> ( ( C3 = zero_zero(C) )
            | ( A3 = B2 ) ) ) ) ).

% mult_cancel_left
tff(fact_1000_mult__cancel__right,axiom,
    ! [C: $tType] :
      ( semiri6575147826004484403cancel(C)
     => ! [A3: C,C3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3) )
        <=> ( ( C3 = zero_zero(C) )
            | ( A3 = B2 ) ) ) ) ).

% mult_cancel_right
tff(fact_1001_cancel__comm__monoid__add__class_Odiff__cancel,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [A3: C] : minus_minus(C,A3,A3) = zero_zero(C) ) ).

% cancel_comm_monoid_add_class.diff_cancel
tff(fact_1002_diff__zero,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [A3: C] : minus_minus(C,A3,zero_zero(C)) = A3 ) ).

% diff_zero
tff(fact_1003_zero__diff,axiom,
    ! [C: $tType] :
      ( comm_monoid_diff(C)
     => ! [A3: C] : minus_minus(C,zero_zero(C),A3) = zero_zero(C) ) ).

% zero_diff
tff(fact_1004_diff__0__right,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : minus_minus(C,A3,zero_zero(C)) = A3 ) ).

% diff_0_right
tff(fact_1005_diff__self,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : minus_minus(C,A3,A3) = zero_zero(C) ) ).

% diff_self
tff(fact_1006_diff__ge__0__iff__ge,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),minus_minus(C,A3,B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% diff_ge_0_iff_ge
tff(fact_1007_zero__comp__diff__simps_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),minus_minus(C,A3,B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% zero_comp_diff_simps(1)
tff(fact_1008_diff__gt__0__iff__gt,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),minus_minus(C,A3,B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ).

% diff_gt_0_iff_gt
tff(fact_1009_zero__comp__diff__simps_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),minus_minus(C,A3,B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ).

% zero_comp_diff_simps(2)
tff(fact_1010_mult__cancel__right2,axiom,
    ! [C: $tType] :
      ( ring_15535105094025558882visors(C)
     => ! [A3: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = C3 )
        <=> ( ( C3 = zero_zero(C) )
            | ( A3 = one_one(C) ) ) ) ) ).

% mult_cancel_right2
tff(fact_1011_mult__cancel__right1,axiom,
    ! [C: $tType] :
      ( ring_15535105094025558882visors(C)
     => ! [C3: C,B2: C] :
          ( ( C3 = aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3) )
        <=> ( ( C3 = zero_zero(C) )
            | ( B2 = one_one(C) ) ) ) ) ).

% mult_cancel_right1
tff(fact_1012_mult__cancel__left2,axiom,
    ! [C: $tType] :
      ( ring_15535105094025558882visors(C)
     => ! [C3: C,A3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3) = C3 )
        <=> ( ( C3 = zero_zero(C) )
            | ( A3 = one_one(C) ) ) ) ) ).

% mult_cancel_left2
tff(fact_1013_mult__cancel__left1,axiom,
    ! [C: $tType] :
      ( ring_15535105094025558882visors(C)
     => ! [C3: C,B2: C] :
          ( ( C3 = aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2) )
        <=> ( ( C3 = zero_zero(C) )
            | ( B2 = one_one(C) ) ) ) ) ).

% mult_cancel_left1
tff(fact_1014_diff__numeral__special_I9_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( minus_minus(C,one_one(C),one_one(C)) = zero_zero(C) ) ) ).

% diff_numeral_special(9)
tff(fact_1015_min__0__1_I1_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ( aa(C,C,aa(C,fun(C,C),ord_min(C),zero_zero(C)),one_one(C)) = zero_zero(C) ) ) ).

% min_0_1(1)
tff(fact_1016_min__0__1_I2_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ( aa(C,C,aa(C,fun(C,C),ord_min(C),one_one(C)),zero_zero(C)) = zero_zero(C) ) ) ).

% min_0_1(2)
tff(fact_1017_max__0__1_I1_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ( aa(C,C,aa(C,fun(C,C),ord_max(C),zero_zero(C)),one_one(C)) = one_one(C) ) ) ).

% max_0_1(1)
tff(fact_1018_max__0__1_I2_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ( aa(C,C,aa(C,fun(C,C),ord_max(C),one_one(C)),zero_zero(C)) = one_one(C) ) ) ).

% max_0_1(2)
tff(fact_1019_zero__reorient,axiom,
    ! [C: $tType] :
      ( zero(C)
     => ! [X: C] :
          ( ( zero_zero(C) = X )
        <=> ( X = zero_zero(C) ) ) ) ).

% zero_reorient
tff(fact_1020_zero__le,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X) ) ).

% zero_le
tff(fact_1021_zero__less__iff__neq__zero,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [N: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),N)
        <=> ( N != zero_zero(C) ) ) ) ).

% zero_less_iff_neq_zero
tff(fact_1022_gr__implies__not__zero,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [M2: C,N: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),M2),N)
         => ( N != zero_zero(C) ) ) ) ).

% gr_implies_not_zero
tff(fact_1023_not__less__zero,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [N: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),N),zero_zero(C)) ) ).

% not_less_zero
tff(fact_1024_gr__zeroI,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [N: C] :
          ( ( N != zero_zero(C) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),N) ) ) ).

% gr_zeroI
tff(fact_1025_mult__not__zero,axiom,
    ! [C: $tType] :
      ( mult_zero(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) != zero_zero(C) )
         => ( ( A3 != zero_zero(C) )
            & ( B2 != zero_zero(C) ) ) ) ) ).

% mult_not_zero
tff(fact_1026_divisors__zero,axiom,
    ! [C: $tType] :
      ( semiri3467727345109120633visors(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = zero_zero(C) )
         => ( ( A3 = zero_zero(C) )
            | ( B2 = zero_zero(C) ) ) ) ) ).

% divisors_zero
tff(fact_1027_no__zero__divisors,axiom,
    ! [C: $tType] :
      ( semiri3467727345109120633visors(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) != zero_zero(C) ) ) ) ) ).

% no_zero_divisors
tff(fact_1028_mult__left__cancel,axiom,
    ! [C: $tType] :
      ( semiri6575147826004484403cancel(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2) )
          <=> ( A3 = B2 ) ) ) ) ).

% mult_left_cancel
tff(fact_1029_mult__right__cancel,axiom,
    ! [C: $tType] :
      ( semiri6575147826004484403cancel(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3) )
          <=> ( A3 = B2 ) ) ) ) ).

% mult_right_cancel
tff(fact_1030_zero__neq__one,axiom,
    ! [C: $tType] :
      ( zero_neq_one(C)
     => ( zero_zero(C) != one_one(C) ) ) ).

% zero_neq_one
tff(fact_1031_eq__iff__diff__eq__0,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = B2 )
        <=> ( minus_minus(C,A3,B2) = zero_zero(C) ) ) ) ).

% eq_iff_diff_eq_0
tff(fact_1032_mult__mono,axiom,
    ! [C: $tType] :
      ( ordered_semiring(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),D3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ) ).

% mult_mono
tff(fact_1033_mult__mono_H,axiom,
    ! [C: $tType] :
      ( ordered_semiring(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),D3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ) ).

% mult_mono'
tff(fact_1034_zero__le__square,axiom,
    ! [C: $tType] :
      ( linordered_ring(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),A3)) ) ).

% zero_le_square
tff(fact_1035_split__mult__pos__le,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [A3: C,B2: C] :
          ( ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C)) ) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ) ).

% split_mult_pos_le
tff(fact_1036_mult__left__mono__neg,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ).

% mult_left_mono_neg
tff(fact_1037_mult__nonpos__nonpos,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ) ) ).

% mult_nonpos_nonpos
tff(fact_1038_mult__left__mono,axiom,
    ! [C: $tType] :
      ( ordered_semiring(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ).

% mult_left_mono
tff(fact_1039_mult__right__mono__neg,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ) ).

% mult_right_mono_neg
tff(fact_1040_mult__right__mono,axiom,
    ! [C: $tType] :
      ( ordered_semiring(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ) ).

% mult_right_mono
tff(fact_1041_mult__le__0__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C)) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2) ) ) ) ) ).

% mult_le_0_iff
tff(fact_1042_split__mult__neg__le,axiom,
    ! [C: $tType] :
      ( ordered_semiring_0(C)
     => ! [A3: C,B2: C] :
          ( ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C)) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2) ) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C)) ) ) ).

% split_mult_neg_le
tff(fact_1043_mult__nonneg__nonneg,axiom,
    ! [C: $tType] :
      ( ordered_semiring_0(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ) ) ).

% mult_nonneg_nonneg
tff(fact_1044_mult__nonneg__nonpos,axiom,
    ! [C: $tType] :
      ( ordered_semiring_0(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C)) ) ) ) ).

% mult_nonneg_nonpos
tff(fact_1045_mult__nonpos__nonneg,axiom,
    ! [C: $tType] :
      ( ordered_semiring_0(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C)) ) ) ) ).

% mult_nonpos_nonneg
tff(fact_1046_mult__nonneg__nonpos2,axiom,
    ! [C: $tType] :
      ( ordered_semiring_0(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)),zero_zero(C)) ) ) ) ).

% mult_nonneg_nonpos2
tff(fact_1047_zero__le__mult__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C)) ) ) ) ) ).

% zero_le_mult_iff
tff(fact_1048_ordered__comm__semiring__class_Ocomm__mult__left__mono,axiom,
    ! [C: $tType] :
      ( ordere2520102378445227354miring(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ).

% ordered_comm_semiring_class.comm_mult_left_mono
tff(fact_1049_zero__less__one__class_Ozero__le__one,axiom,
    ! [C: $tType] :
      ( zero_less_one(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),one_one(C)) ) ).

% zero_less_one_class.zero_le_one
tff(fact_1050_linordered__nonzero__semiring__class_Ozero__le__one,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),one_one(C)) ) ).

% linordered_nonzero_semiring_class.zero_le_one
tff(fact_1051_not__one__le__zero,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),zero_zero(C)) ) ).

% not_one_le_zero
tff(fact_1052_le__iff__diff__le__0,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,A3,B2)),zero_zero(C)) ) ) ).

% le_iff_diff_le_0
tff(fact_1053_mult__neg__neg,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ) ) ).

% mult_neg_neg
tff(fact_1054_not__square__less__zero,axiom,
    ! [C: $tType] :
      ( linordered_ring(C)
     => ! [A3: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),A3)),zero_zero(C)) ) ).

% not_square_less_zero
tff(fact_1055_mult__less__0__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C)) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2) ) ) ) ) ).

% mult_less_0_iff
tff(fact_1056_mult__neg__pos,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C)) ) ) ) ).

% mult_neg_pos
tff(fact_1057_mult__pos__neg,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C)) ) ) ) ).

% mult_pos_neg
tff(fact_1058_mult__pos__pos,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ) ) ).

% mult_pos_pos
tff(fact_1059_mult__pos__neg2,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)),zero_zero(C)) ) ) ) ).

% mult_pos_neg2
tff(fact_1060_zero__less__mult__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C)) ) ) ) ) ).

% zero_less_mult_iff
tff(fact_1061_zero__less__mult__pos,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2) ) ) ) ).

% zero_less_mult_pos
tff(fact_1062_zero__less__mult__pos2,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2) ) ) ) ).

% zero_less_mult_pos2
tff(fact_1063_mult__less__cancel__left__neg,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ).

% mult_less_cancel_left_neg
tff(fact_1064_mult__less__cancel__left__pos,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% mult_less_cancel_left_pos
tff(fact_1065_mult__strict__left__mono__neg,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ).

% mult_strict_left_mono_neg
tff(fact_1066_mult__strict__left__mono,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ).

% mult_strict_left_mono
tff(fact_1067_mult__less__cancel__left__disj,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ) ).

% mult_less_cancel_left_disj
tff(fact_1068_mult__strict__right__mono__neg,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ) ).

% mult_strict_right_mono_neg
tff(fact_1069_mult__strict__right__mono,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ) ).

% mult_strict_right_mono
tff(fact_1070_mult__less__cancel__right__disj,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ) ).

% mult_less_cancel_right_disj
tff(fact_1071_linordered__comm__semiring__strict__class_Ocomm__mult__strict__left__mono,axiom,
    ! [C: $tType] :
      ( linord2810124833399127020strict(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ).

% linordered_comm_semiring_strict_class.comm_mult_strict_left_mono
tff(fact_1072_less__numeral__extra_I1_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),one_one(C)) ) ).

% less_numeral_extra(1)
tff(fact_1073_zero__less__one,axiom,
    ! [C: $tType] :
      ( zero_less_one(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),one_one(C)) ) ).

% zero_less_one
tff(fact_1074_not__one__less__zero,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),zero_zero(C)) ) ).

% not_one_less_zero
tff(fact_1075_less__iff__diff__less__0,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,A3,B2)),zero_zero(C)) ) ) ).

% less_iff_diff_less_0
tff(fact_1076_Inf__fin__def,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ( lattic7752659483105999362nf_fin(C) = lattic1715443433743089157tice_F(C,inf_inf(C)) ) ) ).

% Inf_fin_def
tff(fact_1077_mult__le__cancel__left,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ) ).

% mult_le_cancel_left
tff(fact_1078_mult__le__cancel__right,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ) ).

% mult_le_cancel_right
tff(fact_1079_mult__left__less__imp__less,axiom,
    ! [C: $tType] :
      ( linordered_semiring(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% mult_left_less_imp_less
tff(fact_1080_mult__strict__mono,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),D3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ) ).

% mult_strict_mono
tff(fact_1081_mult__less__cancel__left,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ) ).

% mult_less_cancel_left
tff(fact_1082_mult__right__less__imp__less,axiom,
    ! [C: $tType] :
      ( linordered_semiring(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% mult_right_less_imp_less
tff(fact_1083_mult__strict__mono_H,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),D3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ) ).

% mult_strict_mono'
tff(fact_1084_mult__less__cancel__right,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ) ).

% mult_less_cancel_right
tff(fact_1085_mult__le__cancel__left__neg,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ).

% mult_le_cancel_left_neg
tff(fact_1086_mult__le__cancel__left__pos,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% mult_le_cancel_left_pos
tff(fact_1087_mult__left__le__imp__le,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% mult_left_le_imp_le
tff(fact_1088_mult__right__le__imp__le,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% mult_right_le_imp_le
tff(fact_1089_mult__le__less__imp__less,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),D3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ) ).

% mult_le_less_imp_less
tff(fact_1090_mult__less__le__imp__less,axiom,
    ! [C: $tType] :
      ( linord8928482502909563296strict(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),D3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ) ).

% mult_less_le_imp_less
tff(fact_1091_mult__left__le,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),one_one(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),A3) ) ) ) ).

% mult_left_le
tff(fact_1092_mult__le__one,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),one_one(C)) ) ) ) ) ).

% mult_le_one
tff(fact_1093_mult__right__le__one__le,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),Y)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),Y)),X) ) ) ) ) ).

% mult_right_le_one_le
tff(fact_1094_mult__left__le__one__le,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),Y)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),Y),X)),X) ) ) ) ) ).

% mult_left_le_one_le
tff(fact_1095_semilattice__order__set_OboundedE,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A4: set(C),X: C] :
      ( lattic4895041142388067077er_set(C,F,Less_eq,Less)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4))
           => ! [A11: C] :
                ( member2(C,A11,A4)
               => aa(C,$o,aa(C,fun(C,$o),Less_eq,X),A11) ) ) ) ) ) ).

% semilattice_order_set.boundedE
tff(fact_1096_semilattice__order__set_OboundedI,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A4: set(C),X: C] :
      ( lattic4895041142388067077er_set(C,F,Less_eq,Less)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( ! [A5: C] :
                ( member2(C,A5,A4)
               => aa(C,$o,aa(C,fun(C,$o),Less_eq,X),A5) )
           => aa(C,$o,aa(C,fun(C,$o),Less_eq,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4)) ) ) ) ) ).

% semilattice_order_set.boundedI
tff(fact_1097_semilattice__order__set_Obounded__iff,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A4: set(C),X: C] :
      ( lattic4895041142388067077er_set(C,F,Less_eq,Less)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4))
          <=> ! [X4: C] :
                ( member2(C,X4,A4)
               => aa(C,$o,aa(C,fun(C,$o),Less_eq,X),X4) ) ) ) ) ) ).

% semilattice_order_set.bounded_iff
tff(fact_1098_mult__less__cancel__right2,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),C3)
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C)) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3) ) ) ) ) ).

% mult_less_cancel_right2
tff(fact_1099_mult__less__cancel__right1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),B2) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),one_one(C)) ) ) ) ) ).

% mult_less_cancel_right1
tff(fact_1100_max__mult__distrib__left,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [P3: C,X: C,Y: C] :
          aa(C,C,aa(C,fun(C,C),times_times(C),P3),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y)) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),P3),aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),times_times(C),P3),X)),aa(C,C,aa(C,fun(C,C),times_times(C),P3),Y)),aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),times_times(C),P3),X)),aa(C,C,aa(C,fun(C,C),times_times(C),P3),Y))) ) ).

% max_mult_distrib_left
tff(fact_1101_min__mult__distrib__left,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [P3: C,X: C,Y: C] :
          aa(C,C,aa(C,fun(C,C),times_times(C),P3),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),P3),aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),times_times(C),P3),X)),aa(C,C,aa(C,fun(C,C),times_times(C),P3),Y)),aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),times_times(C),P3),X)),aa(C,C,aa(C,fun(C,C),times_times(C),P3),Y))) ) ).

% min_mult_distrib_left
tff(fact_1102_max__mult__distrib__right,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C,Y: C,P3: C] :
          aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y)),P3) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),P3),aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),P3)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),P3)),aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),P3)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),P3))) ) ).

% max_mult_distrib_right
tff(fact_1103_min__mult__distrib__right,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C,Y: C,P3: C] :
          aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)),P3) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),P3),aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),P3)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),P3)),aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),P3)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),P3))) ) ).

% min_mult_distrib_right
tff(fact_1104_field__le__mult__one__interval,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C,Y: C] :
          ( ! [Z4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Z4)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z4),one_one(C))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),Z4),X)),Y) ) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ).

% field_le_mult_one_interval
tff(fact_1105_mult__le__cancel__iff1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Z2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ) ).

% mult_le_cancel_iff1
tff(fact_1106_mult__le__cancel__iff2,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Z2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ) ).

% mult_le_cancel_iff2
tff(fact_1107_mult__less__iff1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: C,X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Z2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y) ) ) ) ).

% mult_less_iff1
tff(fact_1108_n__lists__Nil,axiom,
    ! [C: $tType,N: nat] :
      n_lists(C,N,nil(C)) = $ite(N = zero_zero(nat),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),nil(list(C))),nil(list(C))) ).

% n_lists_Nil
tff(fact_1109_nat__geq__1__eq__neqz,axiom,
    ! [X: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),X)
    <=> ( X != zero_zero(nat) ) ) ).

% nat_geq_1_eq_neqz
tff(fact_1110_n__lists_Osimps_I1_J,axiom,
    ! [C: $tType,Xs: list(C)] : n_lists(C,zero_zero(nat),Xs) = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),nil(list(C))) ).

% n_lists.simps(1)
tff(fact_1111_semilattice__set_Oinsert__remove,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C),X: C] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),F,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ).

% semilattice_set.insert_remove
tff(fact_1112_semilattice__set_Oremove,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C),X: C] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( member2(C,X,A4)
         => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4) = $ite(minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),F,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ) ) ) ) ).

% semilattice_set.remove
tff(fact_1113_dbl__inc__simps_I2_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl_inc(C,zero_zero(C)) = one_one(C) ) ) ).

% dbl_inc_simps(2)
tff(fact_1114_semilattice__set_Ounion,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C),B3: set(C)] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( ( B3 != bot_bot(set(C)) )
             => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),F,aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4)),aa(set(C),C,lattic1715443433743089157tice_F(C,F),B3)) ) ) ) ) ) ) ).

% semilattice_set.union
tff(fact_1115_semilattice__set_Oinsert__not__elem,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C),X: C] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ~ member2(C,X,A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),F,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4)) ) ) ) ) ) ).

% semilattice_set.insert_not_elem
tff(fact_1116_semilattice__set_Oinsert,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C),X: C] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),F,X),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4)) ) ) ) ) ).

% semilattice_set.insert
tff(fact_1117_semilattice__set_Oclosed,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C)] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C,Y2: C] : member2(C,aa(C,C,aa(C,fun(C,C),F,X2),Y2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C)))))
           => member2(C,aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4),A4) ) ) ) ) ).

% semilattice_set.closed
tff(fact_1118_semilattice__set_Osubset,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A4: set(C),B3: set(C)] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( B3 != bot_bot(set(C)) )
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
           => ( aa(C,C,aa(C,fun(C,C),F,aa(set(C),C,lattic1715443433743089157tice_F(C,F),B3)),aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4)) = aa(set(C),C,lattic1715443433743089157tice_F(C,F),A4) ) ) ) ) ) ).

% semilattice_set.subset
tff(fact_1119_convex__bound__lt,axiom,
    ! [C: $tType] :
      ( linord715952674999750819strict(C)
     => ! [X: C,A3: C,Y: C,U: C,V: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),A3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),U)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),V)
               => ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),U),V) = one_one(C) )
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),U),X)),aa(C,C,aa(C,fun(C,C),times_times(C),V),Y))),A3) ) ) ) ) ) ) ).

% convex_bound_lt
tff(fact_1120_add__right__cancel,axiom,
    ! [C: $tType] :
      ( cancel_semigroup_add(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3) )
        <=> ( B2 = C3 ) ) ) ).

% add_right_cancel
tff(fact_1121_add__left__cancel,axiom,
    ! [C: $tType] :
      ( cancel_semigroup_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3) )
        <=> ( B2 = C3 ) ) ) ).

% add_left_cancel
tff(fact_1122_add__le__cancel__right,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% add_le_cancel_right
tff(fact_1123_add__le__cancel__left,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% add_le_cancel_left
tff(fact_1124_add__0,axiom,
    ! [C: $tType] :
      ( monoid_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),zero_zero(C)),A3) = A3 ) ).

% add_0
tff(fact_1125_zero__eq__add__iff__both__eq__0,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [X: C,Y: C] :
          ( ( zero_zero(C) = aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y) )
        <=> ( ( X = zero_zero(C) )
            & ( Y = zero_zero(C) ) ) ) ) ).

% zero_eq_add_iff_both_eq_0
tff(fact_1126_add__eq__0__iff__both__eq__0,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y) = zero_zero(C) )
        <=> ( ( X = zero_zero(C) )
            & ( Y = zero_zero(C) ) ) ) ) ).

% add_eq_0_iff_both_eq_0
tff(fact_1127_add__cancel__right__right,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) )
        <=> ( B2 = zero_zero(C) ) ) ) ).

% add_cancel_right_right
tff(fact_1128_add__cancel__right__left,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) )
        <=> ( B2 = zero_zero(C) ) ) ) ).

% add_cancel_right_left
tff(fact_1129_add__cancel__left__right,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = A3 )
        <=> ( B2 = zero_zero(C) ) ) ) ).

% add_cancel_left_right
tff(fact_1130_add__cancel__left__left,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [B2: C,A3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) = A3 )
        <=> ( B2 = zero_zero(C) ) ) ) ).

% add_cancel_left_left
tff(fact_1131_double__zero__sym,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( ( zero_zero(C) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),A3) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% double_zero_sym
tff(fact_1132_add_Oright__neutral,axiom,
    ! [C: $tType] :
      ( monoid_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),zero_zero(C)) = A3 ) ).

% add.right_neutral
tff(fact_1133_add__less__cancel__right,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% add_less_cancel_right
tff(fact_1134_add__less__cancel__left,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% add_less_cancel_left
tff(fact_1135_add__diff__cancel__right_H,axiom,
    ! [C: $tType] :
      ( cancel2418104881723323429up_add(C)
     => ! [A3: C,B2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),B2) = A3 ) ).

% add_diff_cancel_right'
tff(fact_1136_add__diff__cancel__right,axiom,
    ! [C: $tType] :
      ( cancel2418104881723323429up_add(C)
     => ! [A3: C,C3: C,B2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) = minus_minus(C,A3,B2) ) ).

% add_diff_cancel_right
tff(fact_1137_add__diff__cancel__left_H,axiom,
    ! [C: $tType] :
      ( cancel2418104881723323429up_add(C)
     => ! [A3: C,B2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),A3) = B2 ) ).

% add_diff_cancel_left'
tff(fact_1138_add__diff__cancel__left,axiom,
    ! [C: $tType] :
      ( cancel2418104881723323429up_add(C)
     => ! [C3: C,A3: C,B2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2)) = minus_minus(C,A3,B2) ) ).

% add_diff_cancel_left
tff(fact_1139_diff__add__cancel,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,A3,B2)),B2) = A3 ) ).

% diff_add_cancel
tff(fact_1140_add__diff__cancel,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),B2) = A3 ) ).

% add_diff_cancel
tff(fact_1141_add__le__same__cancel1,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) ) ) ).

% add_le_same_cancel1
tff(fact_1142_add__le__same__cancel2,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) ) ) ).

% add_le_same_cancel2
tff(fact_1143_le__add__same__cancel1,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2) ) ) ).

% le_add_same_cancel1
tff(fact_1144_le__add__same__cancel2,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2) ) ) ).

% le_add_same_cancel2
tff(fact_1145_double__add__le__zero__iff__single__add__le__zero,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),A3)),zero_zero(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) ) ) ).

% double_add_le_zero_iff_single_add_le_zero
tff(fact_1146_zero__le__double__add__iff__zero__le__single__add,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3) ) ) ).

% zero_le_double_add_iff_zero_le_single_add
tff(fact_1147_zero__less__double__add__iff__zero__less__single__add,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3) ) ) ).

% zero_less_double_add_iff_zero_less_single_add
tff(fact_1148_double__add__less__zero__iff__single__add__less__zero,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),A3)),zero_zero(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% double_add_less_zero_iff_single_add_less_zero
tff(fact_1149_less__add__same__cancel2,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2) ) ) ).

% less_add_same_cancel2
tff(fact_1150_less__add__same__cancel1,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2) ) ) ).

% less_add_same_cancel1
tff(fact_1151_add__less__same__cancel2,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% add_less_same_cancel2
tff(fact_1152_add__less__same__cancel1,axiom,
    ! [C: $tType] :
      ( ordere1937475149494474687imp_le(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% add_less_same_cancel1
tff(fact_1153_diff__add__zero,axiom,
    ! [C: $tType] :
      ( comm_monoid_diff(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) = zero_zero(C) ) ).

% diff_add_zero
tff(fact_1154_exists__leI,axiom,
    ! [N: nat,Pa: fun(nat,$o)] :
      ( ( ! [N5: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N5),N)
           => ~ aa(nat,$o,Pa,N5) )
       => aa(nat,$o,Pa,N) )
     => ? [N6: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N6),N)
          & aa(nat,$o,Pa,N6) ) ) ).

% exists_leI
tff(fact_1155_add_Oright__commute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),B2) ) ).

% add.right_commute
tff(fact_1156_add_Oright__assoc,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) ) ).

% add.right_assoc
tff(fact_1157_add__right__imp__eq,axiom,
    ! [C: $tType] :
      ( cancel_semigroup_add(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3) )
         => ( B2 = C3 ) ) ) ).

% add_right_imp_eq
tff(fact_1158_add__left__imp__eq,axiom,
    ! [C: $tType] :
      ( cancel_semigroup_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3) )
         => ( B2 = C3 ) ) ) ).

% add_left_imp_eq
tff(fact_1159_ab__semigroup__add__class_Oadd_Oleft__commute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) ) ).

% ab_semigroup_add_class.add.left_commute
tff(fact_1160_ab__semigroup__add__class_Oadd_Ocommute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) ) ).

% ab_semigroup_add_class.add.commute
tff(fact_1161_add_Oright__cancel,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3) )
        <=> ( B2 = C3 ) ) ) ).

% add.right_cancel
tff(fact_1162_add_Oleft__cancel,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3) )
        <=> ( B2 = C3 ) ) ) ).

% add.left_cancel
tff(fact_1163_add_Oassoc,axiom,
    ! [C: $tType] :
      ( semigroup_add(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) ) ).

% add.assoc
tff(fact_1164_group__cancel_Oadd2,axiom,
    ! [C: $tType] :
      ( comm_monoid_add(C)
     => ! [B3: C,K: C,B2: C,A3: C] :
          ( ( B3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),B2) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) ) ) ) ).

% group_cancel.add2
tff(fact_1165_group__cancel_Oadd1,axiom,
    ! [C: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: C,K: C,A3: C,B2: C] :
          ( ( A4 = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),A3) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A4),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) ) ) ) ).

% group_cancel.add1
tff(fact_1166_add__mono__thms__linordered__semiring_I4_J,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( ( I = J )
            & ( K = La ) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K) = aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La) ) ) ) ).

% add_mono_thms_linordered_semiring(4)
tff(fact_1167_mlex__leI,axiom,
    ! [A3: nat,A10: nat,B2: nat,B8: nat,N4: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),A10)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),B2),B8)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),N4)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A10),N4)),B8)) ) ) ).

% mlex_leI
tff(fact_1168_dbl__inc__def,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [X: C] : neg_numeral_dbl_inc(C,X) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),X)),one_one(C)) ) ).

% dbl_inc_def
tff(fact_1169_add__le__imp__le__right,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3))
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% add_le_imp_le_right
tff(fact_1170_add__le__imp__le__left,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2))
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% add_le_imp_le_left
tff(fact_1171_le__iff__add,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
        <=> ? [C6: C] : B2 = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C6) ) ) ).

% le_iff_add
tff(fact_1172_add__right__mono,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) ) ) ).

% add_right_mono
tff(fact_1173_less__eqE,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ~ ! [C2: C] : B2 != aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C2) ) ) ).

% less_eqE
tff(fact_1174_add__left__mono,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2)) ) ) ).

% add_left_mono
tff(fact_1175_add__mono,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),D3)) ) ) ) ).

% add_mono
tff(fact_1176_add__mono__thms__linordered__semiring_I1_J,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),I),J)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),K),La) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_semiring(1)
tff(fact_1177_add__mono__thms__linordered__semiring_I2_J,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( ( I = J )
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),K),La) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_semiring(2)
tff(fact_1178_add__mono__thms__linordered__semiring_I3_J,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),I),J)
            & ( K = La ) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_semiring(3)
tff(fact_1179_add_Ogroup__left__neutral,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),zero_zero(C)),A3) = A3 ) ).

% add.group_left_neutral
tff(fact_1180_add_Ocomm__neutral,axiom,
    ! [C: $tType] :
      ( comm_monoid_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),zero_zero(C)) = A3 ) ).

% add.comm_neutral
tff(fact_1181_comm__monoid__add__class_Oadd__0,axiom,
    ! [C: $tType] :
      ( comm_monoid_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),zero_zero(C)),A3) = A3 ) ).

% comm_monoid_add_class.add_0
tff(fact_1182_add__less__imp__less__right,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3))
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% add_less_imp_less_right
tff(fact_1183_add__less__imp__less__left,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2))
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% add_less_imp_less_left
tff(fact_1184_add__strict__right__mono,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) ) ) ).

% add_strict_right_mono
tff(fact_1185_add__strict__left__mono,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2)) ) ) ).

% add_strict_left_mono
tff(fact_1186_add__strict__mono,axiom,
    ! [C: $tType] :
      ( strict9044650504122735259up_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),D3)) ) ) ) ).

% add_strict_mono
tff(fact_1187_add__mono__thms__linordered__field_I1_J,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),I),J)
            & ( K = La ) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_field(1)
tff(fact_1188_add__mono__thms__linordered__field_I2_J,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( ( I = J )
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),K),La) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_field(2)
tff(fact_1189_add__mono__thms__linordered__field_I5_J,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),I),J)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),K),La) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_field(5)
tff(fact_1190_ring__class_Oring__distribs_I2_J,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% ring_class.ring_distribs(2)
tff(fact_1191_ring__class_Oring__distribs_I1_J,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ).

% ring_class.ring_distribs(1)
tff(fact_1192_comm__semiring__class_Odistrib,axiom,
    ! [C: $tType] :
      ( comm_semiring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% comm_semiring_class.distrib
tff(fact_1193_distrib__left,axiom,
    ! [C: $tType] :
      ( semiring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ).

% distrib_left
tff(fact_1194_distrib__right,axiom,
    ! [C: $tType] :
      ( semiring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% distrib_right
tff(fact_1195_combine__common__factor,axiom,
    ! [C: $tType] :
      ( semiring(C)
     => ! [A3: C,E4: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),C3)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),E4)),C3) ) ).

% combine_common_factor
tff(fact_1196_diff__diff__eq,axiom,
    ! [C: $tType] :
      ( cancel2418104881723323429up_add(C)
     => ! [A3: C,B2: C,C3: C] : minus_minus(C,minus_minus(C,A3,B2),C3) = minus_minus(C,A3,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) ) ).

% diff_diff_eq
tff(fact_1197_add__implies__diff,axiom,
    ! [C: $tType] :
      ( cancel1802427076303600483id_add(C)
     => ! [C3: C,B2: C,A3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2) = A3 )
         => ( C3 = minus_minus(C,A3,B2) ) ) ) ).

% add_implies_diff
tff(fact_1198_diff__add__eq__diff__diff__swap,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C,C3: C] : minus_minus(C,A3,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) = minus_minus(C,minus_minus(C,A3,C3),B2) ) ).

% diff_add_eq_diff_diff_swap
tff(fact_1199_diff__add__eq,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,A3,B2)),C3) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3),B2) ) ).

% diff_add_eq
tff(fact_1200_diff__diff__eq2,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C,C3: C] : minus_minus(C,A3,minus_minus(C,B2,C3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3),B2) ) ).

% diff_diff_eq2
tff(fact_1201_add__diff__eq,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),minus_minus(C,B2,C3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),C3) ) ).

% add_diff_eq
tff(fact_1202_eq__diff__eq,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,C3: C,B2: C] :
          ( ( A3 = minus_minus(C,C3,B2) )
        <=> ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = C3 ) ) ) ).

% eq_diff_eq
tff(fact_1203_diff__eq__eq,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( minus_minus(C,A3,B2) = C3 )
        <=> ( A3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2) ) ) ) ).

% diff_eq_eq
tff(fact_1204_group__cancel_Osub1,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A4: C,K: C,A3: C,B2: C] :
          ( ( A4 = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),A3) )
         => ( minus_minus(C,A4,B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),minus_minus(C,A3,B2)) ) ) ) ).

% group_cancel.sub1
tff(fact_1205_min__add__distrib__right,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),X),aa(C,C,aa(C,fun(C,C),ord_min(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y)),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Z2)) ) ).

% min_add_distrib_right
tff(fact_1206_min__add__distrib__left,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)),Z2) = aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Z2)),aa(C,C,aa(C,fun(C,C),plus_plus(C),Y),Z2)) ) ).

% min_add_distrib_left
tff(fact_1207_max__add__distrib__right,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),X),aa(C,C,aa(C,fun(C,C),ord_max(C),Y),Z2)) = aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y)),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Z2)) ) ).

% max_add_distrib_right
tff(fact_1208_max__add__distrib__left,axiom,
    ! [C: $tType] :
      ( ordere2412721322843649153imp_le(C)
     => ! [X: C,Y: C,Z2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y)),Z2) = aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Z2)),aa(C,C,aa(C,fun(C,C),plus_plus(C),Y),Z2)) ) ).

% max_add_distrib_left
tff(fact_1209_Inf__fin_Osemilattice__set__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => lattic149705377957585745ce_set(C,inf_inf(C)) ) ).

% Inf_fin.semilattice_set_axioms
tff(fact_1210_add_Osafe__commute,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => ! [X: C,Y: C,A3: C,B2: C] :
          ( syntax7388354845996824322omatch(C,C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y),A3)
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3) ) ) ) ).

% add.safe_commute
tff(fact_1211_add__decreasing,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),B2) ) ) ) ).

% add_decreasing
tff(fact_1212_add__increasing,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)) ) ) ) ).

% add_increasing
tff(fact_1213_add__decreasing2,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),B2) ) ) ) ).

% add_decreasing2
tff(fact_1214_add__increasing2,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)) ) ) ) ).

% add_increasing2
tff(fact_1215_add__nonneg__nonneg,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) ) ) ) ).

% add_nonneg_nonneg
tff(fact_1216_add__nonpos__nonpos,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),zero_zero(C)) ) ) ) ).

% add_nonpos_nonpos
tff(fact_1217_add__nonneg__eq__0__iff,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),Y)
           => ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y) = zero_zero(C) )
            <=> ( ( X = zero_zero(C) )
                & ( Y = zero_zero(C) ) ) ) ) ) ) ).

% add_nonneg_eq_0_iff
tff(fact_1218_add__nonpos__eq__0__iff,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),zero_zero(C))
           => ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y) = zero_zero(C) )
            <=> ( ( X = zero_zero(C) )
                & ( Y = zero_zero(C) ) ) ) ) ) ) ).

% add_nonpos_eq_0_iff
tff(fact_1219_add__less__le__mono,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),D3)) ) ) ) ).

% add_less_le_mono
tff(fact_1220_add__le__less__mono,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),D3)) ) ) ) ).

% add_le_less_mono
tff(fact_1221_add__mono__thms__linordered__field_I3_J,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),I),J)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),K),La) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_field(3)
tff(fact_1222_add__mono__thms__linordered__field_I4_J,axiom,
    ! [C: $tType] :
      ( ordere580206878836729694up_add(C)
     => ! [I: C,J: C,K: C,La: C] :
          ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),I),J)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),K),La) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),I),K)),aa(C,C,aa(C,fun(C,C),plus_plus(C),J),La)) ) ) ).

% add_mono_thms_linordered_field(4)
tff(fact_1223_pos__add__strict,axiom,
    ! [C: $tType] :
      ( strict7427464778891057005id_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)) ) ) ) ).

% pos_add_strict
tff(fact_1224_canonically__ordered__monoid__add__class_OlessE,axiom,
    ! [C: $tType] :
      ( canoni5634975068530333245id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ~ ! [C2: C] :
                ( ( B2 = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C2) )
               => ( C2 = zero_zero(C) ) ) ) ) ).

% canonically_ordered_monoid_add_class.lessE
tff(fact_1225_add__pos__pos,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) ) ) ) ).

% add_pos_pos
tff(fact_1226_add__neg__neg,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),zero_zero(C)) ) ) ) ).

% add_neg_neg
tff(fact_1227_diff__le__eq,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,A3,B2)),C3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2)) ) ) ).

% diff_le_eq
tff(fact_1228_le__diff__eq,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),minus_minus(C,C3,B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) ) ) ).

% le_diff_eq
tff(fact_1229_ordered__cancel__comm__monoid__diff__class_Odiff__add,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,B2,A3)),A3) = B2 ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_add
tff(fact_1230_le__add__diff,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3),A3)) ) ) ).

% le_add_diff
tff(fact_1231_ordered__cancel__comm__monoid__diff__class_Ole__diff__conv2,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),minus_minus(C,B2,A3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3)),B2) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.le_diff_conv2
tff(fact_1232_ordered__cancel__comm__monoid__diff__class_Oadd__diff__assoc,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),minus_minus(C,B2,A3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2),A3) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.add_diff_assoc
tff(fact_1233_ordered__cancel__comm__monoid__diff__class_Odiff__add__assoc,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),minus_minus(C,B2,A3)) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_add_assoc
tff(fact_1234_ordered__cancel__comm__monoid__diff__class_Oadd__diff__assoc2,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,B2,A3)),C3) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3),A3) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.add_diff_assoc2
tff(fact_1235_ordered__cancel__comm__monoid__diff__class_Odiff__add__assoc2,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,B2,A3)),C3) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_add_assoc2
tff(fact_1236_ordered__cancel__comm__monoid__diff__class_Odiff__diff__right,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( minus_minus(C,C3,minus_minus(C,B2,A3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3),B2) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_diff_right
tff(fact_1237_ordered__cancel__comm__monoid__diff__class_Oadd__diff__inverse,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),minus_minus(C,B2,A3)) = B2 ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.add_diff_inverse
tff(fact_1238_ordered__cancel__comm__monoid__diff__class_Ole__imp__diff__is__add,axiom,
    ! [C: $tType] :
      ( ordere1170586879665033532d_diff(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
           => ( ( minus_minus(C,B2,A3) = C3 )
            <=> ( B2 = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),A3) ) ) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.le_imp_diff_is_add
tff(fact_1239_less__add__one,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))) ) ).

% less_add_one
tff(fact_1240_add__mono1,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),one_one(C))) ) ) ).

% add_mono1
tff(fact_1241_diff__less__eq,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,A3,B2)),C3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),B2)) ) ) ).

% diff_less_eq
tff(fact_1242_less__diff__eq,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,C3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),minus_minus(C,C3,B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C3) ) ) ).

% less_diff_eq
tff(fact_1243_square__diff__square__factored,axiom,
    ! [C: $tType] :
      ( comm_ring(C)
     => ! [X: C,Y: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),X),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Y)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y)),minus_minus(C,X,Y)) ) ).

% square_diff_square_factored
tff(fact_1244_eq__add__iff2,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,E4: C,C3: C,B2: C,D3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),D3) )
        <=> ( C3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,B2,A3)),E4)),D3) ) ) ) ).

% eq_add_iff2
tff(fact_1245_eq__add__iff1,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,E4: C,C3: C,B2: C,D3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),D3) )
        <=> ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,A3,B2)),E4)),C3) = D3 ) ) ) ).

% eq_add_iff1
tff(fact_1246_add__strict__increasing2,axiom,
    ! [C: $tType] :
      ( ordere8940638589300402666id_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)) ) ) ) ).

% add_strict_increasing2
tff(fact_1247_add__strict__increasing,axiom,
    ! [C: $tType] :
      ( ordere8940638589300402666id_add(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3)) ) ) ) ).

% add_strict_increasing
tff(fact_1248_add__pos__nonneg,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) ) ) ) ).

% add_pos_nonneg
tff(fact_1249_add__nonpos__neg,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),zero_zero(C)) ) ) ) ).

% add_nonpos_neg
tff(fact_1250_add__nonneg__pos,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) ) ) ) ).

% add_nonneg_pos
tff(fact_1251_add__neg__nonpos,axiom,
    ! [C: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),zero_zero(C)) ) ) ) ).

% add_neg_nonpos
tff(fact_1252_sum__squares__ge__zero,axiom,
    ! [C: $tType] :
      ( linordered_ring(C)
     => ! [X: C,Y: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Y))) ) ).

% sum_squares_ge_zero
tff(fact_1253_not__sum__squares__lt__zero,axiom,
    ! [C: $tType] :
      ( linordered_ring(C)
     => ! [X: C,Y: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Y))),zero_zero(C)) ) ).

% not_sum_squares_lt_zero
tff(fact_1254_zero__less__two,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),one_one(C))) ) ).

% zero_less_two
tff(fact_1255_le__add__iff2,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [A3: C,E4: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),D3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,B2,A3)),E4)),D3)) ) ) ).

% le_add_iff2
tff(fact_1256_le__add__iff1,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [A3: C,E4: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),D3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,A3,B2)),E4)),C3)),D3) ) ) ).

% le_add_iff1
tff(fact_1257_less__add__iff1,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [A3: C,E4: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),D3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,A3,B2)),E4)),C3)),D3) ) ) ).

% less_add_iff1
tff(fact_1258_less__add__iff2,axiom,
    ! [C: $tType] :
      ( ordered_ring(C)
     => ! [A3: C,E4: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),E4)),C3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),E4)),D3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,B2,A3)),E4)),D3)) ) ) ).

% less_add_iff2
tff(fact_1259_square__diff__one__factored,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [X: C] : minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),X),one_one(C)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),one_one(C))),minus_minus(C,X,one_one(C))) ) ).

% square_diff_one_factored
tff(fact_1260_convex__bound__le,axiom,
    ! [C: $tType] :
      ( linord6961819062388156250ring_1(C)
     => ! [X: C,A3: C,Y: C,U: C,V: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),A3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),U)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),V)
               => ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),U),V) = one_one(C) )
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),U),X)),aa(C,C,aa(C,fun(C,C),times_times(C),V),Y))),A3) ) ) ) ) ) ) ).

% convex_bound_le
tff(fact_1261_semilattice__set_Osingleton,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),X: C] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ) ).

% semilattice_set.singleton
tff(fact_1262_discrete,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),B2) ) ) ).

% discrete
tff(fact_1263_sum__squares__gt__zero__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Y)))
        <=> ( ( X != zero_zero(C) )
            | ( Y != zero_zero(C) ) ) ) ) ).

% sum_squares_gt_zero_iff
tff(fact_1264_sum__squares__le__zero__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Y))),zero_zero(C))
        <=> ( ( X = zero_zero(C) )
            & ( Y = zero_zero(C) ) ) ) ) ).

% sum_squares_le_zero_iff
tff(fact_1265_sum__squares__eq__zero__iff,axiom,
    ! [C: $tType] :
      ( linord4710134922213307826strict(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Y)) = zero_zero(C) )
        <=> ( ( X = zero_zero(C) )
            & ( Y = zero_zero(C) ) ) ) ) ).

% sum_squares_eq_zero_iff
tff(fact_1266_add__scale__eq__noteq,axiom,
    ! [C: $tType] :
      ( semiri1453513574482234551roduct(C)
     => ! [R3: C,A3: C,B2: C,C3: C,D3: C] :
          ( ( R3 != zero_zero(C) )
         => ( ( ( A3 = B2 )
              & ( C3 != D3 ) )
           => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),R3),C3)) != aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),R3),D3)) ) ) ) ) ).

% add_scale_eq_noteq
tff(fact_1267_crossproduct__noteq,axiom,
    ! [C: $tType] :
      ( semiri1453513574482234551roduct(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( ( ( A3 != B2 )
            & ( C3 != D3 ) )
        <=> ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) != aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),D3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ) ).

% crossproduct_noteq
tff(fact_1268_crossproduct__eq,axiom,
    ! [C: $tType] :
      ( semiri1453513574482234551roduct(C)
     => ! [W: C,Y: C,X: C,Z2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),W),Y)),aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),W),Z2)),aa(C,C,aa(C,fun(C,C),times_times(C),X),Y)) )
        <=> ( ( W = X )
            | ( Y = Z2 ) ) ) ) ).

% crossproduct_eq
tff(fact_1269_dbl__dec__def,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [X: C] : neg_numeral_dbl_dec(C,X) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),X),one_one(C)) ) ).

% dbl_dec_def
tff(fact_1270_slice__Cons,axiom,
    ! [C: $tType,Begin: nat,End: nat,X: C,Xs: list(C)] :
      slice(C,Begin,End,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(
        ( ( Begin = zero_zero(nat) )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),End) ),
        aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),slice(C,Begin,minus_minus(nat,End,one_one(nat)),Xs)),
        slice(C,minus_minus(nat,Begin,one_one(nat)),minus_minus(nat,End,one_one(nat)),Xs) ) ).

% slice_Cons
tff(fact_1271_slice__Nil,axiom,
    ! [C: $tType,Begin: nat,End: nat] : slice(C,Begin,End,nil(C)) = nil(C) ).

% slice_Nil
tff(fact_1272_slice__eq__bounds__empty,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] : slice(C,I,I,Xs) = nil(C) ).

% slice_eq_bounds_empty
tff(fact_1273_dbl__dec__simps_I3_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl_dec(C,one_one(C)) = one_one(C) ) ) ).

% dbl_dec_simps(3)
tff(fact_1274_mlex__snd__decrI,axiom,
    ! [A3: nat,A10: nat,B2: nat,B8: nat,N4: nat] :
      ( ( A3 = A10 )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),B8)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),N4)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A10),N4)),B8)) ) ) ).

% mlex_snd_decrI
tff(fact_1275_mlex__fst__decrI,axiom,
    ! [A3: nat,A10: nat,B2: nat,N4: nat,B8: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),A10)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),N4)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B8),N4)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),N4)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A10),N4)),B8)) ) ) ) ).

% mlex_fst_decrI
tff(fact_1276_mlex__bound,axiom,
    ! [A3: nat,A4: nat,B2: nat,N4: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),A4)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),N4)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),N4)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A4),N4)) ) ) ).

% mlex_bound
tff(fact_1277_count__list_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C] :
      aa(C,nat,count_list(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Y) = $ite(X = Y,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(C,nat,count_list(C,Xs),Y)),one_one(nat)),aa(C,nat,count_list(C,Xs),Y)) ).

% count_list.simps(2)
tff(fact_1278_power__decreasing__iff,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [B2: C,M2: nat,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),one_one(C))
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),N))
            <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M2) ) ) ) ) ).

% power_decreasing_iff
tff(fact_1279_nth__Cons__pos,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),N) = aa(nat,C,nth(C,Xs),minus_minus(nat,N,one_one(nat))) ) ) ).

% nth_Cons_pos
tff(fact_1280_gbinomial__reduce__nat,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
         => ( aa(nat,C,gbinomial(C,A3),K) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),minus_minus(nat,K,one_one(nat)))),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),K)) ) ) ) ).

% gbinomial_reduce_nat
tff(fact_1281_power__minus__mult,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [N: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),minus_minus(nat,N,one_one(nat)))),A3) = aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N) ) ) ) ).

% power_minus_mult
tff(fact_1282_power__eq__if,axiom,
    ! [C: $tType] :
      ( power(C)
     => ! [P3: C,M2: nat] :
          aa(nat,C,aa(C,fun(nat,C),power_power(C),P3),M2) = $ite(M2 = zero_zero(nat),one_one(C),aa(C,C,aa(C,fun(C,C),times_times(C),P3),aa(nat,C,aa(C,fun(nat,C),power_power(C),P3),minus_minus(nat,M2,one_one(nat))))) ) ).

% power_eq_if
tff(fact_1283_card__Diff__singleton,axiom,
    ! [C: $tType,X: C,A4: set(C)] :
      ( member2(C,X,A4)
     => ( finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) = minus_minus(nat,finite_card(C,A4),one_one(nat)) ) ) ).

% card_Diff_singleton
tff(fact_1284_card__Diff__singleton__if,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) = $ite(member2(C,X,A4),minus_minus(nat,finite_card(C,A4),one_one(nat)),finite_card(C,A4)) ).

% card_Diff_singleton_if
tff(fact_1285_power__one,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),one_one(C)),N) = one_one(C) ) ).

% power_one
tff(fact_1286_power__inject__exp,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,M2: nat,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => ( ( aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),M2) = aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N) )
          <=> ( M2 = N ) ) ) ) ).

% power_inject_exp
tff(fact_1287_card_Oempty,axiom,
    ! [C: $tType] : finite_card(C,bot_bot(set(C))) = zero_zero(nat) ).

% card.empty
tff(fact_1288_nth__Cons__0,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),zero_zero(nat)) = X ).

% nth_Cons_0
tff(fact_1289_gbinomial__0_I1_J,axiom,
    ! [C: $tType] :
      ( ( semiring_char_0(C)
        & semidom_divide(C) )
     => ! [A3: C] : aa(nat,C,gbinomial(C,A3),zero_zero(nat)) = one_one(C) ) ).

% gbinomial_0(1)
tff(fact_1290_power__strict__increasing__iff,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [B2: C,X: nat,Y: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),X)),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),Y))
          <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X),Y) ) ) ) ).

% power_strict_increasing_iff
tff(fact_1291_card__0__eq,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( ( finite_card(C,A4) = zero_zero(nat) )
      <=> ( A4 = bot_bot(set(C)) ) ) ) ).

% card_0_eq
tff(fact_1292_power__strict__decreasing__iff,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [B2: C,M2: nat,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),one_one(C))
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),N))
            <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2) ) ) ) ) ).

% power_strict_decreasing_iff
tff(fact_1293_power__increasing__iff,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [B2: C,X: nat,Y: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),X)),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),Y))
          <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),X),Y) ) ) ) ).

% power_increasing_iff
tff(fact_1294_power__commuting__commutes,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [X: C,Y: C,N: nat] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),X),Y) = aa(C,C,aa(C,fun(C,C),times_times(C),Y),X) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)),Y) = aa(C,C,aa(C,fun(C,C),times_times(C),Y),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)) ) ) ) ).

% power_commuting_commutes
tff(fact_1295_power__mult__distrib,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),N) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),B2),N)) ) ).

% power_mult_distrib
tff(fact_1296_power__commutes,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ).

% power_commutes
tff(fact_1297_map__eq__nth__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),La: list(D),L_a: list(D),I: nat] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),La) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L_a) )
     => ( aa(D,C,F,aa(nat,D,nth(D,La),I)) = aa(D,C,F,aa(nat,D,nth(D,L_a),I)) ) ) ).

% map_eq_nth_eq
tff(fact_1298_one__le__power,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ) ).

% one_le_power
tff(fact_1299_left__right__inverse__power,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [X: C,Y: C,N: nat] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),X),Y) = one_one(C) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),Y),N)) = one_one(C) ) ) ) ).

% left_right_inverse_power
tff(fact_1300_power__0,axiom,
    ! [C: $tType] :
      ( power(C)
     => ! [A3: C] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),zero_zero(nat)) = one_one(C) ) ).

% power_0
tff(fact_1301_power__add,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C,M2: nat,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ).

% power_add
tff(fact_1302_card__eq__0__iff,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ( finite_card(C,A4) = zero_zero(nat) )
    <=> ( ( A4 = bot_bot(set(C)) )
        | ~ aa(set(C),$o,finite_finite2(C),A4) ) ) ).

% card_eq_0_iff
tff(fact_1303_power__le__one,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),one_one(C)) ) ) ) ).

% power_le_one
tff(fact_1304_power__less__power__Suc,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N))) ) ) ).

% power_less_power_Suc
tff(fact_1305_power__gt1__lemma,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N))) ) ) ).

% power_gt1_lemma
tff(fact_1306_power__0__left,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [N: nat] :
          aa(nat,C,aa(C,fun(nat,C),power_power(C),zero_zero(C)),N) = $ite(N = zero_zero(nat),one_one(C),zero_zero(C)) ) ).

% power_0_left
tff(fact_1307_card__1__singletonE,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ( finite_card(C,A4) = one_one(nat) )
     => ~ ! [X2: C] : A4 != aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C))) ) ).

% card_1_singletonE
tff(fact_1308_power__less__imp__less__exp,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,M2: nat,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N))
           => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M2),N) ) ) ) ).

% power_less_imp_less_exp
tff(fact_1309_power__strict__increasing,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [N: nat,N4: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N4)) ) ) ) ).

% power_strict_increasing
tff(fact_1310_power__increasing,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [N: nat,N4: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N4)) ) ) ) ).

% power_increasing
tff(fact_1311_card__gt__0__iff,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),finite_card(C,A4))
    <=> ( ( A4 != bot_bot(set(C)) )
        & aa(set(C),$o,finite_finite2(C),A4) ) ) ).

% card_gt_0_iff
tff(fact_1312_power__Suc__less,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N))),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ) ) ).

% power_Suc_less
tff(fact_1313_card__1__singletonI,axiom,
    ! [C: $tType,S: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),S)
     => ( ( finite_card(C,S) = one_one(nat) )
       => ( member2(C,X,S)
         => ( S = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) ) ) ) ).

% card_1_singletonI
tff(fact_1314_power__strict__decreasing,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [N: nat,N4: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N4)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ) ) ) ).

% power_strict_decreasing
tff(fact_1315_card__Diff1__le,axiom,
    ! [C: $tType,A4: set(C),X: C] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))),finite_card(C,A4)) ).

% card_Diff1_le
tff(fact_1316_power__decreasing,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [N: nat,N4: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N4)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ) ) ) ).

% power_decreasing
tff(fact_1317_power__le__imp__le__exp,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,M2: nat,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N))
           => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N) ) ) ) ).

% power_le_imp_le_exp
tff(fact_1318_nth__Cons_H,axiom,
    ! [C: $tType,X: C,Xs: list(C),N: nat] :
      aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),N) = $ite(N = zero_zero(nat),X,aa(nat,C,nth(C,Xs),minus_minus(nat,N,one_one(nat)))) ).

% nth_Cons'
tff(fact_1319_self__le__power,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ) ) ).

% self_le_power
tff(fact_1320_card__Un__Int,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),$o,finite_finite2(C),B3)
       => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(C,A4)),finite_card(C,B3)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))),finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ).

% card_Un_Int
tff(fact_1321_one__less__power,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ) ) ).

% one_less_power
tff(fact_1322_card__Diff__subset__Int,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
     => ( finite_card(C,minus_minus(set(C),A4,B3)) = minus_minus(nat,finite_card(C,A4),finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ).

% card_Diff_subset_Int
tff(fact_1323_count__list_Osimps_I1_J,axiom,
    ! [C: $tType,Y: C] : aa(C,nat,count_list(C,nil(C)),Y) = zero_zero(nat) ).

% count_list.simps(1)
tff(fact_1324_card__Diff1__less__iff,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))),finite_card(C,A4))
    <=> ( aa(set(C),$o,finite_finite2(C),A4)
        & member2(C,X,A4) ) ) ).

% card_Diff1_less_iff
tff(fact_1325_card__Diff2__less,axiom,
    ! [C: $tType,A4: set(C),X: C,Y: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( member2(C,X,A4)
       => ( member2(C,Y,A4)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),finite_card(C,minus_minus(set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C)))))),finite_card(C,A4)) ) ) ) ).

% card_Diff2_less
tff(fact_1326_card__Diff1__less,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( member2(C,X,A4)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))),finite_card(C,A4)) ) ) ).

% card_Diff1_less
tff(fact_1327_card__Un__disjoint,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),$o,finite_finite2(C),B3)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
         => ( finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(C,A4)),finite_card(C,B3)) ) ) ) ) ).

% card_Un_disjoint
tff(fact_1328_nth__non__equal__first__eq,axiom,
    ! [C: $tType,X: C,Y: C,Xs: list(C),N: nat] :
      ( ( X != Y )
     => ( ( aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),N) = Y )
      <=> ( ( aa(nat,C,nth(C,Xs),minus_minus(nat,N,one_one(nat))) = Y )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N) ) ) ) ).

% nth_non_equal_first_eq
tff(fact_1329_foldr__max__sorted,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Y: C] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),Xs))
         => ( aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),foldr(C,C),ord_max(C)),Xs),Y) = $ite(Xs = nil(C),Y,aa(C,C,aa(C,fun(C,C),ord_max(C),aa(nat,C,nth(C,Xs),zero_zero(nat))),Y)) ) ) ) ).

% foldr_max_sorted
tff(fact_1330_slice__nth,axiom,
    ! [C: $tType,From: nat,To: nat,Xs: list(C),I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),From),To)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),To),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),minus_minus(nat,To,From))
         => ( aa(nat,C,nth(C,slice(C,From,To,Xs)),I) = aa(nat,C,nth(C,Xs),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),From),I)) ) ) ) ) ).

% slice_nth
tff(fact_1331_last__conv__nth,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( last(C,Xs) = aa(nat,C,nth(C,Xs),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat))) ) ) ).

% last_conv_nth
tff(fact_1332_nth__Cons__numeral,axiom,
    ! [C: $tType,X: C,Xs: list(C),V: num] : aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(num,nat,numeral_numeral(nat),V)) = aa(nat,C,nth(C,Xs),minus_minus(nat,aa(num,nat,numeral_numeral(nat),V),one_one(nat))) ).

% nth_Cons_numeral
tff(fact_1333_card__insert__disjoint_H,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( ~ member2(C,X,A4)
       => ( minus_minus(nat,finite_card(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)),aa(nat,nat,suc,zero_zero(nat))) = finite_card(C,A4) ) ) ) ).

% card_insert_disjoint'
tff(fact_1334_card_Oremove,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( member2(C,X,A4)
       => ( finite_card(C,A4) = aa(nat,nat,suc,finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ).

% card.remove
tff(fact_1335_card_Oinsert__remove,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( finite_card(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(nat,nat,suc,finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ).

% card.insert_remove
tff(fact_1336_card__Suc__Diff1,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( member2(C,X,A4)
       => ( aa(nat,nat,suc,finite_card(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) = finite_card(C,A4) ) ) ) ).

% card_Suc_Diff1
tff(fact_1337_mult__numeral__left__semiring__numeral,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [V: num,W: num,Z2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),Z2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),V),W))),Z2) ) ).

% mult_numeral_left_semiring_numeral
tff(fact_1338_numeral__times__numeral,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [M2: num,N: num] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),M2)),aa(num,C,numeral_numeral(C),N)) = aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),M2),N)) ) ).

% numeral_times_numeral
tff(fact_1339_min__Suc__gt_I1_J,axiom,
    ! [A3: nat,B2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(nat,nat,suc,A3)),B2) = aa(nat,nat,suc,A3) ) ) ).

% min_Suc_gt(1)
tff(fact_1340_min__Suc__gt_I2_J,axiom,
    ! [A3: nat,B2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),B2),aa(nat,nat,suc,A3)) = aa(nat,nat,suc,A3) ) ) ).

% min_Suc_gt(2)
tff(fact_1341_length__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(C),nat,size_size(list(C)),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),nat,size_size(list(D)),Xs) ).

% length_map
tff(fact_1342_append__eq__append__conv,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Us2: list(C),Vs: list(C)] :
      ( ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) )
        | ( aa(list(C),nat,size_size(list(C)),Us2) = aa(list(C),nat,size_size(list(C)),Vs) ) )
     => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Vs) )
      <=> ( ( Xs = Ys )
          & ( Us2 = Vs ) ) ) ) ).

% append_eq_append_conv
tff(fact_1343_length__rev,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) ).

% length_rev
tff(fact_1344_length__rotate1,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),rotate1(C),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) ).

% length_rotate1
tff(fact_1345_distrib__left__numeral,axiom,
    ! [C: $tType] :
      ( ( numeral(C)
        & semiring(C) )
     => ! [V: num,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),C3)) ) ).

% distrib_left_numeral
tff(fact_1346_distrib__right__numeral,axiom,
    ! [C: $tType] :
      ( ( numeral(C)
        & semiring(C) )
     => ! [A3: C,B2: C,V: num] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),aa(num,C,numeral_numeral(C),V)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),V))),aa(C,C,aa(C,fun(C,C),times_times(C),B2),aa(num,C,numeral_numeral(C),V))) ) ).

% distrib_right_numeral
tff(fact_1347_right__diff__distrib__numeral,axiom,
    ! [C: $tType] :
      ( ( numeral(C)
        & ring(C) )
     => ! [V: num,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),minus_minus(C,B2,C3)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),C3)) ) ).

% right_diff_distrib_numeral
tff(fact_1348_left__diff__distrib__numeral,axiom,
    ! [C: $tType] :
      ( ( numeral(C)
        & ring(C) )
     => ! [A3: C,B2: C,V: num] : aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,A3,B2)),aa(num,C,numeral_numeral(C),V)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),V)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),aa(num,C,numeral_numeral(C),V))) ) ).

% left_diff_distrib_numeral
tff(fact_1349_length__0__conv,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = zero_zero(nat) )
    <=> ( Xs = nil(C) ) ) ).

% length_0_conv
tff(fact_1350_power__add__numeral2,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C,M2: num,N: num,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),M2))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),N))),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),aa(num,num,aa(num,fun(num,num),plus_plus(num),M2),N)))),B2) ) ).

% power_add_numeral2
tff(fact_1351_power__add__numeral,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C,M2: num,N: num] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),M2))),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),N))) = aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),aa(num,num,aa(num,fun(num,num),plus_plus(num),M2),N))) ) ).

% power_add_numeral
tff(fact_1352_min__0__1_I6_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),ord_min(C),aa(num,C,numeral_numeral(C),X)),one_one(C)) = one_one(C) ) ).

% min_0_1(6)
tff(fact_1353_min__0__1_I5_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),ord_min(C),one_one(C)),aa(num,C,numeral_numeral(C),X)) = one_one(C) ) ).

% min_0_1(5)
tff(fact_1354_max__0__1_I6_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),ord_max(C),aa(num,C,numeral_numeral(C),X)),one_one(C)) = aa(num,C,numeral_numeral(C),X) ) ).

% max_0_1(6)
tff(fact_1355_max__0__1_I5_J,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),ord_max(C),one_one(C)),aa(num,C,numeral_numeral(C),X)) = aa(num,C,numeral_numeral(C),X) ) ).

% max_0_1(5)
tff(fact_1356_nth__Cons__Suc,axiom,
    ! [C: $tType,X: C,Xs: list(C),N: nat] : aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(nat,nat,suc,N)) = aa(nat,C,nth(C,Xs),N) ).

% nth_Cons_Suc
tff(fact_1357_length__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),nat,size_size(list(C)),Ys)) ).

% length_append
tff(fact_1358_sorted__list__of__set_Olength__sorted__key__list__of__set,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] : aa(list(C),nat,size_size(list(C)),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) = finite_card(C,A4) ) ).

% sorted_list_of_set.length_sorted_key_list_of_set
tff(fact_1359_slice__complete,axiom,
    ! [C: $tType,Xs: list(C)] : slice(C,zero_zero(nat),aa(list(C),nat,size_size(list(C)),Xs),Xs) = Xs ).

% slice_complete
tff(fact_1360_length__product,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),nat,size_size(list(product_prod(C,D))),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),Xs),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(D),nat,size_size(list(D)),Ys)) ).

% length_product
tff(fact_1361_length__greater__0__conv,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),aa(list(C),nat,size_size(list(C)),Xs))
    <=> ( Xs != nil(C) ) ) ).

% length_greater_0_conv
tff(fact_1362_length__concat__rev,axiom,
    ! [C: $tType,Xs: list(list(C))] : aa(list(C),nat,size_size(list(C)),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),rev(list(C)),Xs))) = aa(list(C),nat,size_size(list(C)),aa(list(list(C)),list(C),concat(C),Xs)) ).

% length_concat_rev
tff(fact_1363_nth__append__length,axiom,
    ! [C: $tType,Xs: list(C),X: C,Ys: list(C)] : aa(nat,C,nth(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys))),aa(list(C),nat,size_size(list(C)),Xs)) = X ).

% nth_append_length
tff(fact_1364_Suc__diff,axiom,
    ! [M2: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),M2)
       => ( aa(nat,nat,suc,minus_minus(nat,N,M2)) = minus_minus(nat,N,minus_minus(nat,M2,one_one(nat))) ) ) ) ).

% Suc_diff
tff(fact_1365_nth__map,axiom,
    ! [D: $tType,C: $tType,N: nat,Xs: list(C),F: fun(C,D)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,D,nth(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)),N) = aa(C,D,F,aa(nat,C,nth(C,Xs),N)) ) ) ).

% nth_map
tff(fact_1366_nth__append__first,axiom,
    ! [C: $tType,I: nat,La: list(C),L_a: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),La),L_a)),I) = aa(nat,C,nth(C,La),I) ) ) ).

% nth_append_first
tff(fact_1367_nth__append__length__plus,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),N: nat] : aa(nat,C,nth(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs)),N)) = aa(nat,C,nth(C,Ys),N) ).

% nth_append_length_plus
tff(fact_1368_length__butlast,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),butlast(C),Xs)) = minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat)) ).

% length_butlast
tff(fact_1369_rotate1__length01,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),one_one(nat))
     => ( aa(list(C),list(C),rotate1(C),Xs) = Xs ) ) ).

% rotate1_length01
tff(fact_1370_slice__len,axiom,
    ! [C: $tType,From: nat,To: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),From),To)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),To),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(list(C),nat,size_size(list(C)),slice(C,From,To,Xs)) = minus_minus(nat,To,From) ) ) ) ).

% slice_len
tff(fact_1371_length__ge__1__conv,axiom,
    ! [C: $tType,La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,suc,zero_zero(nat))),aa(list(C),nat,size_size(list(C)),La))
    <=> ( La != nil(C) ) ) ).

% length_ge_1_conv
tff(fact_1372_length__Cons,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(nat,nat,suc,aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_Cons
tff(fact_1373_Suc__length__conv,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( aa(nat,nat,suc,N) = aa(list(C),nat,size_size(list(C)),Xs) )
    <=> ? [Y3: C,Ys3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
          & ( aa(list(C),nat,size_size(list(C)),Ys3) = N ) ) ) ).

% Suc_length_conv
tff(fact_1374_length__Suc__conv,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(nat,nat,suc,N) )
    <=> ? [Y3: C,Ys3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
          & ( aa(list(C),nat,size_size(list(C)),Ys3) = N ) ) ) ).

% length_Suc_conv
tff(fact_1375_Ex__list__of__length,axiom,
    ! [C: $tType,N: nat] :
    ? [Xs2: list(C)] : aa(list(C),nat,size_size(list(C)),Xs2) = N ).

% Ex_list_of_length
tff(fact_1376_neq__if__length__neq,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) != aa(list(C),nat,size_size(list(C)),Ys) )
     => ( Xs != Ys ) ) ).

% neq_if_length_neq
tff(fact_1377_sorted__iff__nth__Suc,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
        <=> ! [I2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,I2)),aa(list(C),nat,size_size(list(C)),Xs))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),I2)),aa(nat,C,nth(C,Xs),aa(nat,nat,suc,I2))) ) ) ) ).

% sorted_iff_nth_Suc
tff(fact_1378_sorted__wrt__less__idx,axiom,
    ! [Ns: list(nat),I: nat] :
      ( sorted_wrt(nat,ord_less(nat),Ns)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(nat),nat,size_size(list(nat)),Ns))
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),aa(nat,nat,nth(nat,Ns),I)) ) ) ).

% sorted_wrt_less_idx
tff(fact_1379_sorted__wrt__nth__less,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C),I: nat,J: nat] :
      ( sorted_wrt(C,Pa,Xs)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
         => aa(C,$o,aa(C,fun(C,$o),Pa,aa(nat,C,nth(C,Xs),I)),aa(nat,C,nth(C,Xs),J)) ) ) ) ).

% sorted_wrt_nth_less
tff(fact_1380_sorted__wrt__iff__nth__less,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( sorted_wrt(C,Pa,Xs)
    <=> ! [I2: nat,J2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),J2)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),aa(list(C),nat,size_size(list(C)),Xs))
           => aa(C,$o,aa(C,fun(C,$o),Pa,aa(nat,C,nth(C,Xs),I2)),aa(nat,C,nth(C,Xs),J2)) ) ) ) ).

% sorted_wrt_iff_nth_less
tff(fact_1381_sorted__wrt01,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,fun(C,$o))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),one_one(nat))
     => sorted_wrt(C,Pa,Xs) ) ).

% sorted_wrt01
tff(fact_1382_Suc__le__length__iff,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,suc,N)),aa(list(C),nat,size_size(list(C)),Xs))
    <=> ? [X4: C,Ys3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Ys3) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(C),nat,size_size(list(C)),Ys3)) ) ) ).

% Suc_le_length_iff
tff(fact_1383_sorted__wrt_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o))] : sorted_wrt(C,Pa,nil(C)) ).

% sorted_wrt.simps(1)
tff(fact_1384_length__induct,axiom,
    ! [C: $tType,Pa: fun(list(C),$o),Xs: list(C)] :
      ( ! [Xs2: list(C)] :
          ( ! [Ys6: list(C)] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Ys6)),aa(list(C),nat,size_size(list(C)),Xs2))
             => aa(list(C),$o,Pa,Ys6) )
         => aa(list(C),$o,Pa,Xs2) )
     => aa(list(C),$o,Pa,Xs) ) ).

% length_induct
tff(fact_1385_finite__maxlen,axiom,
    ! [C: $tType,M: set(list(C))] :
      ( aa(set(list(C)),$o,finite_finite2(list(C)),M)
     => ? [N7: nat] :
        ! [X3: list(C)] :
          ( member2(list(C),X3,M)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),X3)),N7) ) ) ).

% finite_maxlen
tff(fact_1386_map__eq__imp__length__eq,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F: fun(D,C),Xs: list(D),G: fun(E2,C),Ys: list(E2)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),G),Ys) )
     => ( aa(list(D),nat,size_size(list(D)),Xs) = aa(list(E2),nat,size_size(list(E2)),Ys) ) ) ).

% map_eq_imp_length_eq
tff(fact_1387_sorted__rev__iff__nth__Suc,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),Xs))
        <=> ! [I2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,I2)),aa(list(C),nat,size_size(list(C)),Xs))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),aa(nat,nat,suc,I2))),aa(nat,C,nth(C,Xs),I2)) ) ) ) ).

% sorted_rev_iff_nth_Suc
tff(fact_1388_sorted__wrt__mergesort__by__rel,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] :
      ( ! [X2: C,Y2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
          | aa(C,$o,aa(C,fun(C,$o),R,Y2),X2) )
     => ( ! [X2: C,Y2: C,Z4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
           => ( aa(C,$o,aa(C,fun(C,$o),R,Y2),Z4)
             => aa(C,$o,aa(C,fun(C,$o),R,X2),Z4) ) )
       => sorted_wrt(C,R,aa(list(C),list(C),mergesort_by_rel(C,R),Xs)) ) ) ).

% sorted_wrt_mergesort_by_rel
tff(fact_1389_sorted__iff__nth__mono__less,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
        <=> ! [I2: nat,J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),J2)
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),aa(list(C),nat,size_size(list(C)),Xs))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),I2)),aa(nat,C,nth(C,Xs),J2)) ) ) ) ) ).

% sorted_iff_nth_mono_less
tff(fact_1390_sorted01,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),one_one(nat))
         => sorted_wrt(C,ord_less_eq(C),Xs) ) ) ).

% sorted01
tff(fact_1391_list_Osize_I4_J,axiom,
    ! [C: $tType,X21: C,X22: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),X22)),aa(nat,nat,suc,zero_zero(nat))) ).

% list.size(4)
tff(fact_1392_length__Suc__rev__conv,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(nat,nat,suc,N) )
    <=> ? [Ys3: list(C),Y3: C] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),nil(C))) )
          & ( aa(list(C),nat,size_size(list(C)),Ys3) = N ) ) ) ).

% length_Suc_rev_conv
tff(fact_1393_length__Suc__conv__rev,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(nat,nat,suc,N) )
    <=> ? [Y3: C,Ys3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),nil(C))) )
          & ( aa(list(C),nat,size_size(list(C)),Ys3) = N ) ) ) ).

% length_Suc_conv_rev
tff(fact_1394_length__append__singleton,axiom,
    ! [C: $tType,Xs: list(C),X: C] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)))) = aa(nat,nat,suc,aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_append_singleton
tff(fact_1395_strict__sorted__imp__sorted,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),Xs) ) ) ).

% strict_sorted_imp_sorted
tff(fact_1396_sorted__nth__mono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),I: nat,J: nat] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),I)),aa(nat,C,nth(C,Xs),J)) ) ) ) ) ).

% sorted_nth_mono
tff(fact_1397_sorted__iff__nth__mono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
        <=> ! [I2: nat,J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I2),J2)
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),aa(list(C),nat,size_size(list(C)),Xs))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),I2)),aa(nat,C,nth(C,Xs),J2)) ) ) ) ) ).

% sorted_iff_nth_mono
tff(fact_1398_sorted2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C,Zs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
            & sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)) ) ) ) ).

% sorted2
tff(fact_1399_sorted0,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => sorted_wrt(C,ord_less_eq(C),nil(C)) ) ).

% sorted0
tff(fact_1400_strict__sorted__simps_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => sorted_wrt(C,ord_less(C),nil(C)) ) ).

% strict_sorted_simps(1)
tff(fact_1401_sorted__wrt1,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),X: C] : sorted_wrt(C,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% sorted_wrt1
tff(fact_1402_sorted__remove1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),A3: C] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),A3),Xs)) ) ) ).

% sorted_remove1
tff(fact_1403_sorted__list__of__set_Osorted__sorted__key__list__of__set,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] : sorted_wrt(C,ord_less_eq(C),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) ) ).

% sorted_list_of_set.sorted_sorted_key_list_of_set
tff(fact_1404_sorted__list__of__set_Ostrict__sorted__key__list__of__set,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] : sorted_wrt(C,ord_less(C),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) ) ).

% sorted_list_of_set.strict_sorted_key_list_of_set
tff(fact_1405_rev__nth,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),rev(C),Xs)),N) = aa(nat,C,nth(C,Xs),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),aa(nat,nat,suc,N))) ) ) ).

% rev_nth
tff(fact_1406_sorted__mergesort__by__rel,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),mergesort_by_rel(C,ord_less_eq(C)),Xs)) ) ).

% sorted_mergesort_by_rel
tff(fact_1407_list__induct4,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,Xs: list(C),Ys: list(D),Zs: list(E2),Ws2: list(F4),Pa: fun(list(C),fun(list(D),fun(list(E2),fun(list(F4),$o))))] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( ( aa(list(D),nat,size_size(list(D)),Ys) = aa(list(E2),nat,size_size(list(E2)),Zs) )
       => ( ( aa(list(E2),nat,size_size(list(E2)),Zs) = aa(list(F4),nat,size_size(list(F4)),Ws2) )
         => ( aa(list(F4),$o,aa(list(E2),fun(list(F4),$o),aa(list(D),fun(list(E2),fun(list(F4),$o)),aa(list(C),fun(list(D),fun(list(E2),fun(list(F4),$o))),Pa,nil(C)),nil(D)),nil(E2)),nil(F4))
           => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D),Z4: E2,Zs3: list(E2),W3: F4,Ws3: list(F4)] :
                  ( ( aa(list(C),nat,size_size(list(C)),Xs2) = aa(list(D),nat,size_size(list(D)),Ys2) )
                 => ( ( aa(list(D),nat,size_size(list(D)),Ys2) = aa(list(E2),nat,size_size(list(E2)),Zs3) )
                   => ( ( aa(list(E2),nat,size_size(list(E2)),Zs3) = aa(list(F4),nat,size_size(list(F4)),Ws3) )
                     => ( aa(list(F4),$o,aa(list(E2),fun(list(F4),$o),aa(list(D),fun(list(E2),fun(list(F4),$o)),aa(list(C),fun(list(D),fun(list(E2),fun(list(F4),$o))),Pa,Xs2),Ys2),Zs3),Ws3)
                       => aa(list(F4),$o,aa(list(E2),fun(list(F4),$o),aa(list(D),fun(list(E2),fun(list(F4),$o)),aa(list(C),fun(list(D),fun(list(E2),fun(list(F4),$o))),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),Z4),Zs3)),aa(list(F4),list(F4),aa(F4,fun(list(F4),list(F4)),cons(F4),W3),Ws3)) ) ) ) )
             => aa(list(F4),$o,aa(list(E2),fun(list(F4),$o),aa(list(D),fun(list(E2),fun(list(F4),$o)),aa(list(C),fun(list(D),fun(list(E2),fun(list(F4),$o))),Pa,Xs),Ys),Zs),Ws2) ) ) ) ) ) ).

% list_induct4
tff(fact_1408_list__induct3,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Xs: list(C),Ys: list(D),Zs: list(E2),Pa: fun(list(C),fun(list(D),fun(list(E2),$o)))] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( ( aa(list(D),nat,size_size(list(D)),Ys) = aa(list(E2),nat,size_size(list(E2)),Zs) )
       => ( aa(list(E2),$o,aa(list(D),fun(list(E2),$o),aa(list(C),fun(list(D),fun(list(E2),$o)),Pa,nil(C)),nil(D)),nil(E2))
         => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D),Z4: E2,Zs3: list(E2)] :
                ( ( aa(list(C),nat,size_size(list(C)),Xs2) = aa(list(D),nat,size_size(list(D)),Ys2) )
               => ( ( aa(list(D),nat,size_size(list(D)),Ys2) = aa(list(E2),nat,size_size(list(E2)),Zs3) )
                 => ( aa(list(E2),$o,aa(list(D),fun(list(E2),$o),aa(list(C),fun(list(D),fun(list(E2),$o)),Pa,Xs2),Ys2),Zs3)
                   => aa(list(E2),$o,aa(list(D),fun(list(E2),$o),aa(list(C),fun(list(D),fun(list(E2),$o)),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),Z4),Zs3)) ) ) )
           => aa(list(E2),$o,aa(list(D),fun(list(E2),$o),aa(list(C),fun(list(D),fun(list(E2),$o)),Pa,Xs),Ys),Zs) ) ) ) ) ).

% list_induct3
tff(fact_1409_list__induct2,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Pa: fun(list(C),fun(list(D),$o))] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,nil(C)),nil(D))
       => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
              ( ( aa(list(C),nat,size_size(list(C)),Xs2) = aa(list(D),nat,size_size(list(D)),Ys2) )
             => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs2),Ys2)
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)) ) )
         => aa(list(D),$o,aa(list(C),fun(list(D),$o),Pa,Xs),Ys) ) ) ) ).

% list_induct2
tff(fact_1410_one__le__numeral,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [N: num] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(num,C,numeral_numeral(C),N)) ) ).

% one_le_numeral
tff(fact_1411_list_Osize_I3_J,axiom,
    ! [C: $tType] : aa(list(C),nat,size_size(list(C)),nil(C)) = zero_zero(nat) ).

% list.size(3)
tff(fact_1412_not__numeral__less__one,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [N: num] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(num,C,numeral_numeral(C),N)),one_one(C)) ) ).

% not_numeral_less_one
tff(fact_1413_len__greater__imp__nonempty,axiom,
    ! [C: $tType,X: nat,La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X),aa(list(C),nat,size_size(list(C)),La))
     => ( La != nil(C) ) ) ).

% len_greater_imp_nonempty
tff(fact_1414_one__plus__numeral__commute,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(num,C,numeral_numeral(C),X)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),X)),one_one(C)) ) ).

% one_plus_numeral_commute
tff(fact_1415_impossible__Cons,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),nat,size_size(list(C)),Ys))
     => ( Xs != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys) ) ) ).

% impossible_Cons
tff(fact_1416_power__Suc,axiom,
    ! [C: $tType] :
      ( power(C)
     => ! [A3: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ).

% power_Suc
tff(fact_1417_power__Suc2,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),A3) ) ).

% power_Suc2
tff(fact_1418_list__rest__coinc,axiom,
    ! [C: $tType,S22: list(C),S1: list(C),R1: list(C),R2: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),S22)),aa(list(C),nat,size_size(list(C)),S1))
     => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),S1),R1) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),S22),R2) )
       => ? [R1p: list(C)] : R2 = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),R1p),R1) ) ) ).

% list_rest_coinc
tff(fact_1419_nat__compl__induct_H,axiom,
    ! [Pa: fun(nat,$o),N: nat] :
      ( aa(nat,$o,Pa,zero_zero(nat))
     => ( ! [N7: nat] :
            ( ! [Nn: nat] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Nn),N7)
               => aa(nat,$o,Pa,Nn) )
           => aa(nat,$o,Pa,aa(nat,nat,suc,N7)) )
       => aa(nat,$o,Pa,N) ) ) ).

% nat_compl_induct'
tff(fact_1420_nat__compl__induct,axiom,
    ! [Pa: fun(nat,$o),N: nat] :
      ( aa(nat,$o,Pa,zero_zero(nat))
     => ( ! [N7: nat] :
            ( ! [Nn: nat] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Nn),N7)
               => aa(nat,$o,Pa,Nn) )
           => aa(nat,$o,Pa,aa(nat,nat,suc,N7)) )
       => aa(nat,$o,Pa,N) ) ) ).

% nat_compl_induct
tff(fact_1421_nth__equalityI,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Xs))
           => ( aa(nat,C,nth(C,Xs),I3) = aa(nat,C,nth(C,Ys),I3) ) )
       => ( Xs = Ys ) ) ) ).

% nth_equalityI
tff(fact_1422_Skolem__list__nth,axiom,
    ! [C: $tType,K: nat,Pa: fun(nat,fun(C,$o))] :
      ( ! [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),K)
         => ? [X_12: C] : aa(C,$o,aa(nat,fun(C,$o),Pa,I2),X_12) )
    <=> ? [Xs3: list(C)] :
          ( ( aa(list(C),nat,size_size(list(C)),Xs3) = K )
          & ! [I2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),K)
             => aa(C,$o,aa(nat,fun(C,$o),Pa,I2),aa(nat,C,nth(C,Xs3),I2)) ) ) ) ).

% Skolem_list_nth
tff(fact_1423_list__eq__iff__nth__eq,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs = Ys )
    <=> ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) )
        & ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
           => ( aa(nat,C,nth(C,Xs),I2) = aa(nat,C,nth(C,Ys),I2) ) ) ) ) ).

% list_eq_iff_nth_eq
tff(fact_1424_obtain__list__from__elements,axiom,
    ! [C: $tType,N: nat,Pa: fun(C,fun(nat,$o))] :
      ( ! [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),N)
         => ? [Li: C] : aa(nat,$o,aa(C,fun(nat,$o),Pa,Li),I3) )
     => ~ ! [L: list(C)] :
            ( ( aa(list(C),nat,size_size(list(C)),L) = N )
           => ~ ! [I4: nat] :
                  ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I4),N)
                 => aa(nat,$o,aa(C,fun(nat,$o),Pa,aa(nat,C,nth(C,L),I4)),I4) ) ) ) ).

% obtain_list_from_elements
tff(fact_1425_nat__in__between__eq_I1_J,axiom,
    ! [A3: nat,B2: nat] :
      ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),B2),aa(nat,nat,suc,A3)) )
    <=> ( B2 = aa(nat,nat,suc,A3) ) ) ).

% nat_in_between_eq(1)
tff(fact_1426_nat__in__between__eq_I2_J,axiom,
    ! [A3: nat,B2: nat] :
      ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),B2)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),aa(nat,nat,suc,A3)) )
    <=> ( B2 = A3 ) ) ).

% nat_in_between_eq(2)
tff(fact_1427_Suc__to__right,axiom,
    ! [N: nat,M2: nat] :
      ( ( aa(nat,nat,suc,N) = M2 )
     => ( N = minus_minus(nat,M2,aa(nat,nat,suc,zero_zero(nat))) ) ) ).

% Suc_to_right
tff(fact_1428_sorted__rev__nth__mono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),I: nat,J: nat] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),Xs))
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),J)),aa(nat,C,nth(C,Xs),I)) ) ) ) ) ).

% sorted_rev_nth_mono
tff(fact_1429_sorted__rev__iff__nth__mono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),Xs))
        <=> ! [I2: nat,J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I2),J2)
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),aa(list(C),nat,size_size(list(C)),Xs))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,Xs),J2)),aa(nat,C,nth(C,Xs),I2)) ) ) ) ) ).

% sorted_rev_iff_nth_mono
tff(fact_1430_count__le__length,axiom,
    ! [C: $tType,Xs: list(C),X: C] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(C,nat,count_list(C,Xs),X)),aa(list(C),nat,size_size(list(C)),Xs)) ).

% count_le_length
tff(fact_1431_sorted1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C] : sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ) ).

% sorted1
tff(fact_1432_length__code,axiom,
    ! [C: $tType] : size_size(list(C)) = gen_length(C,zero_zero(nat)) ).

% length_code
tff(fact_1433_gen__length__def,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),nat,gen_length(C,N),Xs) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(C),nat,size_size(list(C)),Xs)) ).

% gen_length_def
tff(fact_1434_gen__length__code_I2_J,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : aa(list(C),nat,gen_length(C,N),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),nat,gen_length(C,aa(nat,nat,suc,N)),Xs) ).

% gen_length_code(2)
tff(fact_1435_sorted__butlast,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( ( Xs != nil(C) )
         => ( sorted_wrt(C,ord_less_eq(C),Xs)
           => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),butlast(C),Xs)) ) ) ) ).

% sorted_butlast
tff(fact_1436_sorted__map__remove1,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D),X: D] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
         => sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),remove1(D),X),Xs))) ) ) ).

% sorted_map_remove1
tff(fact_1437_length__compl__induct,axiom,
    ! [C: $tType,Pa: fun(list(C),$o),La: list(C)] :
      ( aa(list(C),$o,Pa,nil(C))
     => ( ! [E: C,L: list(C)] :
            ( ! [Ll2: list(C)] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Ll2)),aa(list(C),nat,size_size(list(C)),L))
               => aa(list(C),$o,Pa,Ll2) )
           => aa(list(C),$o,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E),L)) )
       => aa(list(C),$o,Pa,La) ) ) ).

% length_compl_induct
tff(fact_1438_same__length__different,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs != Ys )
     => ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) )
       => ? [Pre: list(C),X2: C,Xs4: list(C),Y2: C,Ys4: list(C)] :
            ( ( X2 != Y2 )
            & ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Pre),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))),Xs4)) )
            & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Pre),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),nil(C))),Ys4)) ) ) ) ) ).

% same_length_different
tff(fact_1439_power__gt1,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,suc,N))) ) ) ).

% power_gt1
tff(fact_1440_list__decomp__1,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),La) = one_one(nat) )
     => ? [A5: C] : La = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),nil(C)) ) ).

% list_decomp_1
tff(fact_1441_gbinomial__Suc__Suc,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),aa(nat,nat,suc,K)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,gbinomial(C,A3),K)),aa(nat,C,gbinomial(C,A3),aa(nat,nat,suc,K))) ) ).

% gbinomial_Suc_Suc
tff(fact_1442_nth__butlast,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),butlast(C),Xs)))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),butlast(C),Xs)),N) = aa(nat,C,nth(C,Xs),N) ) ) ).

% nth_butlast
tff(fact_1443_sorted__in__between,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [I: nat,J: nat,La: list(C),X: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),zero_zero(nat)),I)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),La))
             => ( sorted_wrt(C,ord_less_eq(C),La)
               => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,La),I)),X)
                 => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(nat,C,nth(C,La),J))
                   => ~ ! [K2: nat] :
                          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),K2)
                         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K2),J)
                           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,La),K2)),X)
                             => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(nat,C,nth(C,La),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K2),one_one(nat)))) ) ) ) ) ) ) ) ) ) ) ).

% sorted_in_between
tff(fact_1444_power__Suc__le__self,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,suc,N))),A3) ) ) ) ).

% power_Suc_le_self
tff(fact_1445_power__Suc__less__one,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [A3: C,N: nat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,suc,N))),one_one(C)) ) ) ) ).

% power_Suc_less_one
tff(fact_1446_length__compl__rev__induct,axiom,
    ! [C: $tType,Pa: fun(list(C),$o),La: list(C)] :
      ( aa(list(C),$o,Pa,nil(C))
     => ( ! [L: list(C),E: C] :
            ( ! [Ll2: list(C)] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Ll2)),aa(list(C),nat,size_size(list(C)),L))
               => aa(list(C),$o,Pa,Ll2) )
           => aa(list(C),$o,Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E),nil(C)))) )
       => aa(list(C),$o,Pa,La) ) ) ).

% length_compl_rev_induct
tff(fact_1447_card__Suc__eq,axiom,
    ! [C: $tType,A4: set(C),K: nat] :
      ( ( finite_card(C,A4) = aa(nat,nat,suc,K) )
    <=> ? [B5: C,B9: set(C)] :
          ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B5),B9) )
          & ~ member2(C,B5,B9)
          & ( finite_card(C,B9) = K )
          & ( ( K = zero_zero(nat) )
           => ( B9 = bot_bot(set(C)) ) ) ) ) ).

% card_Suc_eq
tff(fact_1448_card__eq__SucD,axiom,
    ! [C: $tType,A4: set(C),K: nat] :
      ( ( finite_card(C,A4) = aa(nat,nat,suc,K) )
     => ? [B4: C,B6: set(C)] :
          ( ( A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B4),B6) )
          & ~ member2(C,B4,B6)
          & ( finite_card(C,B6) = K )
          & ( ( K = zero_zero(nat) )
           => ( B6 = bot_bot(set(C)) ) ) ) ) ).

% card_eq_SucD
tff(fact_1449_card__1__singleton__iff,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ( finite_card(C,A4) = aa(nat,nat,suc,zero_zero(nat)) )
    <=> ? [X4: C] : A4 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),bot_bot(set(C))) ) ).

% card_1_singleton_iff
tff(fact_1450_nth__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),N: nat] :
      aa(nat,C,nth(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),N) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs)),aa(nat,C,nth(C,Xs),N),aa(nat,C,nth(C,Ys),minus_minus(nat,N,aa(list(C),nat,size_size(list(C)),Xs)))) ).

% nth_append
tff(fact_1451_nz__le__conv__less,axiom,
    ! [K: nat,M2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),M2)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),minus_minus(nat,K,aa(nat,nat,suc,zero_zero(nat)))),M2) ) ) ).

% nz_le_conv_less
tff(fact_1452_gbinomial__addition__formula,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,A3),aa(nat,nat,suc,K)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),aa(nat,nat,suc,K))),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),K)) ) ).

% gbinomial_addition_formula
tff(fact_1453_Suc__n__minus__m__eq,axiom,
    ! [M2: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),M2)
       => ( aa(nat,nat,suc,minus_minus(nat,N,M2)) = minus_minus(nat,N,minus_minus(nat,M2,one_one(nat))) ) ) ) ).

% Suc_n_minus_m_eq
tff(fact_1454_length__product__lists,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(list(C)),nat,size_size(list(list(C))),aa(list(list(C)),list(list(C)),product_lists(C),Xss2)) = aa(nat,nat,aa(list(nat),fun(nat,nat),aa(fun(nat,fun(nat,nat)),fun(list(nat),fun(nat,nat)),foldr(nat,nat),times_times(nat)),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),Xss2)),one_one(nat)) ).

% length_product_lists
tff(fact_1455_drop__last__conv,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( La != nil(C) )
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),La),aa(nat,nat,suc,zero_zero(nat)))),La) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),last(C,La)),nil(C)) ) ) ).

% drop_last_conv
tff(fact_1456_last__take__nth__conv,axiom,
    ! [C: $tType,N: nat,La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(C),nat,size_size(list(C)),La))
     => ( ( N != zero_zero(nat) )
       => ( last(C,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),La)) = aa(nat,C,nth(C,La),minus_minus(nat,N,one_one(nat))) ) ) ) ).

% last_take_nth_conv
tff(fact_1457_take__Suc__conv__app__nth,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,suc,I)),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(nat,C,nth(C,Xs),I)),nil(C))) ) ) ).

% take_Suc_conv_app_nth
tff(fact_1458_sorted__list__of__set_Osorted__key__list__of__set__unique,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),La: list(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( sorted_wrt(C,ord_less(C),La)
              & ( aa(list(C),set(C),set2(C),La) = A4 )
              & ( aa(list(C),nat,size_size(list(C)),La) = finite_card(C,A4) ) )
          <=> ( aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = La ) ) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_unique
tff(fact_1459_enumerate__Suc_H,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [S: set(C),N: nat] : infini527867602293511546merate(C,S,aa(nat,nat,suc,N)) = infini527867602293511546merate(C,minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),infini527867602293511546merate(C,S,zero_zero(nat))),bot_bot(set(C)))),N) ) ).

% enumerate_Suc'
tff(fact_1460_distinct__sorted__mono__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),I: nat,J: nat] :
          ( aa(list(C),$o,distinct(C),La)
         => ( sorted_wrt(C,ord_less_eq(C),La)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),La))
               => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,nth(C,La),I)),aa(nat,C,nth(C,La),J))
                <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J) ) ) ) ) ) ) ).

% distinct_sorted_mono_iff
tff(fact_1461_take__minus__one__conv__butlast,axiom,
    ! [C: $tType,N: nat,La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,N,aa(nat,nat,suc,zero_zero(nat)))),La) = aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),La)) ) ) ).

% take_minus_one_conv_butlast
tff(fact_1462_List_Ofinite__set,axiom,
    ! [C: $tType,Xs: list(C)] : aa(set(C),$o,finite_finite2(C),aa(list(C),set(C),set2(C),Xs)) ).

% List.finite_set
tff(fact_1463_map__eq__conv,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),G: fun(D,C)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),Xs) )
    <=> ! [X4: D] :
          ( member2(D,X4,aa(list(D),set(D),set2(D),Xs))
         => ( aa(D,C,F,X4) = aa(D,C,G,X4) ) ) ) ).

% map_eq_conv
tff(fact_1464_drop0,axiom,
    ! [C: $tType,X3: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),zero_zero(nat)),X3) = X3 ).

% drop0
tff(fact_1465_set__rev,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% set_rev
tff(fact_1466_drop__drop,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M2)),Xs) ).

% drop_drop
tff(fact_1467_Nil__eq__concat__conv,axiom,
    ! [C: $tType,Xss2: list(list(C))] :
      ( ( nil(C) = aa(list(list(C)),list(C),concat(C),Xss2) )
    <=> ! [X4: list(C)] :
          ( member2(list(C),X4,aa(list(list(C)),set(list(C)),set2(list(C)),Xss2))
         => ( X4 = nil(C) ) ) ) ).

% Nil_eq_concat_conv
tff(fact_1468_concat__eq__Nil__conv,axiom,
    ! [C: $tType,Xss2: list(list(C))] :
      ( ( aa(list(list(C)),list(C),concat(C),Xss2) = nil(C) )
    <=> ! [X4: list(C)] :
          ( member2(list(C),X4,aa(list(list(C)),set(list(C)),set2(list(C)),Xss2))
         => ( X4 = nil(C) ) ) ) ).

% concat_eq_Nil_conv
tff(fact_1469_distinct__rev,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),rev(C),Xs))
    <=> aa(list(C),$o,distinct(C),Xs) ) ).

% distinct_rev
tff(fact_1470_in__set__remove1,axiom,
    ! [C: $tType,A3: C,B2: C,Xs: list(C)] :
      ( ( A3 != B2 )
     => ( member2(C,A3,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),B2),Xs)))
      <=> member2(C,A3,aa(list(C),set(C),set2(C),Xs)) ) ) ).

% in_set_remove1
tff(fact_1471_set__mergesort__by__rel,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),mergesort_by_rel(C,R),Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% set_mergesort_by_rel
tff(fact_1472_take__take,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),M2),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),N),M2)),Xs) ).

% take_take
tff(fact_1473_set__rotate1,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),rotate1(C),Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% set_rotate1
tff(fact_1474_distinct1__rotate,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),rotate1(C),Xs))
    <=> aa(list(C),$o,distinct(C),Xs) ) ).

% distinct1_rotate
tff(fact_1475_in__set__insert,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs) = Xs ) ) ).

% in_set_insert
tff(fact_1476_distinct__insert,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs))
    <=> aa(list(C),$o,distinct(C),Xs) ) ).

% distinct_insert
tff(fact_1477_set__empty,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),set(C),set2(C),Xs) = bot_bot(set(C)) )
    <=> ( Xs = nil(C) ) ) ).

% set_empty
tff(fact_1478_set__empty2,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( bot_bot(set(C)) = aa(list(C),set(C),set2(C),Xs) )
    <=> ( Xs = nil(C) ) ) ).

% set_empty2
tff(fact_1479_list_Osimps_I15_J,axiom,
    ! [C: $tType,X21: C,X22: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X21),aa(list(C),set(C),set2(C),X22)) ).

% list.simps(15)
tff(fact_1480_take__Suc__Cons,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,suc,N)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) ).

% take_Suc_Cons
tff(fact_1481_take__eq__Nil2,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) )
    <=> ( ( N = zero_zero(nat) )
        | ( Xs = nil(C) ) ) ) ).

% take_eq_Nil2
tff(fact_1482_take__eq__Nil,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) = nil(C) )
    <=> ( ( N = zero_zero(nat) )
        | ( Xs = nil(C) ) ) ) ).

% take_eq_Nil
tff(fact_1483_take0,axiom,
    ! [C: $tType,X3: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),zero_zero(nat)),X3) = nil(C) ).

% take0
tff(fact_1484_drop__Suc__Cons,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,N)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) ).

% drop_Suc_Cons
tff(fact_1485_take__all,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),N)
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) = Xs ) ) ).

% take_all
tff(fact_1486_take__all__iff,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) = Xs )
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),N) ) ).

% take_all_iff
tff(fact_1487_nth__take,axiom,
    ! [C: $tType,I: nat,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),N)
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)),I) = aa(nat,C,nth(C,Xs),I) ) ) ).

% nth_take
tff(fact_1488_length__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) = minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),N) ).

% length_drop
tff(fact_1489_List_Olast__in__set,axiom,
    ! [C: $tType,As2: list(C)] :
      ( ( As2 != nil(C) )
     => member2(C,last(C,As2),aa(list(C),set(C),set2(C),As2)) ) ).

% List.last_in_set
tff(fact_1490_Misc_Olast__in__set,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( La != nil(C) )
     => member2(C,last(C,La),aa(list(C),set(C),set2(C),La)) ) ).

% Misc.last_in_set
tff(fact_1491_sorted__list__of__set_Oset__sorted__key__list__of__set,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(list(C),set(C),set2(C),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) = A4 ) ) ) ).

% sorted_list_of_set.set_sorted_key_list_of_set
tff(fact_1492_append__take__drop__id,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) = Xs ).

% append_take_drop_id
tff(fact_1493_length__take,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) = aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(C),nat,size_size(list(C)),Xs)),N) ).

% length_take
tff(fact_1494_not__in__set__insert,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) ) ) ).

% not_in_set_insert
tff(fact_1495_List_Oset__insert,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(list(C),set(C),set2(C),Xs)) ).

% List.set_insert
tff(fact_1496_count__notin,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(C,nat,count_list(C,Xs),X) = zero_zero(nat) ) ) ).

% count_notin
tff(fact_1497_drop__eq__Nil2,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) )
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),N) ) ).

% drop_eq_Nil2
tff(fact_1498_drop__eq__Nil,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) = nil(C) )
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),N) ) ).

% drop_eq_Nil
tff(fact_1499_drop__all,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),N)
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) = nil(C) ) ) ).

% drop_all
tff(fact_1500_take__append,axiom,
    ! [C: $tType,N: nat,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,N,aa(list(C),nat,size_size(list(C)),Xs))),Ys)) ).

% take_append
tff(fact_1501_drop__append,axiom,
    ! [C: $tType,N: nat,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),minus_minus(nat,N,aa(list(C),nat,size_size(list(C)),Xs))),Ys)) ).

% drop_append
tff(fact_1502_last__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( last(C,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) = last(C,Xs) ) ) ).

% last_drop
tff(fact_1503_distinct__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( aa(list(C),$o,distinct(C),Xs)
        & aa(list(C),$o,distinct(C),Ys)
        & ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) ) ) ) ).

% distinct_append
tff(fact_1504_take__Cons__numeral,axiom,
    ! [C: $tType,V: num,X: C,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(num,nat,numeral_numeral(nat),V)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(num,nat,numeral_numeral(nat),V),one_one(nat))),Xs)) ).

% take_Cons_numeral
tff(fact_1505_drop__Cons__numeral,axiom,
    ! [C: $tType,V: num,X: C,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(num,nat,numeral_numeral(nat),V)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),minus_minus(nat,aa(num,nat,numeral_numeral(nat),V),one_one(nat))),Xs) ).

% drop_Cons_numeral
tff(fact_1506_nth__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C),I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)),I) = aa(nat,C,nth(C,Xs),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),I)) ) ) ).

% nth_drop
tff(fact_1507_take__butlast__conv,axiom,
    ! [C: $tType,La: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),La),aa(nat,nat,suc,zero_zero(nat)))),La) = aa(list(C),list(C),butlast(C),La) ).

% take_butlast_conv
tff(fact_1508_set__remove1__eq,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)) = minus_minus(set(C),aa(list(C),set(C),set2(C),Xs),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ) ) ).

% set_remove1_eq
tff(fact_1509_take__drop,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M2)),Xs)) ).

% take_drop
tff(fact_1510_drop__take,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),M2),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,M2,N)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) ).

% drop_take
tff(fact_1511_subseqs__distinctD,axiom,
    ! [C: $tType,Ys: list(C),Xs: list(C)] :
      ( member2(list(C),Ys,aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(C),list(list(C)),subseqs(C),Xs)))
     => ( aa(list(C),$o,distinct(C),Xs)
       => aa(list(C),$o,distinct(C),Ys) ) ) ).

% subseqs_distinctD
tff(fact_1512_distinct__product,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(D),$o,distinct(D),Ys)
       => aa(list(product_prod(C,D)),$o,distinct(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),Xs),Ys)) ) ) ).

% distinct_product
tff(fact_1513_distinct__concat,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( aa(list(list(C)),$o,distinct(list(C)),Xs)
     => ( ! [Ys2: list(C)] :
            ( member2(list(C),Ys2,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
           => aa(list(C),$o,distinct(C),Ys2) )
       => ( ! [Ys2: list(C),Zs3: list(C)] :
              ( member2(list(C),Ys2,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
             => ( member2(list(C),Zs3,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
               => ( ( Ys2 != Zs3 )
                 => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Ys2)),aa(list(C),set(C),set2(C),Zs3)) = bot_bot(set(C)) ) ) ) )
         => aa(list(C),$o,distinct(C),aa(list(list(C)),list(C),concat(C),Xs)) ) ) ) ).

% distinct_concat
tff(fact_1514_distinct__map__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),La: list(D),X: D,Y: D] :
      ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),La))
     => ( ( aa(D,C,F,X) = aa(D,C,F,Y) )
       => ( member2(D,X,aa(list(D),set(D),set2(D),La))
         => ( member2(D,Y,aa(list(D),set(D),set2(D),La))
           => ( X = Y ) ) ) ) ) ).

% distinct_map_eq
tff(fact_1515_distinct_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
        & aa(list(C),$o,distinct(C),Xs) ) ) ).

% distinct.simps(2)
tff(fact_1516_finite__distinct__list,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ? [Xs2: list(C)] :
          ( ( aa(list(C),set(C),set2(C),Xs2) = A4 )
          & aa(list(C),$o,distinct(C),Xs2) ) ) ).

% finite_distinct_list
tff(fact_1517_take__equalityI,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ! [I3: nat] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I3),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I3),Ys)
     => ( Xs = Ys ) ) ).

% take_equalityI
tff(fact_1518_distinct__take,axiom,
    ! [C: $tType,Xs: list(C),I: nat] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Xs)) ) ).

% distinct_take
tff(fact_1519_distinct__drop,axiom,
    ! [C: $tType,Xs: list(C),I: nat] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),Xs)) ) ).

% distinct_drop
tff(fact_1520_in__set__takeD,axiom,
    ! [C: $tType,X: C,N: nat,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% in_set_takeD
tff(fact_1521_in__set__dropD,axiom,
    ! [C: $tType,X: C,N: nat,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% in_set_dropD
tff(fact_1522_sorted__list__of__set_Odistinct__if__distinct__map,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( aa(list(C),$o,distinct(C),Xs)
         => aa(list(C),$o,distinct(C),Xs) ) ) ).

% sorted_list_of_set.distinct_if_distinct_map
tff(fact_1523_distinct__product__lists,axiom,
    ! [C: $tType,Xss2: list(list(C))] :
      ( ! [X2: list(C)] :
          ( member2(list(C),X2,aa(list(list(C)),set(list(C)),set2(list(C)),Xss2))
         => aa(list(C),$o,distinct(C),X2) )
     => aa(list(list(C)),$o,distinct(list(C)),aa(list(list(C)),list(list(C)),product_lists(C),Xss2)) ) ).

% distinct_product_lists
tff(fact_1524_distinct__set__subseqs,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(set(C)),$o,distinct(set(C)),aa(list(list(C)),list(set(C)),aa(fun(list(C),set(C)),fun(list(list(C)),list(set(C))),map(list(C),set(C)),set2(C)),aa(list(C),list(list(C)),subseqs(C),Xs))) ) ).

% distinct_set_subseqs
tff(fact_1525_set__drop__subset,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs))),aa(list(C),set(C),set2(C),Xs)) ).

% set_drop_subset
tff(fact_1526_set__take__subset,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs))),aa(list(C),set(C),set2(C),Xs)) ).

% set_take_subset
tff(fact_1527_set__take__disj__set__drop__if__distinct,axiom,
    ! [C: $tType,Vs: list(C),I: nat,J: nat] :
      ( aa(list(C),$o,distinct(C),Vs)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
       => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Vs))),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),J),Vs))) = bot_bot(set(C)) ) ) ) ).

% set_take_disj_set_drop_if_distinct
tff(fact_1528_append__eq__conv__conj,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = Zs )
    <=> ( ( Xs = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(list(C),nat,size_size(list(C)),Xs)),Zs) )
        & ( Ys = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(list(C),nat,size_size(list(C)),Xs)),Zs) ) ) ) ).

% append_eq_conv_conj
tff(fact_1529_drop__take__drop__unsplit,axiom,
    ! [C: $tType,I: nat,J: nat,La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),J),La))),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),J),La)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),La) ) ) ).

% drop_take_drop_unsplit
tff(fact_1530_take__add,axiom,
    ! [C: $tType,I: nat,J: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J)),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Xs)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),J),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),Xs))) ).

% take_add
tff(fact_1531_set__take__subset__set__take,axiom,
    ! [C: $tType,M2: nat,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),M2),Xs))),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs))) ) ).

% set_take_subset_set_take
tff(fact_1532_set__drop__subset__set__drop,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M2)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),Xs))),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs))) ) ).

% set_drop_subset_set_drop
tff(fact_1533_not__distinct__conv__prefix,axiom,
    ! [C: $tType,As2: list(C)] :
      ( ~ aa(list(C),$o,distinct(C),As2)
    <=> ? [Xs3: list(C),Y3: C,Ys3: list(C)] :
          ( member2(C,Y3,aa(list(C),set(C),set2(C),Xs3))
          & aa(list(C),$o,distinct(C),Xs3)
          & ( As2 = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3)) ) ) ) ).

% not_distinct_conv_prefix
tff(fact_1534_distinct__length__le,axiom,
    ! [C: $tType,Ys: list(C),Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Ys)
     => ( ( aa(list(C),set(C),set2(C),Ys) = aa(list(C),set(C),set2(C),Xs) )
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Ys)),aa(list(C),nat,size_size(list(C)),Xs)) ) ) ).

% distinct_length_le
tff(fact_1535_sorted__distinct__set__unique,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( aa(list(C),$o,distinct(C),Xs)
           => ( sorted_wrt(C,ord_less_eq(C),Ys)
             => ( aa(list(C),$o,distinct(C),Ys)
               => ( ( aa(list(C),set(C),set2(C),Xs) = aa(list(C),set(C),set2(C),Ys) )
                 => ( Xs = Ys ) ) ) ) ) ) ) ).

% sorted_distinct_set_unique
tff(fact_1536_card__distinct,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( finite_card(C,aa(list(C),set(C),set2(C),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) )
     => aa(list(C),$o,distinct(C),Xs) ) ).

% card_distinct
tff(fact_1537_distinct__card,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( finite_card(C,aa(list(C),set(C),set2(C),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) ) ) ).

% distinct_card
tff(fact_1538_take__Nil,axiom,
    ! [C: $tType,N: nat] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),nil(C)) = nil(C) ).

% take_Nil
tff(fact_1539_drop__Nil,axiom,
    ! [C: $tType,N: nat] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),nil(C)) = nil(C) ).

% drop_Nil
tff(fact_1540_drop__0,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),zero_zero(nat)),Xs) = Xs ).

% drop_0
tff(fact_1541_slice__def,axiom,
    ! [C: $tType,From: nat,To: nat,List: list(C)] : slice(C,From,To,List) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,To,From)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),From),List)) ).

% slice_def
tff(fact_1542_distinct__length__2__or__more,axiom,
    ! [C: $tType,A3: C,B2: C,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B2),Xs)))
    <=> ( ( A3 != B2 )
        & aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),Xs))
        & aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B2),Xs)) ) ) ).

% distinct_length_2_or_more
tff(fact_1543_distinct_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),$o,distinct(C),nil(C)) ).

% distinct.simps(1)
tff(fact_1544_take__map,axiom,
    ! [C: $tType,D: $tType,N: nat,F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),N),Xs)) ).

% take_map
tff(fact_1545_drop__map,axiom,
    ! [C: $tType,D: $tType,N: nat,F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),drop(D),N),Xs)) ).

% drop_map
tff(fact_1546_distinct__mapI,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),La: list(D)] :
      ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),La))
     => aa(list(D),$o,distinct(D),La) ) ).

% distinct_mapI
tff(fact_1547_sorted__wrt__take,axiom,
    ! [C: $tType,F: fun(C,fun(C,$o)),Xs: list(C),N: nat] :
      ( sorted_wrt(C,F,Xs)
     => sorted_wrt(C,F,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) ) ).

% sorted_wrt_take
tff(fact_1548_sorted__wrt__drop,axiom,
    ! [C: $tType,F: fun(C,fun(C,$o)),Xs: list(C),N: nat] :
      ( sorted_wrt(C,F,Xs)
     => sorted_wrt(C,F,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) ) ).

% sorted_wrt_drop
tff(fact_1549_list_Oset__intros_I2_J,axiom,
    ! [C: $tType,Y: C,X22: list(C),X21: C] :
      ( member2(C,Y,aa(list(C),set(C),set2(C),X22))
     => member2(C,Y,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22))) ) ).

% list.set_intros(2)
tff(fact_1550_list_Oset__intros_I1_J,axiom,
    ! [C: $tType,X21: C,X22: list(C)] : member2(C,X21,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22))) ).

% list.set_intros(1)
tff(fact_1551_list_Oset__cases,axiom,
    ! [C: $tType,E4: C,A3: list(C)] :
      ( member2(C,E4,aa(list(C),set(C),set2(C),A3))
     => ( ! [Z22: list(C)] : A3 != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),Z22)
       => ~ ! [Z1: C,Z22: list(C)] :
              ( ( A3 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z1),Z22) )
             => ~ member2(C,E4,aa(list(C),set(C),set2(C),Z22)) ) ) ) ).

% list.set_cases
tff(fact_1552_set__ConsD,axiom,
    ! [C: $tType,Y: C,X: C,Xs: list(C)] :
      ( member2(C,Y,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)))
     => ( ( Y = X )
        | member2(C,Y,aa(list(C),set(C),set2(C),Xs)) ) ) ).

% set_ConsD
tff(fact_1553_finite__list,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ? [Xs2: list(C)] : aa(list(C),set(C),set2(C),Xs2) = A4 ) ).

% finite_list
tff(fact_1554_subset__code_I1_J,axiom,
    ! [C: $tType,Xs: list(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),B3)
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => member2(C,X4,B3) ) ) ).

% subset_code(1)
tff(fact_1555_ex__map__conv,axiom,
    ! [D: $tType,C: $tType,Ys: list(D),F: fun(C,D)] :
      ( ? [Xs3: list(C)] : Ys = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs3)
    <=> ! [X4: D] :
          ( member2(D,X4,aa(list(D),set(D),set2(D),Ys))
         => ? [Xa2: C] : X4 = aa(C,D,F,Xa2) ) ) ).

% ex_map_conv
tff(fact_1556_map__cong,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(C),F: fun(C,D),G: fun(C,D)] :
      ( ( Xs = Ys )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Ys))
           => ( aa(C,D,F,X2) = aa(C,D,G,X2) ) )
       => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Ys) ) ) ) ).

% map_cong
tff(fact_1557_map__idI,axiom,
    ! [C: $tType,Xs: list(C),F: fun(C,C)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( aa(C,C,F,X2) = X2 ) )
     => ( aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),map(C,C),F),Xs) = Xs ) ) ).

% map_idI
tff(fact_1558_map__ext,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,D),G: fun(C,D)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( aa(C,D,F,X2) = aa(C,D,G,X2) ) )
     => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Xs) ) ) ).

% map_ext
tff(fact_1559_list_Oinj__map__strong,axiom,
    ! [D: $tType,C: $tType,X: list(C),Xa: list(C),F: fun(C,D),Fa: fun(C,D)] :
      ( ! [Z4: C,Za: C] :
          ( member2(C,Z4,aa(list(C),set(C),set2(C),X))
         => ( member2(C,Za,aa(list(C),set(C),set2(C),Xa))
           => ( ( aa(C,D,F,Z4) = aa(C,D,Fa,Za) )
             => ( Z4 = Za ) ) ) )
     => ( ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),X) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),Fa),Xa) )
       => ( X = Xa ) ) ) ).

% list.inj_map_strong
tff(fact_1560_list_Omap__cong0,axiom,
    ! [D: $tType,C: $tType,X: list(C),F: fun(C,D),G: fun(C,D)] :
      ( ! [Z4: C] :
          ( member2(C,Z4,aa(list(C),set(C),set2(C),X))
         => ( aa(C,D,F,Z4) = aa(C,D,G,Z4) ) )
     => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),X) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),X) ) ) ).

% list.map_cong0
tff(fact_1561_list_Omap__cong,axiom,
    ! [D: $tType,C: $tType,X: list(C),Ya: list(C),F: fun(C,D),G: fun(C,D)] :
      ( ( X = Ya )
     => ( ! [Z4: C] :
            ( member2(C,Z4,aa(list(C),set(C),set2(C),Ya))
           => ( aa(C,D,F,Z4) = aa(C,D,G,Z4) ) )
       => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),X) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Ya) ) ) ) ).

% list.map_cong
tff(fact_1562_drop__butlast,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),butlast(C),Xs)) = aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) ).

% drop_butlast
tff(fact_1563_sorted__wrt__mono__rel,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,fun(C,$o)),Q: fun(C,fun(C,$o))] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( aa(C,$o,aa(C,fun(C,$o),Pa,X2),Y2)
             => aa(C,$o,aa(C,fun(C,$o),Q,X2),Y2) ) ) )
     => ( sorted_wrt(C,Pa,Xs)
       => sorted_wrt(C,Q,Xs) ) ) ).

% sorted_wrt_mono_rel
tff(fact_1564_distinct__butlast,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),butlast(C),Xs)) ) ).

% distinct_butlast
tff(fact_1565_sorted__list__of__set_Odistinct__sorted__key__list__of__set,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] : aa(list(C),$o,distinct(C),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) ) ).

% sorted_list_of_set.distinct_sorted_key_list_of_set
tff(fact_1566_distinct__remove1,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)) ) ).

% distinct_remove1
tff(fact_1567_in__set__butlastD,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),butlast(C),Xs)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% in_set_butlastD
tff(fact_1568_foldr__cong,axiom,
    ! [D: $tType,C: $tType,A3: C,B2: C,La: list(D),K: list(D),F: fun(D,fun(C,C)),G: fun(D,fun(C,C))] :
      ( ( A3 = B2 )
     => ( ( La = K )
       => ( ! [A5: C,X2: D] :
              ( member2(D,X2,aa(list(D),set(D),set2(D),La))
             => ( aa(C,C,aa(D,fun(C,C),F,X2),A5) = aa(C,C,aa(D,fun(C,C),G,X2),A5) ) )
         => ( aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),La),A3) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),G),K),B2) ) ) ) ) ).

% foldr_cong
tff(fact_1569_notin__set__remove1,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),Y),Xs))) ) ).

% notin_set_remove1
tff(fact_1570_remove1__idem,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs) = Xs ) ) ).

% remove1_idem
tff(fact_1571_append__eq__append__conv__if,axiom,
    ! [C: $tType,Xs_1: list(C),Xs_2: list(C),Ys_1: list(C),Ys_2: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs_1),Xs_2) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys_1),Ys_2) )
    <=> $ite(
          aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs_1)),aa(list(C),nat,size_size(list(C)),Ys_1)),
          ( ( Xs_1 = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(list(C),nat,size_size(list(C)),Xs_1)),Ys_1) )
          & ( Xs_2 = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(list(C),nat,size_size(list(C)),Xs_1)),Ys_1)),Ys_2) ) ),
          ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(list(C),nat,size_size(list(C)),Ys_1)),Xs_1) = Ys_1 )
          & ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(list(C),nat,size_size(list(C)),Ys_1)),Xs_1)),Xs_2) = Ys_2 ) ) ) ) ).

% append_eq_append_conv_if
tff(fact_1572_drop__rev,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),N)),Xs)) ).

% drop_rev
tff(fact_1573_rev__drop,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),I)),aa(list(C),list(C),rev(C),Xs)) ).

% rev_drop
tff(fact_1574_rev__take,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),I)),aa(list(C),list(C),rev(C),Xs)) ).

% rev_take
tff(fact_1575_take__rev,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),N)),Xs)) ).

% take_rev
tff(fact_1576_not__distinct__split__distinct,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ~ aa(list(C),$o,distinct(C),Xs)
     => ~ ! [Y2: C,Ys2: list(C)] :
            ( aa(list(C),$o,distinct(C),Ys2)
           => ( member2(C,Y2,aa(list(C),set(C),set2(C),Ys2))
             => ! [Zs3: list(C)] : Xs != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),nil(C))),Zs3)) ) ) ) ).

% not_distinct_split_distinct
tff(fact_1577_finite__sorted__distinct__unique,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ? [X2: list(C)] :
              ( ( aa(list(C),set(C),set2(C),X2) = A4 )
              & sorted_wrt(C,ord_less_eq(C),X2)
              & aa(list(C),$o,distinct(C),X2)
              & ! [Y4: list(C)] :
                  ( ( ( aa(list(C),set(C),set2(C),Y4) = A4 )
                    & sorted_wrt(C,ord_less_eq(C),Y4)
                    & aa(list(C),$o,distinct(C),Y4) )
                 => ( Y4 = X2 ) ) ) ) ) ).

% finite_sorted_distinct_unique
tff(fact_1578_distinct__Ex1,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => ? [X2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),aa(list(C),nat,size_size(list(C)),Xs))
            & ( aa(nat,C,nth(C,Xs),X2) = X )
            & ! [Y4: nat] :
                ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Y4),aa(list(C),nat,size_size(list(C)),Xs))
                  & ( aa(nat,C,nth(C,Xs),Y4) = X ) )
               => ( Y4 = X2 ) ) ) ) ) ).

% distinct_Ex1
tff(fact_1579_subseqs__refl,axiom,
    ! [C: $tType,Xs: list(C)] : member2(list(C),Xs,aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(C),list(list(C)),subseqs(C),Xs))) ).

% subseqs_refl
tff(fact_1580_sorted__list__of__set_Oidem__if__sorted__distinct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( aa(list(C),$o,distinct(C),Xs)
           => ( aa(set(C),list(C),linord4507533701916653071of_set(C),aa(list(C),set(C),set2(C),Xs)) = Xs ) ) ) ) ).

% sorted_list_of_set.idem_if_sorted_distinct
tff(fact_1581_list__bind__cong,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(C),F: fun(C,list(D)),G: fun(C,list(D))] :
      ( ( Xs = Ys )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
           => ( aa(C,list(D),F,X2) = aa(C,list(D),G,X2) ) )
       => ( bind(C,D,Xs,F) = bind(C,D,Ys,G) ) ) ) ).

% list_bind_cong
tff(fact_1582_list__ex1__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( list_ex1(C,Pa,Xs)
    <=> ? [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X4)
          & ! [Y3: C] :
              ( ( member2(C,Y3,aa(list(C),set(C),set2(C),Xs))
                & aa(C,$o,Pa,Y3) )
             => ( Y3 = X4 ) ) ) ) ).

% list_ex1_iff
tff(fact_1583_merge__list__correct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Ls: list(list(C)),As2: list(list(C))] :
          ( ! [L: list(C)] :
              ( member2(list(C),L,aa(list(list(C)),set(list(C)),set2(list(C)),Ls))
             => ( aa(list(C),$o,distinct(C),L)
                & sorted_wrt(C,ord_less_eq(C),L) ) )
         => ( ! [L: list(C)] :
                ( member2(list(C),L,aa(list(list(C)),set(list(C)),set2(list(C)),As2))
               => ( aa(list(C),$o,distinct(C),L)
                  & sorted_wrt(C,ord_less_eq(C),L) ) )
           => ( aa(list(C),$o,distinct(C),merge_list(C,As2,Ls))
              & sorted_wrt(C,ord_less_eq(C),merge_list(C,As2,Ls))
              & ( aa(list(C),set(C),set2(C),merge_list(C,As2,Ls)) = aa(list(C),set(C),set2(C),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(list(list(C)),fun(list(list(C)),list(list(C))),append(list(C)),As2),Ls))) ) ) ) ) ) ).

% merge_list_correct
tff(fact_1584_in__set__member,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
    <=> member(C,Xs,X) ) ).

% in_set_member
tff(fact_1585_in__set__drop__conv__nth,axiom,
    ! [C: $tType,X: C,N: nat,La: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),La)))
    <=> ? [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),I2)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),La))
          & ( X = aa(nat,C,nth(C,La),I2) ) ) ) ).

% in_set_drop_conv_nth
tff(fact_1586_take__0,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),zero_zero(nat)),Xs) = nil(C) ).

% take_0
tff(fact_1587_drop__eq__ConsD,axiom,
    ! [C: $tType,N: nat,Xs: list(C),X: C,Xs6: list(C)] :
      ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs6) )
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,N)),Xs) = Xs6 ) ) ).

% drop_eq_ConsD
tff(fact_1588_distinct__singleton,axiom,
    ! [C: $tType,X: C] : aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% distinct_singleton
tff(fact_1589_sorted__take,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),N: nat] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) ) ) ).

% sorted_take
tff(fact_1590_sorted__drop,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),N: nat] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) ) ) ).

% sorted_drop
tff(fact_1591_nth__via__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C),Y: C,Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys) )
     => ( aa(nat,C,nth(C,Xs),N) = Y ) ) ).

% nth_via_drop
tff(fact_1592_distinct__match,axiom,
    ! [C: $tType,Al: list(C),E4: C,Bl: list(C),Al2: list(C),Bl2: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),Bl)))
     => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),Bl)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),Bl2)) )
      <=> ( ( Al = Al2 )
          & ( Bl = Bl2 ) ) ) ) ).

% distinct_match
tff(fact_1593_merge__correct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [L12: list(C),L22: list(C)] :
          ( ( aa(list(C),$o,distinct(C),L12)
            & sorted_wrt(C,ord_less_eq(C),L12) )
         => ( ( aa(list(C),$o,distinct(C),L22)
              & sorted_wrt(C,ord_less_eq(C),L22) )
           => ( aa(list(C),$o,distinct(C),merge(C,L12,L22))
              & sorted_wrt(C,ord_less_eq(C),merge(C,L12,L22))
              & ( aa(list(C),set(C),set2(C),merge(C,L12,L22)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),L12)),aa(list(C),set(C),set2(C),L22)) ) ) ) ) ) ).

% merge_correct
tff(fact_1594_empty__set,axiom,
    ! [C: $tType] : bot_bot(set(C)) = aa(list(C),set(C),set2(C),nil(C)) ).

% empty_set
tff(fact_1595_set__subset__Cons,axiom,
    ! [C: $tType,Xs: list(C),X: C] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) ).

% set_subset_Cons
tff(fact_1596_split__list,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ? [Ys2: list(C),Zs3: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs3)) ) ).

% split_list
tff(fact_1597_split__list__last,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ? [Ys2: list(C),Zs3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs3)) )
          & ~ member2(C,X,aa(list(C),set(C),set2(C),Zs3)) ) ) ).

% split_list_last
tff(fact_1598_split__list__prop,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X3) )
     => ? [Ys2: list(C),X2: C] :
          ( ? [Zs3: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Zs3))
          & aa(C,$o,Pa,X2) ) ) ).

% split_list_prop
tff(fact_1599_split__list__first,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ? [Ys2: list(C),Zs3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs3)) )
          & ~ member2(C,X,aa(list(C),set(C),set2(C),Ys2)) ) ) ).

% split_list_first
tff(fact_1600_split__list__propE,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X3) )
     => ~ ! [Ys2: list(C),X2: C] :
            ( ? [Zs3: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Zs3))
           => ~ aa(C,$o,Pa,X2) ) ) ).

% split_list_propE
tff(fact_1601_append__Cons__eq__iff,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C),Xs6: list(C),Ys7: list(C)] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( ~ member2(C,X,aa(list(C),set(C),set2(C),Ys))
       => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs6),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys7)) )
        <=> ( ( Xs = Xs6 )
            & ( Ys = Ys7 ) ) ) ) ) ).

% append_Cons_eq_iff
tff(fact_1602_in__set__conv__decomp,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
    <=> ? [Ys3: list(C),Zs2: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs2)) ) ).

% in_set_conv_decomp
tff(fact_1603_split__list__last__prop,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X3) )
     => ? [Ys2: list(C),X2: C,Zs3: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Zs3)) )
          & aa(C,$o,Pa,X2)
          & ! [Xa3: C] :
              ( member2(C,Xa3,aa(list(C),set(C),set2(C),Zs3))
             => ~ aa(C,$o,Pa,Xa3) ) ) ) ).

% split_list_last_prop
tff(fact_1604_split__list__first__prop,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X3) )
     => ? [Ys2: list(C),X2: C] :
          ( ? [Zs3: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Zs3))
          & aa(C,$o,Pa,X2)
          & ! [Xa3: C] :
              ( member2(C,Xa3,aa(list(C),set(C),set2(C),Ys2))
             => ~ aa(C,$o,Pa,Xa3) ) ) ) ).

% split_list_first_prop
tff(fact_1605_split__list__last__propE,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X3) )
     => ~ ! [Ys2: list(C),X2: C,Zs3: list(C)] :
            ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Zs3)) )
           => ( aa(C,$o,Pa,X2)
             => ~ ! [Xa3: C] :
                    ( member2(C,Xa3,aa(list(C),set(C),set2(C),Zs3))
                   => ~ aa(C,$o,Pa,Xa3) ) ) ) ) ).

% split_list_last_propE
tff(fact_1606_split__list__first__propE,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X3) )
     => ~ ! [Ys2: list(C),X2: C] :
            ( ? [Zs3: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Zs3))
           => ( aa(C,$o,Pa,X2)
             => ~ ! [Xa3: C] :
                    ( member2(C,Xa3,aa(list(C),set(C),set2(C),Ys2))
                   => ~ aa(C,$o,Pa,Xa3) ) ) ) ) ).

% split_list_first_propE
tff(fact_1607_in__set__conv__decomp__last,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
    <=> ? [Ys3: list(C),Zs2: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs2)) )
          & ~ member2(C,X,aa(list(C),set(C),set2(C),Zs2)) ) ) ).

% in_set_conv_decomp_last
tff(fact_1608_in__set__conv__decomp__first,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
    <=> ? [Ys3: list(C),Zs2: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs2)) )
          & ~ member2(C,X,aa(list(C),set(C),set2(C),Ys3)) ) ) ).

% in_set_conv_decomp_first
tff(fact_1609_split__list__last__prop__iff,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X4) )
    <=> ? [Ys3: list(C),X4: C,Zs2: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Zs2)) )
          & aa(C,$o,Pa,X4)
          & ! [Xa2: C] :
              ( member2(C,Xa2,aa(list(C),set(C),set2(C),Zs2))
             => ~ aa(C,$o,Pa,Xa2) ) ) ) ).

% split_list_last_prop_iff
tff(fact_1610_split__list__first__prop__iff,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X4) )
    <=> ? [Ys3: list(C),X4: C] :
          ( ? [Zs2: list(C)] : Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Zs2))
          & aa(C,$o,Pa,X4)
          & ! [Xa2: C] :
              ( member2(C,Xa2,aa(list(C),set(C),set2(C),Ys3))
             => ~ aa(C,$o,Pa,Xa2) ) ) ) ).

% split_list_first_prop_iff
tff(fact_1611_in__set__list__format,axiom,
    ! [C: $tType,E4: C,La: list(C)] :
      ( member2(C,E4,aa(list(C),set(C),set2(C),La))
     => ~ ! [L1: list(C),L2: list(C)] : La != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),L2)) ) ).

% in_set_list_format
tff(fact_1612_xy__in__set__cases,axiom,
    ! [C: $tType,X: C,La: list(C),Y: C] :
      ( member2(C,X,aa(list(C),set(C),set2(C),La))
     => ( member2(C,Y,aa(list(C),set(C),set2(C),La))
       => ( ( ( X = Y )
           => ! [L1: list(C),L2: list(C)] : La != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),L2)) )
         => ( ( ( X != Y )
             => ! [L1: list(C),L2: list(C),L32: list(C)] : La != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),L32)))) )
           => ~ ( ( X != Y )
               => ! [L1: list(C),L2: list(C),L32: list(C)] : La != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),L32)))) ) ) ) ) ) ).

% xy_in_set_cases
tff(fact_1613_strict__sorted__equal,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( sorted_wrt(C,ord_less(C),Xs)
         => ( sorted_wrt(C,ord_less(C),Ys)
           => ( ( aa(list(C),set(C),set2(C),Ys) = aa(list(C),set(C),set2(C),Xs) )
             => ( Ys = Xs ) ) ) ) ) ).

% strict_sorted_equal
tff(fact_1614_set__union__code,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) ).

% set_union_code
tff(fact_1615_sorted__wrt__append,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( sorted_wrt(C,Pa,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( sorted_wrt(C,Pa,Xs)
        & sorted_wrt(C,Pa,Ys)
        & ! [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
           => ! [Xa2: C] :
                ( member2(C,Xa2,aa(list(C),set(C),set2(C),Ys))
               => aa(C,$o,aa(C,fun(C,$o),Pa,X4),Xa2) ) ) ) ) ).

% sorted_wrt_append
tff(fact_1616_in__set__butlast__appendI,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] :
      ( ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),butlast(C),Xs)))
        | member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),butlast(C),Ys))) )
     => member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)))) ) ).

% in_set_butlast_appendI
tff(fact_1617_set__remove1__subset,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs))),aa(list(C),set(C),set2(C),Xs)) ).

% set_remove1_subset
tff(fact_1618_remove1__append,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] :
      aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = $ite(member2(C,X,aa(list(C),set(C),set2(C),Xs)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)),Ys),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Ys))) ).

% remove1_append
tff(fact_1619_Cons__in__subseqsD,axiom,
    ! [C: $tType,Y: C,Ys: list(C),Xs: list(C)] :
      ( member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys),aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(C),list(list(C)),subseqs(C),Xs)))
     => member2(list(C),Ys,aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(C),list(list(C)),subseqs(C),Xs))) ) ).

% Cons_in_subseqsD
tff(fact_1620_subset__code_I2_J,axiom,
    ! [C: $tType,A4: set(C),Ys: list(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),coset(C,Ys))
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Ys))
         => ~ member2(C,X4,A4) ) ) ).

% subset_code(2)
tff(fact_1621_List_Oinsert__def,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs) = $ite(member2(C,X,aa(list(C),set(C),set2(C),Xs)),Xs,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) ).

% List.insert_def
tff(fact_1622_arg__min__list__in,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Xs: list(C),F: fun(C,D)] :
          ( ( Xs != nil(C) )
         => member2(C,arg_min_list(C,D,F,Xs),aa(list(C),set(C),set2(C),Xs)) ) ) ).

% arg_min_list_in
tff(fact_1623_in__set__product__lists__length,axiom,
    ! [C: $tType,Xs: list(C),Xss2: list(list(C))] :
      ( member2(list(C),Xs,aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(list(C)),list(list(C)),product_lists(C),Xss2)))
     => ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(list(C)),nat,size_size(list(list(C))),Xss2) ) ) ).

% in_set_product_lists_length
tff(fact_1624_length__n__lists__elem,axiom,
    ! [C: $tType,Ys: list(C),N: nat,Xs: list(C)] :
      ( member2(list(C),Ys,aa(list(list(C)),set(list(C)),set2(list(C)),n_lists(C,N,Xs)))
     => ( aa(list(C),nat,size_size(list(C)),Ys) = N ) ) ).

% length_n_lists_elem
tff(fact_1625_id__take__nth__drop,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(nat,C,nth(C,Xs),I)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,I)),Xs))) ) ) ).

% id_take_nth_drop
tff(fact_1626_strict__sorted__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C)] :
          ( sorted_wrt(C,ord_less(C),La)
        <=> ( sorted_wrt(C,ord_less_eq(C),La)
            & aa(list(C),$o,distinct(C),La) ) ) ) ).

% strict_sorted_iff
tff(fact_1627_not__distinct__decomp,axiom,
    ! [C: $tType,Ws2: list(C)] :
      ( ~ aa(list(C),$o,distinct(C),Ws2)
     => ? [Xs2: list(C),Ys2: list(C),Zs3: list(C),Y2: C] : Ws2 = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs2),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),nil(C))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys2),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),nil(C))),Zs3)))) ) ).

% not_distinct_decomp
tff(fact_1628_nth__eq__iff__index__eq,axiom,
    ! [C: $tType,Xs: list(C),I: nat,J: nat] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
         => ( ( aa(nat,C,nth(C,Xs),I) = aa(nat,C,nth(C,Xs),J) )
          <=> ( I = J ) ) ) ) ) ).

% nth_eq_iff_index_eq
tff(fact_1629_distinct__conv__nth,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
    <=> ! [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
         => ! [J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),aa(list(C),nat,size_size(list(C)),Xs))
             => ( ( I2 != J2 )
               => ( aa(nat,C,nth(C,Xs),I2) != aa(nat,C,nth(C,Xs),J2) ) ) ) ) ) ).

% distinct_conv_nth
tff(fact_1630_take__butlast,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),butlast(C),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) ) ) ).

% take_butlast
tff(fact_1631_length__pos__if__in__set,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),aa(list(C),nat,size_size(list(C)),Xs)) ) ).

% length_pos_if_in_set
tff(fact_1632_sorted__simps_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Ys: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys))
        <=> ( ! [X4: C] :
                ( member2(C,X4,aa(list(C),set(C),set2(C),Ys))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),X4) )
            & sorted_wrt(C,ord_less_eq(C),Ys) ) ) ) ).

% sorted_simps(2)
tff(fact_1633_strict__sorted__simps_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Ys: list(C)] :
          ( sorted_wrt(C,ord_less(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys))
        <=> ( ! [X4: C] :
                ( member2(C,X4,aa(list(C),set(C),set2(C),Ys))
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),X4) )
            & sorted_wrt(C,ord_less(C),Ys) ) ) ) ).

% strict_sorted_simps(2)
tff(fact_1634_sorted__append,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
        <=> ( sorted_wrt(C,ord_less_eq(C),Xs)
            & sorted_wrt(C,ord_less_eq(C),Ys)
            & ! [X4: C] :
                ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
               => ! [Xa2: C] :
                    ( member2(C,Xa2,aa(list(C),set(C),set2(C),Ys))
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),Xa2) ) ) ) ) ) ).

% sorted_append
tff(fact_1635_all__set__conv__nth,axiom,
    ! [C: $tType,La: list(C),Pa: fun(C,$o)] :
      ( ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),La))
         => aa(C,$o,Pa,X4) )
    <=> ! [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),La))
         => aa(C,$o,Pa,aa(nat,C,nth(C,La),I2)) ) ) ).

% all_set_conv_nth
tff(fact_1636_all__set__conv__all__nth,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) )
    <=> ! [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
         => aa(C,$o,Pa,aa(nat,C,nth(C,Xs),I2)) ) ) ).

% all_set_conv_all_nth
tff(fact_1637_all__nth__imp__all__set,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o),X: C] :
      ( ! [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Xs))
         => aa(C,$o,Pa,aa(nat,C,nth(C,Xs),I3)) )
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => aa(C,$o,Pa,X) ) ) ).

% all_nth_imp_all_set
tff(fact_1638_in__set__conv__nth,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
    <=> ? [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
          & ( aa(nat,C,nth(C,Xs),I2) = X ) ) ) ).

% in_set_conv_nth
tff(fact_1639_list__ball__nth,axiom,
    ! [C: $tType,N: nat,Xs: list(C),Pa: fun(C,$o)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
           => aa(C,$o,Pa,X2) )
       => aa(C,$o,Pa,aa(nat,C,nth(C,Xs),N)) ) ) ).

% list_ball_nth
tff(fact_1640_nth__mem,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => member2(C,aa(nat,C,nth(C,Xs),N),aa(list(C),set(C),set2(C),Xs)) ) ).

% nth_mem
tff(fact_1641_card__length,axiom,
    ! [C: $tType,Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(C,aa(list(C),set(C),set2(C),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% card_length
tff(fact_1642_butlast__subset,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] :
      ( ( Xs != nil(C) )
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),A4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),butlast(C),Xs))),A4) ) ) ).

% butlast_subset
tff(fact_1643_remove1__split,axiom,
    ! [C: $tType,A3: C,Xs: list(C),Ys: list(C)] :
      ( member2(C,A3,aa(list(C),set(C),set2(C),Xs))
     => ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),A3),Xs) = Ys )
      <=> ? [Ls3: list(C),Rs: list(C)] :
            ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ls3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),Rs)) )
            & ~ member2(C,A3,aa(list(C),set(C),set2(C),Ls3))
            & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ls3),Rs) ) ) ) ) ).

% remove1_split
tff(fact_1644_subset__code_I3_J,axiom,
    ! [C: $tType] : ~ aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),coset(C,nil(C))),aa(list(C),set(C),set2(C),nil(C))) ).

% subset_code(3)
tff(fact_1645_the__elem__set,axiom,
    ! [C: $tType,X: C] : the_elem(C,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)))) = X ).

% the_elem_set
tff(fact_1646_drop__Cons_H,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(N = zero_zero(nat),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),minus_minus(nat,N,one_one(nat))),Xs)) ).

% drop_Cons'
tff(fact_1647_nth__take__lemma,axiom,
    ! [C: $tType,K: nat,Xs: list(C),Ys: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),aa(list(C),nat,size_size(list(C)),Ys))
       => ( ! [I3: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),K)
             => ( aa(nat,C,nth(C,Xs),I3) = aa(nat,C,nth(C,Ys),I3) ) )
         => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),K),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),K),Ys) ) ) ) ) ).

% nth_take_lemma
tff(fact_1648_distinct__idx,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),La: list(D),I: nat,J: nat] :
      ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),La))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(D),nat,size_size(list(D)),La))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(D),nat,size_size(list(D)),La))
         => ( ( aa(D,C,F,aa(nat,D,nth(D,La),I)) = aa(D,C,F,aa(nat,D,nth(D,La),J)) )
           => ( I = J ) ) ) ) ) ).

% distinct_idx
tff(fact_1649_butlast__conv__take,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),butlast(C),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat))),Xs) ).

% butlast_conv_take
tff(fact_1650_length__remove1,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)) = $ite(member2(C,X,aa(list(C),set(C),set2(C),Xs)),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat)),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_remove1
tff(fact_1651_take__Cons_H,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(N = zero_zero(nat),nil(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,N,one_one(nat))),Xs))) ).

% take_Cons'
tff(fact_1652_Cons__nth__drop__Suc,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(nat,C,nth(C,Xs),I)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,I)),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),Xs) ) ) ).

% Cons_nth_drop_Suc
tff(fact_1653_butlast__take,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),list(C),butlast(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,N,one_one(nat))),Xs) ) ) ).

% butlast_take
tff(fact_1654_sorted__append__bigger,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Y: C] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( ! [X2: C] :
                ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y) )
           => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C)))) ) ) ) ).

% sorted_append_bigger
tff(fact_1655_nth__equal__first__eq,axiom,
    ! [C: $tType,X: C,Xs: list(C),N: nat] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
       => ( ( aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),N) = X )
        <=> ( N = zero_zero(nat) ) ) ) ) ).

% nth_equal_first_eq
tff(fact_1656_sorted__list__of__set_Ofinite__set__strict__sorted,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ~ ! [L: list(C)] :
                ( sorted_wrt(C,ord_less(C),L)
               => ( ( aa(list(C),set(C),set2(C),L) = A4 )
                 => ( aa(list(C),nat,size_size(list(C)),L) != finite_card(C,A4) ) ) ) ) ) ).

% sorted_list_of_set.finite_set_strict_sorted
tff(fact_1657_distinct__sorted__mono,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),I: nat,J: nat] :
          ( sorted_wrt(C,ord_less_eq(C),La)
         => ( aa(list(C),$o,distinct(C),La)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),La))
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,nth(C,La),I)),aa(nat,C,nth(C,La),J)) ) ) ) ) ) ).

% distinct_sorted_mono
tff(fact_1658_distinct__sorted__strict__mono__iff,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),I: nat,J: nat] :
          ( aa(list(C),$o,distinct(C),La)
         => ( sorted_wrt(C,ord_less_eq(C),La)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),La))
               => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,nth(C,La),I)),aa(nat,C,nth(C,La),J))
                <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J) ) ) ) ) ) ) ).

% distinct_sorted_strict_mono_iff
tff(fact_1659_set__union,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),union(C),Xs),Ys)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) ).

% set_union
tff(fact_1660_can__select__set__list__ex1,axiom,
    ! [C: $tType,Pa: fun(C,$o),A4: list(C)] :
      ( can_select(C,Pa,aa(list(C),set(C),set2(C),A4))
    <=> list_ex1(C,Pa,A4) ) ).

% can_select_set_list_ex1
tff(fact_1661_mergesort__remdups__correct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C)] :
          ( aa(list(C),$o,distinct(C),aa(list(C),list(C),mergesort_remdups(C),La))
          & sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),mergesort_remdups(C),La))
          & ( aa(list(C),set(C),set2(C),aa(list(C),list(C),mergesort_remdups(C),La)) = aa(list(C),set(C),set2(C),La) ) ) ) ).

% mergesort_remdups_correct
tff(fact_1662_length__transpose__sorted,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( sorted_wrt(nat,ord_less_eq(nat),aa(list(nat),list(nat),rev(nat),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),Xs)))
     => ( aa(list(list(C)),nat,size_size(list(list(C))),transpose(C,Xs)) = $ite(Xs = nil(list(C)),zero_zero(nat),aa(list(C),nat,size_size(list(C)),aa(nat,list(C),nth(list(C),Xs),zero_zero(nat)))) ) ) ).

% length_transpose_sorted
tff(fact_1663_folding__insort__key_Ofinite__set__strict__sorted,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ~ ! [L: list(D)] :
                ( sorted_wrt(C,Less,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),L))
               => ( ( aa(list(D),set(D),set2(D),L) = A4 )
                 => ( aa(list(D),nat,size_size(list(D)),L) != finite_card(D,A4) ) ) ) ) ) ) ).

% folding_insort_key.finite_set_strict_sorted
tff(fact_1664_distinct__union,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),union(C),Xs),Ys))
    <=> aa(list(C),$o,distinct(C),Ys) ) ).

% distinct_union
tff(fact_1665_horner__sum__append,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_semiring_1(C)
     => ! [F: fun(D,C),A3: C,Xs: list(D),Ys: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Xs),Ys)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),Xs)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(list(D),nat,size_size(list(D)),Xs))),aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),Ys))) ) ).

% horner_sum_append
tff(fact_1666_distinct__concat__iff,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( aa(list(C),$o,distinct(C),aa(list(list(C)),list(C),concat(C),Xs))
    <=> ( aa(list(list(C)),$o,distinct(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),removeAll(list(C)),nil(C)),Xs))
        & ! [Ys3: list(C)] :
            ( member2(list(C),Ys3,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
           => aa(list(C),$o,distinct(C),Ys3) )
        & ! [Ys3: list(C),Zs2: list(C)] :
            ( ( member2(list(C),Ys3,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
              & member2(list(C),Zs2,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
              & ( Ys3 != Zs2 ) )
           => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Ys3)),aa(list(C),set(C),set2(C),Zs2)) = bot_bot(set(C)) ) ) ) ) ).

% distinct_concat_iff
tff(fact_1667_removeAll__id,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs) = Xs ) ) ).

% removeAll_id
tff(fact_1668_removeAll__append,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Ys)) ).

% removeAll_append
tff(fact_1669_horner__sum__simps_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_semiring_0(C)
     => ! [F: fun(D,C),A3: C] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),nil(D)) = zero_zero(C) ) ).

% horner_sum_simps(1)
tff(fact_1670_horner__sum__simps_I2_J,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_semiring_0(C)
     => ! [F: fun(D,C),A3: C,X: D,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(D,C,F,X)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),Xs))) ) ).

% horner_sum_simps(2)
tff(fact_1671_set__removeAll,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)) = minus_minus(set(C),aa(list(C),set(C),set2(C),Xs),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ).

% set_removeAll
tff(fact_1672_can__select__def,axiom,
    ! [C: $tType,Pa: fun(C,$o),A4: set(C)] :
      ( can_select(C,Pa,A4)
    <=> ? [X4: C] :
          ( member2(C,X4,A4)
          & aa(C,$o,Pa,X4)
          & ! [Y3: C] :
              ( ( member2(C,Y3,A4)
                & aa(C,$o,Pa,Y3) )
             => ( Y3 = X4 ) ) ) ) ).

% can_select_def
tff(fact_1673_transpose_Osimps_I1_J,axiom,
    ! [C: $tType] : transpose(C,nil(list(C))) = nil(list(C)) ).

% transpose.simps(1)
tff(fact_1674_removeAll_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Y: C,Xs: list(C)] :
      aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)) = $ite(X = Y,aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs))) ).

% removeAll.simps(2)
tff(fact_1675_removeAll_Osimps_I1_J,axiom,
    ! [C: $tType,X: C] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),nil(C)) = nil(C) ).

% removeAll.simps(1)
tff(fact_1676_distinct__removeAll,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)) ) ).

% distinct_removeAll
tff(fact_1677_transpose_Osimps_I2_J,axiom,
    ! [C: $tType,Xss2: list(list(C))] : transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss2)) = transpose(C,Xss2) ).

% transpose.simps(2)
tff(fact_1678_transpose__empty,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( ( transpose(C,Xs) = nil(list(C)) )
    <=> ! [X4: list(C)] :
          ( member2(list(C),X4,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
         => ( X4 = nil(C) ) ) ) ).

% transpose_empty
tff(fact_1679_length__removeAll__less__eq,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_removeAll_less_eq
tff(fact_1680_transpose__map__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(list(D))] : transpose(C,aa(list(list(D)),list(list(C)),aa(fun(list(D),list(C)),fun(list(list(D)),list(list(C))),map(list(D),list(C)),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F)),Xs)) = aa(list(list(D)),list(list(C)),aa(fun(list(D),list(C)),fun(list(list(D)),list(list(C))),map(list(D),list(C)),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F)),transpose(D,Xs)) ).

% transpose_map_map
tff(fact_1681_folding__insort__key_Odistinct__if__distinct__map,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),Xs: list(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
       => aa(list(D),$o,distinct(D),Xs) ) ) ).

% folding_insort_key.distinct_if_distinct_map
tff(fact_1682_distinct__remove1__removeAll,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs) ) ) ).

% distinct_remove1_removeAll
tff(fact_1683_insert__code_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),coset(C,Xs)) = coset(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)) ).

% insert_code(2)
tff(fact_1684_remove__code_I1_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),remove(C),X),aa(list(C),set(C),set2(C),Xs)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)) ).

% remove_code(1)
tff(fact_1685_length__removeAll__less,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ) ).

% length_removeAll_less
tff(fact_1686_sorted__transpose,axiom,
    ! [C: $tType,Xs: list(list(C))] : sorted_wrt(nat,ord_less_eq(nat),aa(list(nat),list(nat),rev(nat),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),transpose(C,Xs)))) ).

% sorted_transpose
tff(fact_1687_folding__insort__key_Osorted__key__list__of__set__unique,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D),La: list(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ( ( sorted_wrt(C,Less,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),La))
              & ( aa(list(D),set(D),set2(D),La) = A4 )
              & ( aa(list(D),nat,size_size(list(D)),La) = finite_card(D,A4) ) )
          <=> ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4) = La ) ) ) ) ) ).

% folding_insort_key.sorted_key_list_of_set_unique
tff(fact_1688_folding__insort__key_Osorted__key__list__of__set__remove,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),X: D,A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),A4)),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),minus_minus(set(D),A4,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D))))) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),remove1(D),X),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4)) ) ) ) ) ).

% folding_insort_key.sorted_key_list_of_set_remove
tff(fact_1689_folding__insort__key_Oidem__if__sorted__distinct,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),Xs: list(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(list(D),set(D),set2(D),Xs)),S)
       => ( sorted_wrt(C,Less_eq,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
         => ( aa(list(D),$o,distinct(D),Xs)
           => ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),aa(list(D),set(D),set2(D),Xs)) = Xs ) ) ) ) ) ).

% folding_insort_key.idem_if_sorted_distinct
tff(fact_1690_take__hd__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs))),nil(C))) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,suc,N)),Xs) ) ) ).

% take_hd_drop
tff(fact_1691_set__update__distinct,axiom,
    ! [C: $tType,Xs: list(C),N: nat,X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),minus_minus(set(C),aa(list(C),set(C),set2(C),Xs),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(nat,C,nth(C,Xs),N)),bot_bot(set(C))))) ) ) ) ).

% set_update_distinct
tff(fact_1692_is__empty__set,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( is_empty(C,aa(list(C),set(C),set2(C),Xs))
    <=> aa(list(C),$o,null(C),Xs) ) ).

% is_empty_set
tff(fact_1693_folding__insort__key_Osorted__key__list__of__set__eq__Nil__iff,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ( ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4) = nil(D) )
          <=> ( A4 = bot_bot(set(D)) ) ) ) ) ) ).

% folding_insort_key.sorted_key_list_of_set_eq_Nil_iff
tff(fact_1694_distinct__foldl__invar,axiom,
    ! [D: $tType,C: $tType,S: list(C),I5: fun(set(C),fun(D,$o)),Sigma_0: D,F: fun(D,fun(C,D))] :
      ( aa(list(C),$o,distinct(C),S)
     => ( aa(D,$o,aa(set(C),fun(D,$o),I5,aa(list(C),set(C),set2(C),S)),Sigma_0)
       => ( ! [X2: C,It: set(C),Sigma: D] :
              ( member2(C,X2,It)
             => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),It),aa(list(C),set(C),set2(C),S))
               => ( aa(D,$o,aa(set(C),fun(D,$o),I5,It),Sigma)
                 => aa(D,$o,aa(set(C),fun(D,$o),I5,minus_minus(set(C),It,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C))))),aa(C,D,aa(D,fun(C,D),F,Sigma),X2)) ) ) )
         => aa(D,$o,aa(set(C),fun(D,$o),I5,bot_bot(set(C))),aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),F),Sigma_0),S)) ) ) ) ).

% distinct_foldl_invar
tff(fact_1695_list__update__overwrite,axiom,
    ! [C: $tType,Xs: list(C),I: nat,X: C,Y: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),I),Y) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),Y) ).

% list_update_overwrite
tff(fact_1696_list__update__nonempty,axiom,
    ! [C: $tType,Xs: list(C),K: nat,X: C] :
      ( ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),K),X) = nil(C) )
    <=> ( Xs = nil(C) ) ) ).

% list_update_nonempty
tff(fact_1697_length__list__update,axiom,
    ! [C: $tType,Xs: list(C),I: nat,X: C] : aa(list(C),nat,size_size(list(C)),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)) = aa(list(C),nat,size_size(list(C)),Xs) ).

% length_list_update
tff(fact_1698_nth__list__update__neq,axiom,
    ! [C: $tType,I: nat,J: nat,Xs: list(C),X: C] :
      ( ( I != J )
     => ( aa(nat,C,nth(C,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),J) = aa(nat,C,nth(C,Xs),J) ) ) ).

% nth_list_update_neq
tff(fact_1699_list__update__id,axiom,
    ! [C: $tType,Xs: list(C),I: nat] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),aa(nat,C,nth(C,Xs),I)) = Xs ).

% list_update_id
tff(fact_1700_foldl__append,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,C)),A3: C,Xs: list(D),Ys: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Xs),Ys)) = aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),Xs)),Ys) ).

% foldl_append
tff(fact_1701_take__update,axiom,
    ! [C: $tType,N: nat,La: list(C),I: nat,X: C] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),La)),I),X) ).

% take_update
tff(fact_1702_take__update__swap,axiom,
    ! [C: $tType,M2: nat,Xs: list(C),N: nat,X: C] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),M2),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),M2),Xs)),N),X) ).

% take_update_swap
tff(fact_1703_list__update__beyond,axiom,
    ! [C: $tType,Xs: list(C),I: nat,X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),I)
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X) = Xs ) ) ).

% list_update_beyond
tff(fact_1704_hd__append2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),C,hd(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),C,hd(C),Xs) ) ) ).

% hd_append2
tff(fact_1705_take__update__cancel,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C),Y: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M2)
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),M2),Y)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) ) ) ).

% take_update_cancel
tff(fact_1706_drop__upd__irrelevant,axiom,
    ! [C: $tType,M2: nat,N: nat,La: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M2),N)
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),M2),X)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),La) ) ) ).

% drop_upd_irrelevant
tff(fact_1707_drop__update__cancel,axiom,
    ! [C: $tType,N: nat,M2: nat,Xs: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2)
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),Xs) ) ) ).

% drop_update_cancel
tff(fact_1708_list__update__length,axiom,
    ! [C: $tType,Xs: list(C),X: C,Ys: list(C),Y: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys))),aa(list(C),nat,size_size(list(C)),Xs)),Y) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ).

% list_update_length
tff(fact_1709_nth__update__invalid,axiom,
    ! [C: $tType,I: nat,La: list(C),J: nat,X: C] :
      ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(nat,C,nth(C,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),J),X)),I) = aa(nat,C,nth(C,La),I) ) ) ).

% nth_update_invalid
tff(fact_1710_nth__list__update__eq,axiom,
    ! [C: $tType,I: nat,Xs: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,C,nth(C,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),I) = X ) ) ).

% nth_list_update_eq
tff(fact_1711_hd__take,axiom,
    ! [C: $tType,J: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),J)
     => ( aa(list(C),C,hd(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),J),Xs)) = aa(list(C),C,hd(C),Xs) ) ) ).

% hd_take
tff(fact_1712_set__swap,axiom,
    ! [C: $tType,I: nat,Xs: list(C),J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),aa(nat,C,nth(C,Xs),J))),J),aa(nat,C,nth(C,Xs),I))) = aa(list(C),set(C),set2(C),Xs) ) ) ) ).

% set_swap
tff(fact_1713_distinct__swap,axiom,
    ! [C: $tType,I: nat,Xs: list(C),J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(list(C),$o,distinct(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),aa(nat,C,nth(C,Xs),J))),J),aa(nat,C,nth(C,Xs),I)))
        <=> aa(list(C),$o,distinct(C),Xs) ) ) ) ).

% distinct_swap
tff(fact_1714_foldl__foldl__conv__concat,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,C)),A3: C,Xs: list(list(D))] : aa(list(list(D)),C,aa(C,fun(list(list(D)),C),aa(fun(C,fun(list(D),C)),fun(C,fun(list(list(D)),C)),foldl(C,list(D)),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F)),A3),Xs) = aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),aa(list(list(D)),list(D),concat(D),Xs)) ).

% foldl_foldl_conv_concat
tff(fact_1715_foldl__A1__eq,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),N: C,I: C,Ww: list(C)] :
      ( ! [E: C] : aa(C,C,aa(C,fun(C,C),F,N),E) = E
     => ( ! [E: C] : aa(C,C,aa(C,fun(C,C),F,E),N) = E
       => ( ! [A5: C,B4: C,C2: C] : aa(C,C,aa(C,fun(C,C),F,A5),aa(C,C,aa(C,fun(C,C),F,B4),C2)) = aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A5),B4)),C2)
         => ( aa(list(C),C,aa(C,fun(list(C),C),aa(fun(C,fun(C,C)),fun(C,fun(list(C),C)),foldl(C,C),F),I),Ww) = aa(C,C,aa(C,fun(C,C),F,I),aa(list(C),C,aa(C,fun(list(C),C),aa(fun(C,fun(C,C)),fun(C,fun(list(C),C)),foldl(C,C),F),N),Ww)) ) ) ) ) ).

% foldl_A1_eq
tff(fact_1716_list__update__swap,axiom,
    ! [C: $tType,I: nat,I6: nat,Xs: list(C),X: C,X6: C] :
      ( ( I != I6 )
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),I6),X6) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I6),X6)),I),X) ) ) ).

% list_update_swap
tff(fact_1717_linorder_Osorted__key__list__of__set_Ocong,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(D,fun(D,$o))] : sorted8670434370408473282of_set(D,C,Less_eq) = sorted8670434370408473282of_set(D,C,Less_eq) ).

% linorder.sorted_key_list_of_set.cong
tff(fact_1718_list__update_Osimps_I1_J,axiom,
    ! [C: $tType,I: nat,V: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),nil(C)),I),V) = nil(C) ).

% list_update.simps(1)
tff(fact_1719_list__update__code_I1_J,axiom,
    ! [C: $tType,I: nat,Y: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),nil(C)),I),Y) = nil(C) ).

% list_update_code(1)
tff(fact_1720_map__update,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),K: nat,Y: D] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(D,list(D),aa(nat,fun(D,list(D)),aa(list(D),fun(nat,fun(D,list(D))),list_update(D),Xs),K),Y)) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)),K),aa(D,C,F,Y)) ).

% map_update
tff(fact_1721_list_Osel_I1_J,axiom,
    ! [C: $tType,X21: C,X22: list(C)] : aa(list(C),C,hd(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)) = X21 ).

% list.sel(1)
tff(fact_1722_butlast__update_H,axiom,
    ! [C: $tType,La: list(C),I: nat,X: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),butlast(C),La)),I),X) = aa(list(C),list(C),butlast(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),X)) ).

% butlast_update'
tff(fact_1723_foldl__Cons,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,C)),A3: C,X: D,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)) = aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),aa(D,C,aa(C,fun(D,C),F,A3),X)),Xs) ).

% foldl_Cons
tff(fact_1724_foldl__Nil,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(D,C)),A3: C] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),nil(D)) = A3 ).

% foldl_Nil
tff(fact_1725_foldl__cong,axiom,
    ! [C: $tType,D: $tType,A3: C,B2: C,La: list(D),K: list(D),F: fun(C,fun(D,C)),G: fun(C,fun(D,C))] :
      ( ( A3 = B2 )
     => ( ( La = K )
       => ( ! [A5: C,X2: D] :
              ( member2(D,X2,aa(list(D),set(D),set2(D),La))
             => ( aa(D,C,aa(C,fun(D,C),F,A5),X2) = aa(D,C,aa(C,fun(D,C),G,A5),X2) ) )
         => ( aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),La) = aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),G),B2),K) ) ) ) ) ).

% foldl_cong
tff(fact_1726_hd__concat,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( ( Xs != nil(list(C)) )
     => ( ( aa(list(list(C)),list(C),hd(list(C)),Xs) != nil(C) )
       => ( aa(list(C),C,hd(C),aa(list(list(C)),list(C),concat(C),Xs)) = aa(list(C),C,hd(C),aa(list(list(C)),list(C),hd(list(C)),Xs)) ) ) ) ).

% hd_concat
tff(fact_1727_list__update__code_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),zero_zero(nat)),Y) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs) ).

% list_update_code(2)
tff(fact_1728_list__update__code_I3_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),I: nat,Y: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(nat,nat,suc,I)),Y) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),Y)) ).

% list_update_code(3)
tff(fact_1729_set__update__subsetI,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C),X: C,I: nat] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),A4)
     => ( member2(C,X,A4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X))),A4) ) ) ).

% set_update_subsetI
tff(fact_1730_hd__in__set,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => member2(C,aa(list(C),C,hd(C),Xs),aa(list(C),set(C),set2(C),Xs)) ) ).

% hd_in_set
tff(fact_1731_list_Oset__sel_I1_J,axiom,
    ! [C: $tType,A3: list(C)] :
      ( ( A3 != nil(C) )
     => member2(C,aa(list(C),C,hd(C),A3),aa(list(C),set(C),set2(C),A3)) ) ).

% list.set_sel(1)
tff(fact_1732_list_Omap__sel_I1_J,axiom,
    ! [D: $tType,C: $tType,A3: list(C),F: fun(C,D)] :
      ( ( A3 != nil(C) )
     => ( aa(list(D),D,hd(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),A3)) = aa(C,D,F,aa(list(C),C,hd(C),A3)) ) ) ).

% list.map_sel(1)
tff(fact_1733_hd__map,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,D)] :
      ( ( Xs != nil(C) )
     => ( aa(list(D),D,hd(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) = aa(C,D,F,aa(list(C),C,hd(C),Xs)) ) ) ).

% hd_map
tff(fact_1734_hd__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      aa(list(C),C,hd(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = $ite(Xs = nil(C),aa(list(C),C,hd(C),Ys),aa(list(C),C,hd(C),Xs)) ).

% hd_append
tff(fact_1735_longest__common__prefix,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
    ? [Ps2: list(C),Xs4: list(C),Ys4: list(C)] :
      ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ps2),Xs4) )
      & ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ps2),Ys4) )
      & ( ( Xs4 = nil(C) )
        | ( Ys4 = nil(C) )
        | ( aa(list(C),C,hd(C),Xs4) != aa(list(C),C,hd(C),Ys4) ) ) ) ).

% longest_common_prefix
tff(fact_1736_hd__Nil__eq__last,axiom,
    ! [C: $tType] : aa(list(C),C,hd(C),nil(C)) = last(C,nil(C)) ).

% hd_Nil_eq_last
tff(fact_1737_last__rev,axiom,
    ! [C: $tType,Xs: list(C)] : last(C,aa(list(C),list(C),rev(C),Xs)) = aa(list(C),C,hd(C),Xs) ).

% last_rev
tff(fact_1738_hd__rev,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),C,hd(C),aa(list(C),list(C),rev(C),Xs)) = last(C,Xs) ).

% hd_rev
tff(fact_1739_foldl__conc__empty__eq,axiom,
    ! [C: $tType,I: list(C),Ww: list(list(C))] : aa(list(list(C)),list(C),aa(list(C),fun(list(list(C)),list(C)),aa(fun(list(C),fun(list(C),list(C))),fun(list(C),fun(list(list(C)),list(C))),foldl(list(C),list(C)),append(C)),I),Ww) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),I),aa(list(list(C)),list(C),aa(list(C),fun(list(list(C)),list(C)),aa(fun(list(C),fun(list(C),list(C))),fun(list(C),fun(list(list(C)),list(C))),foldl(list(C),list(C)),append(C)),nil(C)),Ww)) ).

% foldl_conc_empty_eq
tff(fact_1740_foldl__absorb1,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [X: C,Zs: list(C)] : aa(C,C,aa(C,fun(C,C),times_times(C),X),aa(list(C),C,aa(C,fun(list(C),C),aa(fun(C,fun(C,C)),fun(C,fun(list(C),C)),foldl(C,C),times_times(C)),one_one(C)),Zs)) = aa(list(C),C,aa(C,fun(list(C),C),aa(fun(C,fun(C,C)),fun(C,fun(list(C),C)),foldl(C,C),times_times(C)),X),Zs) ) ).

% foldl_absorb1
tff(fact_1741_foldl__un__empty__eq,axiom,
    ! [C: $tType,I: set(C),Ww: list(set(C))] : aa(list(set(C)),set(C),aa(set(C),fun(list(set(C)),set(C)),aa(fun(set(C),fun(set(C),set(C))),fun(set(C),fun(list(set(C)),set(C))),foldl(set(C),set(C)),sup_sup(set(C))),I),Ww) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),I),aa(list(set(C)),set(C),aa(set(C),fun(list(set(C)),set(C)),aa(fun(set(C),fun(set(C),set(C))),fun(set(C),fun(list(set(C)),set(C))),foldl(set(C),set(C)),sup_sup(set(C))),bot_bot(set(C))),Ww)) ).

% foldl_un_empty_eq
tff(fact_1742_foldl__list__update,axiom,
    ! [D: $tType,C: $tType,N: nat,Xs: list(C),F: fun(D,fun(C,D)),A3: D,X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),F),A3),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X)) = aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),F),aa(C,D,aa(D,fun(C,D),F,aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),F),A3),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs))),X)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,N)),Xs)) ) ) ).

% foldl_list_update
tff(fact_1743_null__rec_I1_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : ~ aa(list(C),$o,null(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) ).

% null_rec(1)
tff(fact_1744_eq__Nil__null,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs = nil(C) )
    <=> aa(list(C),$o,null(C),Xs) ) ).

% eq_Nil_null
tff(fact_1745_null__rec_I2_J,axiom,
    ! [C: $tType] : aa(list(C),$o,null(C),nil(C)) ).

% null_rec(2)
tff(fact_1746_set__update__subset__insert,axiom,
    ! [C: $tType,Xs: list(C),I: nat,X: C] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X))),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(list(C),set(C),set2(C),Xs))) ).

% set_update_subset_insert
tff(fact_1747_in__set__upd__eq__aux,axiom,
    ! [C: $tType,I: nat,La: list(C),X: C,Y: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
     => ( member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),Y)))
      <=> ( ( X = Y )
          | ! [Y3: C] : member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),Y3))) ) ) ) ).

% in_set_upd_eq_aux
tff(fact_1748_in__set__upd__cases,axiom,
    ! [C: $tType,X: C,La: list(C),I: nat,Y: C] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),Y)))
     => ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
         => ( X != Y ) )
       => member2(C,X,aa(list(C),set(C),set2(C),La)) ) ) ).

% in_set_upd_cases
tff(fact_1749_in__set__upd__eq,axiom,
    ! [C: $tType,I: nat,La: list(C),X: C,Y: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
     => ( member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),Y)))
      <=> ( ( X = Y )
          | ( member2(C,X,aa(list(C),set(C),set2(C),La))
            & ! [Y3: C] : member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),Y3))) ) ) ) ) ).

% in_set_upd_eq
tff(fact_1750_set__update__memI,axiom,
    ! [C: $tType,N: nat,Xs: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X))) ) ).

% set_update_memI
tff(fact_1751_list__update__append1,axiom,
    ! [C: $tType,I: nat,Xs: list(C),Ys: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),I),X) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),Ys) ) ) ).

% list_update_append1
tff(fact_1752_nth__list__update_H,axiom,
    ! [C: $tType,La: list(C),I: nat,X: C,J: nat] :
      aa(nat,C,nth(C,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),X)),J) = $ite(
        ( ( I = J )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La)) ),
        X,
        aa(nat,C,nth(C,La),J) ) ).

% nth_list_update'
tff(fact_1753_list__update__same__conv,axiom,
    ! [C: $tType,I: nat,Xs: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X) = Xs )
      <=> ( aa(nat,C,nth(C,Xs),I) = X ) ) ) ).

% list_update_same_conv
tff(fact_1754_nth__list__update,axiom,
    ! [C: $tType,I: nat,Xs: list(C),X: C,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,C,nth(C,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),J) = $ite(I = J,X,aa(nat,C,nth(C,Xs),J)) ) ) ).

% nth_list_update
tff(fact_1755_drop__update__swap,axiom,
    ! [C: $tType,M2: nat,N: nat,Xs: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M2),Xs)),minus_minus(nat,N,M2)),X) ) ) ).

% drop_update_swap
tff(fact_1756_hd__conv__nth,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),C,hd(C),Xs) = aa(nat,C,nth(C,Xs),zero_zero(nat)) ) ) ).

% hd_conv_nth
tff(fact_1757_distinct__butlast__swap,axiom,
    ! [C: $tType,Pq: list(C),I: nat] :
      ( aa(list(C),$o,distinct(C),Pq)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),butlast(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Pq),I),last(C,Pq)))) ) ).

% distinct_butlast_swap
tff(fact_1758_foldl__rule,axiom,
    ! [C: $tType,D: $tType,I5: fun(C,fun(list(D),fun(list(D),$o))),Sigma_0: C,L0: list(D),F: fun(C,fun(D,C))] :
      ( aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,Sigma_0),nil(D)),L0)
     => ( ! [L1: list(D),L2: list(D),X2: D,Sigma: C] :
            ( ( L0 = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2)) )
           => ( aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,Sigma),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2))
             => aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,aa(D,C,aa(C,fun(D,C),F,Sigma),X2)),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),nil(D)))),L2) ) )
       => aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),Sigma_0),L0)),L0),nil(D)) ) ) ).

% foldl_rule
tff(fact_1759_foldl__rule__P,axiom,
    ! [C: $tType,D: $tType,I5: fun(C,fun(list(D),fun(list(D),$o))),Sigma_0: C,L0: list(D),F: fun(C,fun(D,C)),Pa: fun(C,$o)] :
      ( aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,Sigma_0),nil(D)),L0)
     => ( ! [L1: list(D),L2: list(D),X2: D,Sigma: C] :
            ( ( L0 = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2)) )
           => ( aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,Sigma),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2))
             => aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,aa(D,C,aa(C,fun(D,C),F,Sigma),X2)),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),nil(D)))),L2) ) )
       => ( ! [Sigma: C] :
              ( aa(list(D),$o,aa(list(D),fun(list(D),$o),aa(C,fun(list(D),fun(list(D),$o)),I5,Sigma),L0),nil(D))
             => aa(C,$o,Pa,Sigma) )
         => aa(C,$o,Pa,aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),Sigma_0),L0)) ) ) ) ).

% foldl_rule_P
tff(fact_1760_foldl__rule__aux,axiom,
    ! [C: $tType,D: $tType,I5: fun(C,fun(list(D),$o)),Sigma_0: C,L0: list(D),F: fun(C,fun(D,C))] :
      ( aa(list(D),$o,aa(C,fun(list(D),$o),I5,Sigma_0),L0)
     => ( ! [L1: list(D),L2: list(D),X2: D,Sigma: C] :
            ( ( L0 = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2)) )
           => ( aa(list(D),$o,aa(C,fun(list(D),$o),I5,Sigma),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2))
             => aa(list(D),$o,aa(C,fun(list(D),$o),I5,aa(D,C,aa(C,fun(D,C),F,Sigma),X2)),L2) ) )
       => aa(list(D),$o,aa(C,fun(list(D),$o),I5,aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),Sigma_0),L0)),nil(D)) ) ) ).

% foldl_rule_aux
tff(fact_1761_foldl__rule__aux__P,axiom,
    ! [C: $tType,D: $tType,I5: fun(C,fun(list(D),$o)),Sigma_0: C,L0: list(D),F: fun(C,fun(D,C)),Pa: fun(C,$o)] :
      ( aa(list(D),$o,aa(C,fun(list(D),$o),I5,Sigma_0),L0)
     => ( ! [L1: list(D),L2: list(D),X2: D,Sigma: C] :
            ( ( L0 = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L1),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2)) )
           => ( aa(list(D),$o,aa(C,fun(list(D),$o),I5,Sigma),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X2),L2))
             => aa(list(D),$o,aa(C,fun(list(D),$o),I5,aa(D,C,aa(C,fun(D,C),F,Sigma),X2)),L2) ) )
       => ( ! [Sigma: C] :
              ( aa(list(D),$o,aa(C,fun(list(D),$o),I5,Sigma),nil(D))
             => aa(C,$o,Pa,Sigma) )
         => aa(C,$o,Pa,aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),Sigma_0),L0)) ) ) ) ).

% foldl_rule_aux_P
tff(fact_1762_list__update__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),N: nat,X: C] :
      aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),N),X) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N),X)),Ys),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Ys),minus_minus(nat,N,aa(list(C),nat,size_size(list(C)),Xs))),X))) ).

% list_update_append
tff(fact_1763_map__upd__eq,axiom,
    ! [D: $tType,C: $tType,I: nat,La: list(C),F: fun(C,D),X: C] :
      ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
       => ( aa(C,D,F,aa(nat,C,nth(C,La),I)) = aa(C,D,F,X) ) )
     => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),X)) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),La) ) ) ).

% map_upd_eq
tff(fact_1764_sorted__hd__min,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( ( Xs != nil(C) )
         => ( sorted_wrt(C,ord_less_eq(C),Xs)
           => ! [X3: C] :
                ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(list(C),C,hd(C),Xs)),X3) ) ) ) ) ).

% sorted_hd_min
tff(fact_1765_butlast__list__update,axiom,
    ! [C: $tType,Xs: list(C),K: nat,X: C] :
      aa(list(C),list(C),butlast(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),K),X)) = $ite(K = minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat)),aa(list(C),list(C),butlast(C),Xs),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),butlast(C),Xs)),K),X)) ).

% butlast_list_update
tff(fact_1766_hd__drop__conv__nth,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),C,hd(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) = aa(nat,C,nth(C,Xs),N) ) ) ).

% hd_drop_conv_nth
tff(fact_1767_sorted__hd__last,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),La)
         => ( ( La != nil(C) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(list(C),C,hd(C),La)),last(C,La)) ) ) ) ).

% sorted_hd_last
tff(fact_1768_hd__last__singletonI,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( ( aa(list(C),C,hd(C),Xs) = last(C,Xs) )
       => ( aa(list(C),$o,distinct(C),Xs)
         => ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),Xs)),nil(C)) ) ) ) ) ).

% hd_last_singletonI
tff(fact_1769_hd__butlast,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),C,hd(C),aa(list(C),list(C),butlast(C),Xs)) = aa(list(C),C,hd(C),Xs) ) ) ).

% hd_butlast
tff(fact_1770_folding__insort__key_Osorted__key__list__of__set__empty,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),bot_bot(set(D))) = nil(D) ) ) ).

% folding_insort_key.sorted_key_list_of_set_empty
tff(fact_1771_folding__insort__key_Osorted__key__list__of__set__inject,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D),B3: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),B3),S)
         => ( ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4) = aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),B3) )
           => ( aa(set(D),$o,finite_finite2(D),A4)
             => ( aa(set(D),$o,finite_finite2(D),B3)
               => ( A4 = B3 ) ) ) ) ) ) ) ).

% folding_insort_key.sorted_key_list_of_set_inject
tff(fact_1772_insert__swap__set__eq,axiom,
    ! [C: $tType,I: nat,La: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(nat,C,nth(C,La),I)),aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),La),I),X))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(list(C),set(C),set2(C),La)) ) ) ).

% insert_swap_set_eq
tff(fact_1773_rev__update,axiom,
    ! [C: $tType,K: nat,Xs: list(C),Y: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(list(C),list(C),rev(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),K),Y)) = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),rev(C),Xs)),minus_minus(nat,minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),K),one_one(nat))),Y) ) ) ).

% rev_update
tff(fact_1774_last__list__update,axiom,
    ! [C: $tType,Xs: list(C),K: nat,X: C] :
      ( ( Xs != nil(C) )
     => ( last(C,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),K),X)) = $ite(K = minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat)),X,last(C,Xs)) ) ) ).

% last_list_update
tff(fact_1775_slice__head,axiom,
    ! [C: $tType,From: nat,To: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),From),To)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),To),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(list(C),C,hd(C),slice(C,From,To,Xs)) = aa(nat,C,nth(C,Xs),From) ) ) ) ).

% slice_head
tff(fact_1776_distinct__list__update,axiom,
    ! [C: $tType,Xs: list(C),A3: C,I: nat] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( ~ member2(C,A3,minus_minus(set(C),aa(list(C),set(C),set2(C),Xs),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(nat,C,nth(C,Xs),I)),bot_bot(set(C)))))
       => aa(list(C),$o,distinct(C),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),A3)) ) ) ).

% distinct_list_update
tff(fact_1777_folding__insort__key_Oset__sorted__key__list__of__set,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ( aa(list(D),set(D),set2(D),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4)) = A4 ) ) ) ) ).

% folding_insort_key.set_sorted_key_list_of_set
tff(fact_1778_folding__insort__key_Olength__sorted__key__list__of__set,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => ( aa(list(D),nat,size_size(list(D)),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4)) = finite_card(D,A4) ) ) ) ).

% folding_insort_key.length_sorted_key_list_of_set
tff(fact_1779_folding__insort__key_Odistinct__sorted__key__list__of__set,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4))) ) ) ).

% folding_insort_key.distinct_sorted_key_list_of_set
tff(fact_1780_folding__insort__key_Ostrict__sorted__key__list__of__set,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => sorted_wrt(C,Less,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4))) ) ) ).

% folding_insort_key.strict_sorted_key_list_of_set
tff(fact_1781_folding__insort__key_Osorted__sorted__key__list__of__set,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),S)
       => sorted_wrt(C,Less_eq,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4))) ) ) ).

% folding_insort_key.sorted_sorted_key_list_of_set
tff(fact_1782_take__update__last,axiom,
    ! [C: $tType,N: nat,List: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),List))
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,suc,N)),List)),N),X) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),List)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ) ) ).

% take_update_last
tff(fact_1783_upd__conv__take__nth__drop,axiom,
    ! [C: $tType,I: nat,Xs: list(C),A3: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),A3) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,I)),Xs))) ) ) ).

% upd_conv_take_nth_drop
tff(fact_1784_folding__insort__key_Osorted__key__list__of__set__insert__remove,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),X: D,A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),A4)),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),A4)) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),aa(fun(D,C),fun(D,fun(list(D),list(D))),insort_key(C,D,Less_eq),F),X),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),minus_minus(set(D),A4,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D)))))) ) ) ) ) ).

% folding_insort_key.sorted_key_list_of_set_insert_remove
tff(fact_1785_folding__insort__key_Osorted__key__list__of__set__insert,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),X: D,A4: set(D)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),A4)),S)
       => ( aa(set(D),$o,finite_finite2(D),A4)
         => ( ~ member2(D,X,A4)
           => ( aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),A4)) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),aa(fun(D,C),fun(D,fun(list(D),list(D))),insort_key(C,D,Less_eq),F),X),aa(set(D),list(D),aa(fun(D,C),fun(set(D),list(D)),sorted8670434370408473282of_set(C,D,Less_eq),F),A4)) ) ) ) ) ) ).

% folding_insort_key.sorted_key_list_of_set_insert
tff(fact_1786_map__distinct__upd__conv,axiom,
    ! [D: $tType,C: $tType,I: nat,La: list(C),F: fun(C,D),X: D] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(list(C),$o,distinct(C),La)
       => ( aa(D,list(D),aa(nat,fun(D,list(D)),aa(list(D),fun(nat,fun(D,list(D))),list_update(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),La)),I),X) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),fun_upd(C,D,F,aa(nat,C,nth(C,La),I),X)),La) ) ) ) ).

% map_distinct_upd_conv
tff(fact_1787_min__list__Min,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( ( Xs != nil(C) )
         => ( min_list(C,Xs) = lattic643756798350308766er_Min(C,aa(list(C),set(C),set2(C),Xs)) ) ) ) ).

% min_list_Min
tff(fact_1788_nth__sorted__list__of__set__greaterThanLessThan,axiom,
    ! [N: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),minus_minus(nat,J,aa(nat,nat,suc,I)))
     => ( aa(nat,nat,nth(nat,aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or5935395276787703475ssThan(nat,I,J))),N) = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),N)) ) ) ).

% nth_sorted_list_of_set_greaterThanLessThan
tff(fact_1789_rev__split__conv,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( La != nil(C) )
     => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),aa(list(C),list(C),tl(C),La))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),La)),nil(C))) = aa(list(C),list(C),rev(C),La) ) ) ).

% rev_split_conv
tff(fact_1790_Un__set__drop__extend,axiom,
    ! [C: $tType,J: nat,La: list(set(C))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,suc,zero_zero(nat))),J)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(set(C)),nat,size_size(list(set(C))),La))
       => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(nat,set(C),nth(set(C),La),minus_minus(nat,J,aa(nat,nat,suc,zero_zero(nat))))),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(list(set(C)),set(set(C)),set2(set(C)),aa(list(set(C)),list(set(C)),aa(nat,fun(list(set(C)),list(set(C))),drop(set(C)),J),La)))) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(list(set(C)),set(set(C)),set2(set(C)),aa(list(set(C)),list(set(C)),aa(nat,fun(list(set(C)),list(set(C))),drop(set(C)),minus_minus(nat,J,aa(nat,nat,suc,zero_zero(nat)))),La))) ) ) ) ).

% Un_set_drop_extend
tff(fact_1791_Sup__bot__conv_I1_J,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( ( aa(set(C),C,complete_Sup_Sup(C),A4) = bot_bot(C) )
        <=> ! [X4: C] :
              ( member2(C,X4,A4)
             => ( X4 = bot_bot(C) ) ) ) ) ).

% Sup_bot_conv(1)
tff(fact_1792_Sup__bot__conv_I2_J,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( ( bot_bot(C) = aa(set(C),C,complete_Sup_Sup(C),A4) )
        <=> ! [X4: C] :
              ( member2(C,X4,A4)
             => ( X4 = bot_bot(C) ) ) ) ) ).

% Sup_bot_conv(2)
tff(fact_1793_Sup__empty,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ( aa(set(C),C,complete_Sup_Sup(C),bot_bot(set(C))) = bot_bot(C) ) ) ).

% Sup_empty
tff(fact_1794_tl__append2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),tl(C),Xs)),Ys) ) ) ).

% tl_append2
tff(fact_1795_map__fun__upd,axiom,
    ! [D: $tType,C: $tType,Y: C,Xs: list(C),F: fun(C,D),V: D] :
      ( ~ member2(C,Y,aa(list(C),set(C),set2(C),Xs))
     => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),fun_upd(C,D,F,Y,V)),Xs) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs) ) ) ).

% map_fun_upd
tff(fact_1796_butlast__rev,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),butlast(C),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),tl(C),Xs)) ).

% butlast_rev
tff(fact_1797_length__tl,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),tl(C),Xs)) = minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat)) ).

% length_tl
tff(fact_1798_hd__Cons__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),Xs)),aa(list(C),list(C),tl(C),Xs)) = Xs ) ) ).

% hd_Cons_tl
tff(fact_1799_list_Ocollapse,axiom,
    ! [C: $tType,List: list(C)] :
      ( ( List != nil(C) )
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),List)),aa(list(C),list(C),tl(C),List)) = List ) ) ).

% list.collapse
tff(fact_1800_in__hd__or__tl__conv,axiom,
    ! [C: $tType,La: list(C),X: C] :
      ( ( La != nil(C) )
     => ( ( ( X = aa(list(C),C,hd(C),La) )
          | member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),tl(C),La))) )
      <=> member2(C,X,aa(list(C),set(C),set2(C),La)) ) ) ).

% in_hd_or_tl_conv
tff(fact_1801_linorder_Oinsort__key_Ocong,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(D,fun(D,$o))] : insort_key(D,C,Less_eq) = insort_key(D,C,Less_eq) ).

% linorder.insort_key.cong
tff(fact_1802_list_Osel_I3_J,axiom,
    ! [C: $tType,X21: C,X22: list(C)] : aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)) = X22 ).

% list.sel(3)
tff(fact_1803_list_Osel_I2_J,axiom,
    ! [C: $tType] : aa(list(C),list(C),tl(C),nil(C)) = nil(C) ).

% list.sel(2)
tff(fact_1804_in__set__tlD,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),tl(C),Xs)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% in_set_tlD
tff(fact_1805_Union__empty,axiom,
    ! [C: $tType] : aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),bot_bot(set(set(C)))) = bot_bot(set(C)) ).

% Union_empty
tff(fact_1806_Union__empty__conv,axiom,
    ! [C: $tType,A4: set(set(C))] :
      ( ( aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),A4) = bot_bot(set(C)) )
    <=> ! [X4: set(C)] :
          ( member2(set(C),X4,A4)
         => ( X4 = bot_bot(set(C)) ) ) ) ).

% Union_empty_conv
tff(fact_1807_empty__Union__conv,axiom,
    ! [C: $tType,A4: set(set(C))] :
      ( ( bot_bot(set(C)) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),A4) )
    <=> ! [X4: set(C)] :
          ( member2(set(C),X4,A4)
         => ( X4 = bot_bot(set(C)) ) ) ) ).

% empty_Union_conv
tff(fact_1808_map__tl,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),tl(D),Xs)) = aa(list(C),list(C),tl(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) ).

% map_tl
tff(fact_1809_Union__take__drop__id,axiom,
    ! [C: $tType,N: nat,La: list(set(C))] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(list(set(C)),set(set(C)),set2(set(C)),aa(list(set(C)),list(set(C)),aa(nat,fun(list(set(C)),list(set(C))),drop(set(C)),N),La)))),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(list(set(C)),set(set(C)),set2(set(C)),aa(list(set(C)),list(set(C)),aa(nat,fun(list(set(C)),list(set(C))),take(set(C)),N),La)))) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(list(set(C)),set(set(C)),set2(set(C)),La)) ).

% Union_take_drop_id
tff(fact_1810_distinct__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),tl(C),Xs)) ) ).

% distinct_tl
tff(fact_1811_tl__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),tl(C),Xs)) ).

% tl_drop
tff(fact_1812_butlast__tl,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),butlast(C),aa(list(C),list(C),tl(C),Xs)) = aa(list(C),list(C),tl(C),aa(list(C),list(C),butlast(C),Xs)) ).

% butlast_tl
tff(fact_1813_less__eq__Sup,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C),U: C] :
          ( ! [V2: C] :
              ( member2(C,V2,A4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),U),V2) )
         => ( ( A4 != bot_bot(set(C)) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),U),aa(set(C),C,complete_Sup_Sup(C),A4)) ) ) ) ).

% less_eq_Sup
tff(fact_1814_tl__obtain__elem,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( ( aa(list(C),list(C),tl(C),Xs) = nil(C) )
       => ~ ! [E: C] : Xs != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E),nil(C)) ) ) ).

% tl_obtain_elem
tff(fact_1815_tl__Nil,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),list(C),tl(C),Xs) = nil(C) )
    <=> ( ( Xs = nil(C) )
        | ? [X4: C] : Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),nil(C)) ) ) ).

% tl_Nil
tff(fact_1816_Nil__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),tl(C),Xs) )
    <=> ( ( Xs = nil(C) )
        | ? [X4: C] : Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),nil(C)) ) ) ).

% Nil_tl
tff(fact_1817_list_Oset__sel_I2_J,axiom,
    ! [C: $tType,A3: list(C),X: C] :
      ( ( A3 != nil(C) )
     => ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),tl(C),A3)))
       => member2(C,X,aa(list(C),set(C),set2(C),A3)) ) ) ).

% list.set_sel(2)
tff(fact_1818_list_Omap__sel_I2_J,axiom,
    ! [D: $tType,C: $tType,A3: list(C),F: fun(C,D)] :
      ( ( A3 != nil(C) )
     => ( aa(list(D),list(D),tl(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),A3)) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(list(C),list(C),tl(C),A3)) ) ) ).

% list.map_sel(2)
tff(fact_1819_sorted__tl,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),tl(C),Xs)) ) ) ).

% sorted_tl
tff(fact_1820_insert__partition,axiom,
    ! [C: $tType,X: set(C),F2: set(set(C))] :
      ( ~ member2(set(C),X,F2)
     => ( ! [X2: set(C)] :
            ( member2(set(C),X2,aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),X),F2))
           => ! [Xa4: set(C)] :
                ( member2(set(C),Xa4,aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),X),F2))
               => ( ( X2 != Xa4 )
                 => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X2),Xa4) = bot_bot(set(C)) ) ) ) )
       => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),F2)) = bot_bot(set(C)) ) ) ) ).

% insert_partition
tff(fact_1821_Union__disjoint,axiom,
    ! [C: $tType,C4: set(set(C)),A4: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4)),A4) = bot_bot(set(C)) )
    <=> ! [X4: set(C)] :
          ( member2(set(C),X4,C4)
         => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X4),A4) = bot_bot(set(C)) ) ) ) ).

% Union_disjoint
tff(fact_1822_Union__Int__subset,axiom,
    ! [C: $tType,A4: set(set(C)),B3: set(set(C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),inf_inf(set(set(C))),A4),B3))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),A4)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),B3))) ).

% Union_Int_subset
tff(fact_1823_take__tl,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),tl(C),Xs)) = aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,suc,N)),Xs)) ).

% take_tl
tff(fact_1824_drop__Suc,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(nat,nat,suc,N)),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),tl(C),Xs)) ).

% drop_Suc
tff(fact_1825_list_Oexpand,axiom,
    ! [C: $tType,List: list(C),List2: list(C)] :
      ( ( ( List = nil(C) )
      <=> ( List2 = nil(C) ) )
     => ( ( ( List != nil(C) )
         => ( ( List2 != nil(C) )
           => ( ( aa(list(C),C,hd(C),List) = aa(list(C),C,hd(C),List2) )
              & ( aa(list(C),list(C),tl(C),List) = aa(list(C),list(C),tl(C),List2) ) ) ) )
       => ( List = List2 ) ) ) ).

% list.expand
tff(fact_1826_not__hd__in__tl,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ( X != aa(list(C),C,hd(C),Xs) )
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),tl(C),Xs))) ) ) ).

% not_hd_in_tl
tff(fact_1827_tl__last,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),list(C),tl(C),Xs) != nil(C) )
     => ( last(C,Xs) = last(C,aa(list(C),list(C),tl(C),Xs)) ) ) ).

% tl_last
tff(fact_1828_last__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( ( Xs = nil(C) )
        | ( aa(list(C),list(C),tl(C),Xs) != nil(C) ) )
     => ( last(C,aa(list(C),list(C),tl(C),Xs)) = last(C,Xs) ) ) ).

% last_tl
tff(fact_1829_sorted__list__of__set__greaterThanLessThan,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,I)),J)
     => ( aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or5935395276787703475ssThan(nat,I,J)) = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),aa(nat,nat,suc,I)),aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or5935395276787703475ssThan(nat,aa(nat,nat,suc,I),J))) ) ) ).

% sorted_list_of_set_greaterThanLessThan
tff(fact_1830_rev__butlast__is__tl__rev,axiom,
    ! [C: $tType,La: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),butlast(C),La)) = aa(list(C),list(C),tl(C),aa(list(C),list(C),rev(C),La)) ).

% rev_butlast_is_tl_rev
tff(fact_1831_finite__Sup__in,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C,Y2: C] :
                  ( member2(C,X2,A4)
                 => ( member2(C,Y2,A4)
                   => member2(C,aa(C,C,aa(C,fun(C,C),sup_sup(C),X2),Y2),A4) ) )
             => member2(C,aa(set(C),C,complete_Sup_Sup(C),A4),A4) ) ) ) ) ).

% finite_Sup_in
tff(fact_1832_Sup__inter__less__eq,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C),B3: set(C)] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))),aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Sup_Sup(C),A4)),aa(set(C),C,complete_Sup_Sup(C),B3))) ) ).

% Sup_inter_less_eq
tff(fact_1833_tl__subset,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] :
      ( ( Xs != nil(C) )
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),A4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),tl(C),Xs))),A4) ) ) ).

% tl_subset
tff(fact_1834_Misc_Onth__tl,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( ( Xs != nil(C) )
     => ( aa(nat,C,nth(C,aa(list(C),list(C),tl(C),Xs)),N) = aa(nat,C,nth(C,Xs),aa(nat,nat,suc,N)) ) ) ).

% Misc.nth_tl
tff(fact_1835_list__take__induct__tl2,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D),Pa: fun(D,fun(C,$o))] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( ! [N7: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N7),aa(list(C),nat,size_size(list(C)),Xs))
           => aa(C,$o,aa(D,fun(C,$o),Pa,aa(nat,D,nth(D,Ys),N7)),aa(nat,C,nth(C,Xs),N7)) )
       => ! [N8: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N8),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),tl(C),Xs)))
           => aa(C,$o,aa(D,fun(C,$o),Pa,aa(nat,D,nth(D,aa(list(D),list(D),tl(D),Ys)),N8)),aa(nat,C,nth(C,aa(list(C),list(C),tl(C),Xs)),N8)) ) ) ) ).

% list_take_induct_tl2
tff(fact_1836_Max__Sup,axiom,
    ! [C: $tType] :
      ( comple5582772986160207858norder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic643756798349783984er_Max(C,A4) = aa(set(C),C,complete_Sup_Sup(C),A4) ) ) ) ) ).

% Max_Sup
tff(fact_1837_list_Oexhaust__sel,axiom,
    ! [C: $tType,List: list(C)] :
      ( ( List != nil(C) )
     => ( List = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),List)),aa(list(C),list(C),tl(C),List)) ) ) ).

% list.exhaust_sel
tff(fact_1838_Sup__fin__Sup,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic5882676163264333800up_fin(C,A4) = aa(set(C),C,complete_Sup_Sup(C),A4) ) ) ) ) ).

% Sup_fin_Sup
tff(fact_1839_tl__take,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,N,one_one(nat))),aa(list(C),list(C),tl(C),Xs)) ).

% tl_take
tff(fact_1840_distinct__hd__tl,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( ( X = aa(list(C),C,hd(C),Xs) )
       => ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),tl(C),Xs))) ) ) ).

% distinct_hd_tl
tff(fact_1841_butlast__rev__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),butlast(C),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),tl(C),Xs)) ) ) ).

% butlast_rev_tl
tff(fact_1842_remove1__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),aa(list(C),C,hd(C),Xs)),Xs) = aa(list(C),list(C),tl(C),Xs) ) ) ).

% remove1_tl
tff(fact_1843_list__collect__set__as__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,set(C)),La: list(D)] : list_collect_set(D,C,F,La) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(list(set(C)),set(set(C)),set2(set(C)),aa(list(D),list(set(C)),aa(fun(D,set(C)),fun(list(D),list(set(C))),map(D,set(C)),F),La))) ).

% list_collect_set_as_map
tff(fact_1844_List_Onth__tl,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),tl(C),Xs)))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),tl(C),Xs)),N) = aa(nat,C,nth(C,Xs),aa(nat,nat,suc,N)) ) ) ).

% List.nth_tl
tff(fact_1845_card__partition,axiom,
    ! [C: $tType,C4: set(set(C)),K: nat] :
      ( aa(set(set(C)),$o,finite_finite2(set(C)),C4)
     => ( aa(set(C),$o,finite_finite2(C),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4))
       => ( ! [C2: set(C)] :
              ( member2(set(C),C2,C4)
             => ( finite_card(C,C2) = K ) )
         => ( ! [C13: set(C),C24: set(C)] :
                ( member2(set(C),C13,C4)
               => ( member2(set(C),C24,C4)
                 => ( ( C13 != C24 )
                   => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),C13),C24) = bot_bot(set(C)) ) ) ) )
           => ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),finite_card(set(C),C4)) = finite_card(C,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4)) ) ) ) ) ) ).

% card_partition
tff(fact_1846_take__Suc,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,suc,N)),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),Xs)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),tl(C),Xs))) ) ) ).

% take_Suc
tff(fact_1847_rotate1__hd__tl,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),rotate1(C),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),tl(C),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(list(C),C,hd(C),Xs)),nil(C))) ) ) ).

% rotate1_hd_tl
tff(fact_1848_Int__greaterThanLessThan,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or5935395276787703475ssThan(C,A3,B2)),set_or5935395276787703475ssThan(C,C3,D3)) = set_or5935395276787703475ssThan(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),D3)) ) ).

% Int_greaterThanLessThan
tff(fact_1849_greaterThanLessThan__empty__iff2,axiom,
    ! [C: $tType] :
      ( dense_linorder(C)
     => ! [A3: C,B2: C] :
          ( ( bot_bot(set(C)) = set_or5935395276787703475ssThan(C,A3,B2) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% greaterThanLessThan_empty_iff2
tff(fact_1850_greaterThanLessThan__empty__iff,axiom,
    ! [C: $tType] :
      ( dense_linorder(C)
     => ! [A3: C,B2: C] :
          ( ( set_or5935395276787703475ssThan(C,A3,B2) = bot_bot(set(C)) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ).

% greaterThanLessThan_empty_iff
tff(fact_1851_greaterThanLessThan__empty,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,K: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),La),K)
         => ( set_or5935395276787703475ssThan(C,K,La) = bot_bot(set(C)) ) ) ) ).

% greaterThanLessThan_empty
tff(fact_1852_cSup__singleton,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X: C] : aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% cSup_singleton
tff(fact_1853_ccpo__Sup__singleton,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [X: C] : aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% ccpo_Sup_singleton
tff(fact_1854_Nitpick_Osize__list__simp_I2_J,axiom,
    ! [C: $tType,Xs: list(C)] :
      aa(list(C),nat,size_size(list(C)),Xs) = $ite(Xs = nil(C),zero_zero(nat),aa(nat,nat,suc,aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),tl(C),Xs)))) ).

% Nitpick.size_list_simp(2)
tff(fact_1855_cSup__least,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),Z2: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,X5)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Z2) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),X5)),Z2) ) ) ) ).

% cSup_least
tff(fact_1856_cSup__eq__non__empty,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),A3: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,X5)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),A3) )
           => ( ! [Y2: C] :
                  ( ! [X3: C] :
                      ( member2(C,X3,X5)
                     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X3),Y2) )
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),Y2) )
             => ( aa(set(C),C,complete_Sup_Sup(C),X5) = A3 ) ) ) ) ) ).

% cSup_eq_non_empty
tff(fact_1857_less__cSupE,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [Y: C,X5: set(C)] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),aa(set(C),C,complete_Sup_Sup(C),X5))
         => ( ( X5 != bot_bot(set(C)) )
           => ~ ! [X2: C] :
                  ( member2(C,X2,X5)
                 => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X2) ) ) ) ) ).

% less_cSupE
tff(fact_1858_less__cSupD,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C),Z2: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),aa(set(C),C,complete_Sup_Sup(C),X5))
           => ? [X2: C] :
                ( member2(C,X2,X5)
                & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),X2) ) ) ) ) ).

% less_cSupD
tff(fact_1859_finite__Sup__less__iff,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C),A3: C] :
          ( aa(set(C),$o,finite_finite2(C),X5)
         => ( ( X5 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(set(C),C,complete_Sup_Sup(C),X5)),A3)
            <=> ! [X4: C] :
                  ( member2(C,X4,X5)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),A3) ) ) ) ) ) ).

% finite_Sup_less_iff
tff(fact_1860_cSup__eq__Max,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),X5)
         => ( ( X5 != bot_bot(set(C)) )
           => ( aa(set(C),C,complete_Sup_Sup(C),X5) = lattic643756798349783984er_Max(C,X5) ) ) ) ) ).

% cSup_eq_Max
tff(fact_1861_cSup__eq__Sup__fin,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),X5)
         => ( ( X5 != bot_bot(set(C)) )
           => ( aa(set(C),C,complete_Sup_Sup(C),X5) = lattic5882676163264333800up_fin(C,X5) ) ) ) ) ).

% cSup_eq_Sup_fin
tff(fact_1862_Sup__insert__finite,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [S: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),S)) = $ite(S = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),ord_max(C),X),aa(set(C),C,complete_Sup_Sup(C),S))) ) ) ) ).

% Sup_insert_finite
tff(fact_1863_Sup__inf__eq__bot__iff,axiom,
    ! [C: $tType] :
      ( comple592849572758109894attice(C)
     => ! [B3: set(C),A3: C] :
          ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Sup_Sup(C),B3)),A3) = bot_bot(C) )
        <=> ! [X4: C] :
              ( member2(C,X4,B3)
             => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X4),A3) = bot_bot(C) ) ) ) ) ).

% Sup_inf_eq_bot_iff
tff(fact_1864_Nitpick_Osize__list__simp_I1_J,axiom,
    ! [C: $tType,F: fun(C,nat),Xs: list(C)] :
      aa(list(C),nat,size_list(C,F),Xs) = $ite(Xs = nil(C),zero_zero(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(C,nat,F,aa(list(C),C,hd(C),Xs))),aa(list(C),nat,size_list(C,F),aa(list(C),list(C),tl(C),Xs))))) ).

% Nitpick.size_list_simp(1)
tff(fact_1865_nth__sorted__list__of__set__greaterThanAtMost,axiom,
    ! [N: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),minus_minus(nat,J,I))
     => ( aa(nat,nat,nth(nat,aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or3652927894154168847AtMost(nat,I,J))),N) = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),N)) ) ) ).

% nth_sorted_list_of_set_greaterThanAtMost
tff(fact_1866_list_Osplit__sel__asm,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),F1: C,F22: fun(D,fun(list(D),C)),List: list(D)] :
      ( aa(C,$o,Pa,aa(list(D),C,aa(fun(D,fun(list(D),C)),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),C)),fun(list(D),C)),case_list(C,D),F1),F22),List))
    <=> ~ ( ( ( List = nil(D) )
            & ~ aa(C,$o,Pa,F1) )
          | ( ( List = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),aa(list(D),D,hd(D),List)),aa(list(D),list(D),tl(D),List)) )
            & ~ aa(C,$o,Pa,aa(list(D),C,aa(D,fun(list(D),C),F22,aa(list(D),D,hd(D),List)),aa(list(D),list(D),tl(D),List))) ) ) ) ).

% list.split_sel_asm
tff(fact_1867_list_Osplit__sel,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),F1: C,F22: fun(D,fun(list(D),C)),List: list(D)] :
      ( aa(C,$o,Pa,aa(list(D),C,aa(fun(D,fun(list(D),C)),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),C)),fun(list(D),C)),case_list(C,D),F1),F22),List))
    <=> ( ( ( List = nil(D) )
         => aa(C,$o,Pa,F1) )
        & ( ( List = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),aa(list(D),D,hd(D),List)),aa(list(D),list(D),tl(D),List)) )
         => aa(C,$o,Pa,aa(list(D),C,aa(D,fun(list(D),C),F22,aa(list(D),D,hd(D),List)),aa(list(D),list(D),tl(D),List))) ) ) ) ).

% list.split_sel
tff(fact_1868_finite__enumerate__initial__segment,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [S: set(C),N: nat,S4: C] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),set_ord_lessThan(C,S4))))
           => ( infini527867602293511546merate(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),set_ord_lessThan(C,S4)),N) = infini527867602293511546merate(C,S,N) ) ) ) ) ).

% finite_enumerate_initial_segment
tff(fact_1869_Pow__set_I1_J,axiom,
    ! [C: $tType] : pow(C,aa(list(C),set(C),set2(C),nil(C))) = aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),bot_bot(set(C))),bot_bot(set(set(C)))) ).

% Pow_set(1)
tff(fact_1870_PowI,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => member2(set(C),A4,pow(C,B3)) ) ).

% PowI
tff(fact_1871_Pow__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( member2(set(C),A4,pow(C,B3))
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ).

% Pow_iff
tff(fact_1872_greaterThanAtMost__empty,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,K: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),La),K)
         => ( set_or3652927894154168847AtMost(C,K,La) = bot_bot(set(C)) ) ) ) ).

% greaterThanAtMost_empty
tff(fact_1873_greaterThanAtMost__empty__iff,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [K: C,La: C] :
          ( ( set_or3652927894154168847AtMost(C,K,La) = bot_bot(set(C)) )
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),K),La) ) ) ).

% greaterThanAtMost_empty_iff
tff(fact_1874_greaterThanAtMost__empty__iff2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [K: C,La: C] :
          ( ( bot_bot(set(C)) = set_or3652927894154168847AtMost(C,K,La) )
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),K),La) ) ) ).

% greaterThanAtMost_empty_iff2
tff(fact_1875_size__list__append,axiom,
    ! [C: $tType,F: fun(C,nat),Xs: list(C),Ys: list(C)] : aa(list(C),nat,size_list(C,F),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_list(C,F),Xs)),aa(list(C),nat,size_list(C,F),Ys)) ).

% size_list_append
tff(fact_1876_sorted__list__of__set__lessThan__Suc,axiom,
    ! [K: nat] : aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_ord_lessThan(nat,aa(nat,nat,suc,K))) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_ord_lessThan(nat,K))),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),K),nil(nat))) ).

% sorted_list_of_set_lessThan_Suc
tff(fact_1877_Pow__Int__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : pow(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),inf_inf(set(set(C))),pow(C,A4)),pow(C,B3)) ).

% Pow_Int_eq
tff(fact_1878_single__Diff__lessThan,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [K: C] : minus_minus(set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),K),bot_bot(set(C))),set_ord_lessThan(C,K)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),K),bot_bot(set(C))) ) ).

% single_Diff_lessThan
tff(fact_1879_Int__greaterThanAtMost,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or3652927894154168847AtMost(C,A3,B2)),set_or3652927894154168847AtMost(C,C3,D3)) = set_or3652927894154168847AtMost(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),D3)) ) ).

% Int_greaterThanAtMost
tff(fact_1880_Pow__empty,axiom,
    ! [C: $tType] : pow(C,bot_bot(set(C))) = aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),bot_bot(set(C))),bot_bot(set(set(C)))) ).

% Pow_empty
tff(fact_1881_Pow__singleton__iff,axiom,
    ! [C: $tType,X5: set(C),Y5: set(C)] :
      ( ( pow(C,X5) = aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),Y5),bot_bot(set(set(C)))) )
    <=> ( ( X5 = bot_bot(set(C)) )
        & ( Y5 = bot_bot(set(C)) ) ) ) ).

% Pow_singleton_iff
tff(fact_1882_Pow__top,axiom,
    ! [C: $tType,A4: set(C)] : member2(set(C),A4,pow(C,A4)) ).

% Pow_top
tff(fact_1883_Pow__bottom,axiom,
    ! [C: $tType,B3: set(C)] : member2(set(C),bot_bot(set(C)),pow(C,B3)) ).

% Pow_bottom
tff(fact_1884_PowD,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( member2(set(C),A4,pow(C,B3))
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3) ) ).

% PowD
tff(fact_1885_Pow__mono,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => aa(set(set(C)),$o,aa(set(set(C)),fun(set(set(C)),$o),ord_less_eq(set(set(C))),pow(C,A4)),pow(C,B3)) ) ).

% Pow_mono
tff(fact_1886_Un__Pow__subset,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(set(C)),$o,aa(set(set(C)),fun(set(set(C)),$o),ord_less_eq(set(set(C))),aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),sup_sup(set(set(C))),pow(C,A4)),pow(C,B3))),pow(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))) ).

% Un_Pow_subset
tff(fact_1887_lessThan__non__empty,axiom,
    ! [C: $tType] :
      ( no_bot(C)
     => ! [X: C] : set_ord_lessThan(C,X) != bot_bot(set(C)) ) ).

% lessThan_non_empty
tff(fact_1888_Pow__not__empty,axiom,
    ! [C: $tType,A4: set(C)] : pow(C,A4) != bot_bot(set(set(C))) ).

% Pow_not_empty
tff(fact_1889_list_Osimps_I5_J,axiom,
    ! [C: $tType,D: $tType,F1: C,F22: fun(D,fun(list(D),C)),X21: D,X22: list(D)] : aa(list(D),C,aa(fun(D,fun(list(D),C)),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),C)),fun(list(D),C)),case_list(C,D),F1),F22),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X21),X22)) = aa(list(D),C,aa(D,fun(list(D),C),F22,X21),X22) ).

% list.simps(5)
tff(fact_1890_list_Osimps_I4_J,axiom,
    ! [D: $tType,C: $tType,F1: C,F22: fun(D,fun(list(D),C))] : aa(list(D),C,aa(fun(D,fun(list(D),C)),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),C)),fun(list(D),C)),case_list(C,D),F1),F22),nil(D)) = F1 ).

% list.simps(4)
tff(fact_1891_ivl__disj__int__two_I6_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or3652927894154168847AtMost(C,La,M2)),set_or3652927894154168847AtMost(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(6)
tff(fact_1892_Iio__eq__empty__iff,axiom,
    ! [C: $tType] :
      ( ( linorder(C)
        & order_bot(C) )
     => ! [N: C] :
          ( ( set_ord_lessThan(C,N) = bot_bot(set(C)) )
        <=> ( N = bot_bot(C) ) ) ) ).

% Iio_eq_empty_iff
tff(fact_1893_greaterThan__Int__greaterThan,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_lessThan(C,A3)),set_ord_lessThan(C,B2)) = set_ord_lessThan(C,aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)) ) ).

% greaterThan_Int_greaterThan
tff(fact_1894_list_Osize__gen_I1_J,axiom,
    ! [C: $tType,X: fun(C,nat)] : aa(list(C),nat,size_list(C,X),nil(C)) = zero_zero(nat) ).

% list.size_gen(1)
tff(fact_1895_size__list__estimation,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: nat,F: fun(C,nat)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Y),aa(C,nat,F,X))
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Y),aa(list(C),nat,size_list(C,F),Xs)) ) ) ).

% size_list_estimation
tff(fact_1896_size__list__estimation_H,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: nat,F: fun(C,nat)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Y),aa(C,nat,F,X))
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Y),aa(list(C),nat,size_list(C,F),Xs)) ) ) ).

% size_list_estimation'
tff(fact_1897_size__list__pointwise,axiom,
    ! [C: $tType,Xs: list(C),F: fun(C,nat),G: fun(C,nat)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(C,nat,F,X2)),aa(C,nat,G,X2)) )
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_list(C,F),Xs)),aa(list(C),nat,size_list(C,G),Xs)) ) ).

% size_list_pointwise
tff(fact_1898_Ioc__disjoint,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or3652927894154168847AtMost(C,A3,B2)),set_or3652927894154168847AtMost(C,C3,D3)) = bot_bot(set(C)) )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),D3),C3)
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),C3)
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),D3),A3) ) ) ) ).

% Ioc_disjoint
tff(fact_1899_ivl__disj__int__two_I2_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or3652927894154168847AtMost(C,La,M2)),set_or5935395276787703475ssThan(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(2)
tff(fact_1900_Iio__Int__singleton,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [K: C,X: C] :
          aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_lessThan(C,K)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),K),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),bot_bot(set(C))) ) ).

% Iio_Int_singleton
tff(fact_1901_sorted__list__of__set__greaterThanAtMost,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,suc,I)),J)
     => ( aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or3652927894154168847AtMost(nat,I,J)) = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),aa(nat,nat,suc,I)),aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or3652927894154168847AtMost(nat,aa(nat,nat,suc,I),J))) ) ) ).

% sorted_list_of_set_greaterThanAtMost
tff(fact_1902_list_Ocase__eq__if,axiom,
    ! [C: $tType,D: $tType,F1: C,F22: fun(D,fun(list(D),C)),List: list(D)] :
      aa(list(D),C,aa(fun(D,fun(list(D),C)),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),C)),fun(list(D),C)),case_list(C,D),F1),F22),List) = $ite(List = nil(D),F1,aa(list(D),C,aa(D,fun(list(D),C),F22,aa(list(D),D,hd(D),List)),aa(list(D),list(D),tl(D),List))) ).

% list.case_eq_if
tff(fact_1903_ivl__disj__un__singleton_I4_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: C,U: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),La),U)
         => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),set_or5935395276787703475ssThan(C,La,U)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),U),bot_bot(set(C)))) = set_or3652927894154168847AtMost(C,La,U) ) ) ) ).

% ivl_disj_un_singleton(4)
tff(fact_1904_butlast__upd__last__eq,axiom,
    ! [C: $tType,La: list(C),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),butlast(C),La)),minus_minus(nat,aa(list(C),nat,size_size(list(C)),La),aa(num,nat,numeral_numeral(nat),bit0(one2)))),X) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),La),aa(num,nat,numeral_numeral(nat),bit0(one2)))),La)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ) ) ).

% butlast_upd_last_eq
tff(fact_1905_map__sorted__distinct__set__unique,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C),Ys: list(C)] :
          ( inj_on(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)))
         => ( sorted_wrt(D,ord_less_eq(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))
           => ( aa(list(D),$o,distinct(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))
             => ( sorted_wrt(D,ord_less_eq(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Ys))
               => ( aa(list(D),$o,distinct(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Ys))
                 => ( ( aa(list(C),set(C),set2(C),Xs) = aa(list(C),set(C),set2(C),Ys) )
                   => ( Xs = Ys ) ) ) ) ) ) ) ) ).

% map_sorted_distinct_set_unique
tff(fact_1906_sorted__insort__insert__key,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D),X: D] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
         => sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),linord329482645794927042rt_key(D,C,F,X,Xs))) ) ) ).

% sorted_insort_insert_key
tff(fact_1907_distinct__adj__append__iff,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( aa(list(C),$o,distinct_adj(C),Xs)
        & aa(list(C),$o,distinct_adj(C),Ys)
        & ( ( Xs = nil(C) )
          | ( Ys = nil(C) )
          | ( last(C,Xs) != aa(list(C),C,hd(C),Ys) ) ) ) ) ).

% distinct_adj_append_iff
tff(fact_1908_numeral__plus__one,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ! [N: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),N)),one_one(C)) = aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),plus_plus(num),N),one2)) ) ).

% numeral_plus_one
tff(fact_1909_one__plus__numeral,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ! [N: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(num,C,numeral_numeral(C),N)) = aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),N)) ) ).

% one_plus_numeral
tff(fact_1910_nth__rotate1,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),rotate1(C),Xs)),N) = aa(nat,C,nth(C,Xs),modulo_modulo(nat,aa(nat,nat,suc,N),aa(list(C),nat,size_size(list(C)),Xs))) ) ) ).

% nth_rotate1
tff(fact_1911_inj__on__rev,axiom,
    ! [C: $tType,A4: set(list(C))] : inj_on(list(C),list(C),rev(C),A4) ).

% inj_on_rev
tff(fact_1912_distinct__adj__Cons__Cons,axiom,
    ! [C: $tType,X: C,Y: C,Xs: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)))
    <=> ( ( X != Y )
        & aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)) ) ) ).

% distinct_adj_Cons_Cons
tff(fact_1913_distinct__adj__rev,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),rev(C),Xs))
    <=> aa(list(C),$o,distinct_adj(C),Xs) ) ).

% distinct_adj_rev
tff(fact_1914_numeral__eq__one__iff,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [N: num] :
          ( ( aa(num,C,numeral_numeral(C),N) = one_one(C) )
        <=> ( N = one2 ) ) ) ).

% numeral_eq_one_iff
tff(fact_1915_one__eq__numeral__iff,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [N: num] :
          ( ( one_one(C) = aa(num,C,numeral_numeral(C),N) )
        <=> ( one2 = N ) ) ) ).

% one_eq_numeral_iff
tff(fact_1916_mod__by__1,axiom,
    ! [C: $tType] :
      ( semidom_modulo(C)
     => ! [A3: C] : modulo_modulo(C,A3,one_one(C)) = zero_zero(C) ) ).

% mod_by_1
tff(fact_1917_numeral__le__one__iff,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [N: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(num,C,numeral_numeral(C),N)),one_one(C))
        <=> aa(num,$o,aa(num,fun(num,$o),ord_less_eq(num),N),one2) ) ) ).

% numeral_le_one_iff
tff(fact_1918_one__less__numeral__iff,axiom,
    ! [C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [N: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(num,C,numeral_numeral(C),N))
        <=> aa(num,$o,aa(num,fun(num,$o),ord_less(num),one2),N) ) ) ).

% one_less_numeral_iff
tff(fact_1919_one__add__one,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),one_one(C)) = aa(num,C,numeral_numeral(C),bit0(one2)) ) ) ).

% one_add_one
tff(fact_1920_card__doubleton__eq__2__iff,axiom,
    ! [C: $tType,A3: C,B2: C] :
      ( ( finite_card(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) = aa(num,nat,numeral_numeral(nat),bit0(one2)) )
    <=> ( A3 != B2 ) ) ).

% card_doubleton_eq_2_iff
tff(fact_1921_inj__on__Cons1,axiom,
    ! [C: $tType,X: C,A4: set(list(C))] : inj_on(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),A4) ).

% inj_on_Cons1
tff(fact_1922_distinct__adj__map__iff,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),Xs: list(C)] :
      ( inj_on(C,D,F,aa(list(C),set(C),set2(C),Xs))
     => ( aa(list(D),$o,distinct_adj(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))
      <=> aa(list(C),$o,distinct_adj(C),Xs) ) ) ).

% distinct_adj_map_iff
tff(fact_1923_distinct__adj__mapI,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,D)] :
      ( aa(list(C),$o,distinct_adj(C),Xs)
     => ( inj_on(C,D,F,aa(list(C),set(C),set2(C),Xs))
       => aa(list(D),$o,distinct_adj(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) ) ) ).

% distinct_adj_mapI
tff(fact_1924_divmod__digit__0_I2_J,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2))),B2)
           => ( modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2)) = modulo_modulo(C,A3,B2) ) ) ) ) ).

% divmod_digit_0(2)
tff(fact_1925_folding__insort__key_Oinj__on,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => inj_on(D,C,F,S) ) ).

% folding_insort_key.inj_on
tff(fact_1926_distinct__adj__ConsD,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
     => aa(list(C),$o,distinct_adj(C),Xs) ) ).

% distinct_adj_ConsD
tff(fact_1927_distinct__adj__Nil,axiom,
    ! [C: $tType] : aa(list(C),$o,distinct_adj(C),nil(C)) ).

% distinct_adj_Nil
tff(fact_1928_left__add__twice,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),A3)),B2) ) ).

% left_add_twice
tff(fact_1929_mult__2__right,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [Z2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),Z2),aa(num,C,numeral_numeral(C),bit0(one2))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),Z2) ) ).

% mult_2_right
tff(fact_1930_mult__2,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [Z2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Z2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),Z2) ) ).

% mult_2
tff(fact_1931_distinct__adj__mapD,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
     => aa(list(D),$o,distinct_adj(D),Xs) ) ).

% distinct_adj_mapD
tff(fact_1932_distinct__adj__appendD2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
     => aa(list(C),$o,distinct_adj(C),Ys) ) ).

% distinct_adj_appendD2
tff(fact_1933_distinct__adj__appendD1,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
     => aa(list(C),$o,distinct_adj(C),Xs) ) ).

% distinct_adj_appendD1
tff(fact_1934_power4__eq__xxxx,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [X: C] : aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(bit0(one2)))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),X)),X)),X) ) ).

% power4_eq_xxxx
tff(fact_1935_power2__eq__square,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),bit0(one2))) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),A3) ) ).

% power2_eq_square
tff(fact_1936_one__power2,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ( aa(nat,C,aa(C,fun(nat,C),power_power(C),one_one(C)),aa(num,nat,numeral_numeral(nat),bit0(one2))) = one_one(C) ) ) ).

% one_power2
tff(fact_1937_mod__double__modulus,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [M2: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),M2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
           => ( ( modulo_modulo(C,X,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)) = modulo_modulo(C,X,M2) )
              | ( modulo_modulo(C,X,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,X,M2)),M2) ) ) ) ) ) ).

% mod_double_modulus
tff(fact_1938_divmod__digit__1_I2_J,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2)))
             => ( minus_minus(C,modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2)),B2) = modulo_modulo(C,A3,B2) ) ) ) ) ) ).

% divmod_digit_1(2)
tff(fact_1939_inj__on__mult,axiom,
    ! [C: $tType] :
      ( semidom_divide(C)
     => ! [A3: C,A4: set(C)] :
          ( ( A3 != zero_zero(C) )
         => inj_on(C,C,aa(C,fun(C,C),times_times(C),A3),A4) ) ) ).

% inj_on_mult
tff(fact_1940_list__decomp__2,axiom,
    ! [C: $tType,La: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),La) = aa(num,nat,numeral_numeral(nat),bit0(one2)) )
     => ? [A5: C,B4: C] : La = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B4),nil(C))) ) ).

% list_decomp_2
tff(fact_1941_card__2__iff,axiom,
    ! [C: $tType,S: set(C)] :
      ( ( finite_card(C,S) = aa(num,nat,numeral_numeral(nat),bit0(one2)) )
    <=> ? [X4: C,Y3: C] :
          ( ( S = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y3),bot_bot(set(C)))) )
          & ( X4 != Y3 ) ) ) ).

% card_2_iff
tff(fact_1942_mult__numeral__1,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),one2)),A3) = A3 ) ).

% mult_numeral_1
tff(fact_1943_mult__numeral__1__right,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),one2)) = A3 ) ).

% mult_numeral_1_right
tff(fact_1944_numeral__One,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ( aa(num,C,numeral_numeral(C),one2) = one_one(C) ) ) ).

% numeral_One
tff(fact_1945_distinct__insort__insert,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Xs: list(C),F: fun(C,D),X: C] :
          ( aa(list(C),$o,distinct(C),Xs)
         => aa(list(C),$o,distinct(C),linord329482645794927042rt_key(C,D,F,X,Xs)) ) ) ).

% distinct_insort_insert
tff(fact_1946_length__subseqs,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(list(C)),nat,size_size(list(list(C))),aa(list(C),list(list(C)),subseqs(C),Xs)) = aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_subseqs
tff(fact_1947_power2__sum,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [X: C,Y: C] : aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y)),aa(num,nat,numeral_numeral(nat),bit0(one2))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(one2)))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Y),aa(num,nat,numeral_numeral(nat),bit0(one2))))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),X)),Y)) ) ).

% power2_sum
tff(fact_1948_power__odd__eq,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N))) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)),aa(num,nat,numeral_numeral(nat),bit0(one2)))) ) ).

% power_odd_eq
tff(fact_1949_distinct__adj__singleton,axiom,
    ! [C: $tType,X: C] : aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% distinct_adj_singleton
tff(fact_1950_map__inj__on,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),Ys: list(D)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ys) )
     => ( inj_on(D,C,F,aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),aa(list(D),set(D),set2(D),Xs)),aa(list(D),set(D),set2(D),Ys)))
       => ( Xs = Ys ) ) ) ).

% map_inj_on
tff(fact_1951_inj__on__map__eq__map,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),Xs: list(C),Ys: list(C)] :
      ( inj_on(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)))
     => ( ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Ys) )
      <=> ( Xs = Ys ) ) ) ).

% inj_on_map_eq_map
tff(fact_1952_distinct__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] :
      ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
    <=> ( aa(list(D),$o,distinct(D),Xs)
        & inj_on(D,C,F,aa(list(D),set(D),set2(D),Xs)) ) ) ).

% distinct_map
tff(fact_1953_power2__diff,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [X: C,Y: C] : aa(nat,C,aa(C,fun(nat,C),power_power(C),minus_minus(C,X,Y)),aa(num,nat,numeral_numeral(nat),bit0(one2))) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(one2)))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Y),aa(num,nat,numeral_numeral(nat),bit0(one2)))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),X)),Y)) ) ).

% power2_diff
tff(fact_1954_inj__on__nth,axiom,
    ! [C: $tType,Xs: list(C),I5: set(nat)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( ! [X2: nat] :
            ( member2(nat,X2,I5)
           => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),aa(list(C),nat,size_size(list(C)),Xs)) )
       => inj_on(nat,C,nth(C,Xs),I5) ) ) ).

% inj_on_nth
tff(fact_1955_map__removeAll__inj__on,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),X: C,Xs: list(C)] :
      ( inj_on(C,D,F,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(list(C),set(C),set2(C),Xs)))
     => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),removeAll(D),aa(C,D,F,X)),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) ) ) ).

% map_removeAll_inj_on
tff(fact_1956_distinct__adj__Cons,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> ( ( Xs = nil(C) )
        | ( ( X != aa(list(C),C,hd(C),Xs) )
          & aa(list(C),$o,distinct_adj(C),Xs) ) ) ) ).

% distinct_adj_Cons
tff(fact_1957_not__mod__2__eq__0__eq__1,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) != zero_zero(C) )
        <=> ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) = one_one(C) ) ) ) ).

% not_mod_2_eq_0_eq_1
tff(fact_1958_not__mod__2__eq__1__eq__0,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) != one_one(C) )
        <=> ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) = zero_zero(C) ) ) ) ).

% not_mod_2_eq_1_eq_0
tff(fact_1959_one__mod__two__eq__one,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ( modulo_modulo(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))) = one_one(C) ) ) ).

% one_mod_two_eq_one
tff(fact_1960_bits__one__mod__two__eq__one,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ( modulo_modulo(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))) = one_one(C) ) ) ).

% bits_one_mod_two_eq_one
tff(fact_1961_mask__mod__exp,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [N: nat,M2: nat] : modulo_modulo(C,minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N),one_one(C)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)) = minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),M2),N)),one_one(C)) ) ).

% mask_mod_exp
tff(fact_1962_mult__exp__mod__exp__eq,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [M2: nat,N: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),modulo_modulo(C,A3,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),minus_minus(nat,N,M2)))),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)) ) ) ) ).

% mult_exp_mod_exp_eq
tff(fact_1963_mod__mult__self1,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,C3: C,B2: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)),B2) = modulo_modulo(C,A3,B2) ) ).

% mod_mult_self1
tff(fact_1964_mod__mult__self2__is__0,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,B2: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),B2) = zero_zero(C) ) ).

% mod_mult_self2_is_0
tff(fact_1965_mod__mult__self1__is__0,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,A3: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3),B2) = zero_zero(C) ) ).

% mod_mult_self1_is_0
tff(fact_1966_bits__mod__by__1,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C] : modulo_modulo(C,A3,one_one(C)) = zero_zero(C) ) ).

% bits_mod_by_1
tff(fact_1967_mod__mult__self4,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,C3: C,A3: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)),A3),B2) = modulo_modulo(C,A3,B2) ) ).

% mod_mult_self4
tff(fact_1968_mod__mult__self3,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [C3: C,B2: C,A3: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)),A3),B2) = modulo_modulo(C,A3,B2) ) ).

% mod_mult_self3
tff(fact_1969_mod__mult__self2,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,B2: C,C3: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)),B2) = modulo_modulo(C,A3,B2) ) ).

% mod_mult_self2
tff(fact_1970_mod__mult__eq,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,C3: C,B2: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),modulo_modulo(C,A3,C3)),modulo_modulo(C,B2,C3)),C3) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ).

% mod_mult_eq
tff(fact_1971_mod__mult__cong,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,C3: C,A10: C,B2: C,B8: C] :
          ( ( modulo_modulo(C,A3,C3) = modulo_modulo(C,A10,C3) )
         => ( ( modulo_modulo(C,B2,C3) = modulo_modulo(C,B8,C3) )
           => ( modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A10),B8),C3) ) ) ) ) ).

% mod_mult_cong
tff(fact_1972_mod__mult__mult2,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,C3: C,B2: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),times_times(C),modulo_modulo(C,A3,B2)),C3) ) ).

% mod_mult_mult2
tff(fact_1973_mult__mod__right,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),C3),modulo_modulo(C,A3,B2)) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ).

% mult_mod_right
tff(fact_1974_mod__mult__left__eq,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,C3: C,B2: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),modulo_modulo(C,A3,C3)),B2),C3) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ).

% mod_mult_left_eq
tff(fact_1975_mod__mult__right__eq,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,B2: C,C3: C] : modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),modulo_modulo(C,B2,C3)),C3) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ).

% mod_mult_right_eq
tff(fact_1976_mod__eqE,axiom,
    ! [C: $tType] :
      ( euclid8851590272496341667cancel(C)
     => ! [A3: C,C3: C,B2: C] :
          ( ( modulo_modulo(C,A3,C3) = modulo_modulo(C,B2,C3) )
         => ~ ! [D4: C] : B2 != aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),D4)) ) ) ).

% mod_eqE
tff(fact_1977_inj__on__empty,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] : inj_on(C,D,F,bot_bot(set(C))) ).

% inj_on_empty
tff(fact_1978_inj__on__map__inv__f,axiom,
    ! [D: $tType,C: $tType,La: list(C),A4: set(C),F: fun(C,D)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),La)),A4)
     => ( inj_on(C,D,F,A4)
       => ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),inv_on(C,D,F,A4)),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),La)) = La ) ) ) ).

% inj_on_map_inv_f
tff(fact_1979_dbl__simps_I3_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl(C,one_one(C)) = aa(num,C,numeral_numeral(C),bit0(one2)) ) ) ).

% dbl_simps(3)
tff(fact_1980_even__succ__mod__exp,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C,N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => ( modulo_modulo(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),modulo_modulo(C,A3,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N))) ) ) ) ) ).

% even_succ_mod_exp
tff(fact_1981_divmod__digit__1_I1_J,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2)))
             => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2)))),one_one(C)) = divide_divide(C,A3,B2) ) ) ) ) ) ).

% divmod_digit_1(1)
tff(fact_1982_one__mod__2__pow__eq,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [N: nat] : modulo_modulo(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa($o,C,zero_neq_one_of_bool(C),aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)) ) ).

% one_mod_2_pow_eq
tff(fact_1983_semiring__parity__class_Oeven__mask__iff,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N),one_one(C)))
        <=> ( N = zero_zero(nat) ) ) ) ).

% semiring_parity_class.even_mask_iff
tff(fact_1984_times__divide__eq__left,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [B2: C,C3: C,A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,B2,C3)),A3) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3),C3) ) ).

% times_divide_eq_left
tff(fact_1985_divide__divide__eq__left,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C,C3: C] : divide_divide(C,divide_divide(C,A3,B2),C3) = divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ).

% divide_divide_eq_left
tff(fact_1986_divide__divide__eq__right,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C,C3: C] : divide_divide(C,A3,divide_divide(C,B2,C3)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),B2) ) ).

% divide_divide_eq_right
tff(fact_1987_times__divide__eq__right,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),divide_divide(C,B2,C3)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ).

% times_divide_eq_right
tff(fact_1988_div__by__1,axiom,
    ! [C: $tType] :
      ( semidom_divide(C)
     => ! [A3: C] : divide_divide(C,A3,one_one(C)) = A3 ) ).

% div_by_1
tff(fact_1989_bits__div__by__1,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C] : divide_divide(C,A3,one_one(C)) = A3 ) ).

% bits_div_by_1
tff(fact_1990_of__bool__eq_I2_J,axiom,
    ! [C: $tType] :
      ( zero_neq_one(C)
     => ( aa($o,C,zero_neq_one_of_bool(C),$true) = one_one(C) ) ) ).

% of_bool_eq(2)
tff(fact_1991_of__bool__eq__1__iff,axiom,
    ! [C: $tType] :
      ( zero_neq_one(C)
     => ! [Pa: $o] :
          ( ( aa($o,C,zero_neq_one_of_bool(C),(Pa)) = one_one(C) )
        <=> (Pa) ) ) ).

% of_bool_eq_1_iff
tff(fact_1992_inv__on__f__f,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C),X: C] :
      ( inj_on(C,D,F,A4)
     => ( member2(C,X,A4)
       => ( aa(D,C,inv_on(C,D,F,A4),aa(C,D,F,X)) = X ) ) ) ).

% inv_on_f_f
tff(fact_1993_dvd__mult__cancel__left,axiom,
    ! [C: $tType] :
      ( idom(C)
     => ! [C3: C,A3: C,B2: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( ( C3 = zero_zero(C) )
            | dvd_dvd(C,A3,B2) ) ) ) ).

% dvd_mult_cancel_left
tff(fact_1994_dvd__mult__cancel__right,axiom,
    ! [C: $tType] :
      ( idom(C)
     => ! [A3: C,C3: C,B2: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( ( C3 = zero_zero(C) )
            | dvd_dvd(C,A3,B2) ) ) ) ).

% dvd_mult_cancel_right
tff(fact_1995_dvd__times__left__cancel__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 != zero_zero(C) )
         => ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3))
          <=> dvd_dvd(C,B2,C3) ) ) ) ).

% dvd_times_left_cancel_iff
tff(fact_1996_dvd__times__right__cancel__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 != zero_zero(C) )
         => ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3))
          <=> dvd_dvd(C,B2,C3) ) ) ) ).

% dvd_times_right_cancel_iff
tff(fact_1997_nonzero__mult__div__cancel__left,axiom,
    ! [C: $tType] :
      ( semidom_divide(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),A3) = B2 ) ) ) ).

% nonzero_mult_div_cancel_left
tff(fact_1998_nonzero__mult__div__cancel__right,axiom,
    ! [C: $tType] :
      ( semidom_divide(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),B2) = A3 ) ) ) ).

% nonzero_mult_div_cancel_right
tff(fact_1999_mult__divide__mult__cancel__left__if,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [C3: C,A3: C,B2: C] :
          divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = $ite(C3 = zero_zero(C),zero_zero(C),divide_divide(C,A3,B2)) ) ).

% mult_divide_mult_cancel_left_if
tff(fact_2000_nonzero__mult__divide__mult__cancel__left,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = divide_divide(C,A3,B2) ) ) ) ).

% nonzero_mult_divide_mult_cancel_left
tff(fact_2001_nonzero__mult__divide__mult__cancel__left2,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,A3,B2) ) ) ) ).

% nonzero_mult_divide_mult_cancel_left2
tff(fact_2002_nonzero__mult__divide__mult__cancel__right,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,A3,B2) ) ) ) ).

% nonzero_mult_divide_mult_cancel_right
tff(fact_2003_nonzero__mult__divide__mult__cancel__right2,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = divide_divide(C,A3,B2) ) ) ) ).

% nonzero_mult_divide_mult_cancel_right2
tff(fact_2004_div__mult__mult1,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = divide_divide(C,A3,B2) ) ) ) ).

% div_mult_mult1
tff(fact_2005_div__mult__mult2,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,A3,B2) ) ) ) ).

% div_mult_mult2
tff(fact_2006_div__mult__mult1__if,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [C3: C,A3: C,B2: C] :
          divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = $ite(C3 = zero_zero(C),zero_zero(C),divide_divide(C,A3,B2)) ) ).

% div_mult_mult1_if
tff(fact_2007_div__self,axiom,
    ! [C: $tType] :
      ( semidom_divide(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( divide_divide(C,A3,A3) = one_one(C) ) ) ) ).

% div_self
tff(fact_2008_divide__eq__1__iff,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] :
          ( ( divide_divide(C,A3,B2) = one_one(C) )
        <=> ( ( B2 != zero_zero(C) )
            & ( A3 = B2 ) ) ) ) ).

% divide_eq_1_iff
tff(fact_2009_one__eq__divide__iff,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] :
          ( ( one_one(C) = divide_divide(C,A3,B2) )
        <=> ( ( B2 != zero_zero(C) )
            & ( A3 = B2 ) ) ) ) ).

% one_eq_divide_iff
tff(fact_2010_divide__self,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( divide_divide(C,A3,A3) = one_one(C) ) ) ) ).

% divide_self
tff(fact_2011_divide__self__if,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C] :
          divide_divide(C,A3,A3) = $ite(A3 = zero_zero(C),zero_zero(C),one_one(C)) ) ).

% divide_self_if
tff(fact_2012_divide__eq__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C] :
          ( ( divide_divide(C,B2,A3) = one_one(C) )
        <=> ( ( A3 != zero_zero(C) )
            & ( A3 = B2 ) ) ) ) ).

% divide_eq_eq_1
tff(fact_2013_eq__divide__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C] :
          ( ( one_one(C) = divide_divide(C,B2,A3) )
        <=> ( ( A3 != zero_zero(C) )
            & ( A3 = B2 ) ) ) ) ).

% eq_divide_eq_1
tff(fact_2014_one__divide__eq__0__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( ( divide_divide(C,one_one(C),A3) = zero_zero(C) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% one_divide_eq_0_iff
tff(fact_2015_zero__eq__1__divide__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( ( zero_zero(C) = divide_divide(C,one_one(C),A3) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% zero_eq_1_divide_iff
tff(fact_2016_dvd__add__times__triv__right__iff,axiom,
    ! [C: $tType] :
      ( comm_s4317794764714335236cancel(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)))
        <=> dvd_dvd(C,A3,B2) ) ) ).

% dvd_add_times_triv_right_iff
tff(fact_2017_dvd__add__times__triv__left__iff,axiom,
    ! [C: $tType] :
      ( comm_s4317794764714335236cancel(C)
     => ! [A3: C,C3: C,B2: C] :
          ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),B2))
        <=> dvd_dvd(C,A3,B2) ) ) ).

% dvd_add_times_triv_left_iff
tff(fact_2018_unit__prod,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( dvd_dvd(C,B2,one_one(C))
           => dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),one_one(C)) ) ) ) ).

% unit_prod
tff(fact_2019_dvd__mult__div__cancel,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,B2)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),divide_divide(C,B2,A3)) = B2 ) ) ) ).

% dvd_mult_div_cancel
tff(fact_2020_dvd__div__mult__self,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,B2)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,B2,A3)),A3) = B2 ) ) ) ).

% dvd_div_mult_self
tff(fact_2021_unit__div,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( dvd_dvd(C,B2,one_one(C))
           => dvd_dvd(C,divide_divide(C,A3,B2),one_one(C)) ) ) ) ).

% unit_div
tff(fact_2022_unit__div__1__unit,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => dvd_dvd(C,divide_divide(C,one_one(C),A3),one_one(C)) ) ) ).

% unit_div_1_unit
tff(fact_2023_unit__div__1__div__1,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( divide_divide(C,one_one(C),divide_divide(C,one_one(C),A3)) = A3 ) ) ) ).

% unit_div_1_div_1
tff(fact_2024_of__bool__less__one__iff,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [Pa: $o] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa($o,C,zero_neq_one_of_bool(C),(Pa))),one_one(C))
        <=> ~ (Pa) ) ) ).

% of_bool_less_one_iff
tff(fact_2025_of__bool__not__iff,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [Pa: $o] : aa($o,C,zero_neq_one_of_bool(C),~ (Pa)) = minus_minus(C,one_one(C),aa($o,C,zero_neq_one_of_bool(C),(Pa))) ) ).

% of_bool_not_iff
tff(fact_2026_divide__le__0__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,one_one(C),A3)),zero_zero(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) ) ) ).

% divide_le_0_1_iff
tff(fact_2027_zero__le__divide__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),divide_divide(C,one_one(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3) ) ) ).

% zero_le_divide_1_iff
tff(fact_2028_divide__less__0__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,one_one(C),A3)),zero_zero(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% divide_less_0_1_iff
tff(fact_2029_divide__less__eq__1__neg,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,A3)),one_one(C))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% divide_less_eq_1_neg
tff(fact_2030_divide__less__eq__1__pos,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,A3)),one_one(C))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ).

% divide_less_eq_1_pos
tff(fact_2031_less__divide__eq__1__neg,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),divide_divide(C,B2,A3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ).

% less_divide_eq_1_neg
tff(fact_2032_less__divide__eq__1__pos,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),divide_divide(C,B2,A3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ).

% less_divide_eq_1_pos
tff(fact_2033_zero__less__divide__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),divide_divide(C,one_one(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3) ) ) ).

% zero_less_divide_1_iff
tff(fact_2034_le__divide__eq__numeral1_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),divide_divide(C,B2,aa(num,C,numeral_numeral(C),W)))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),W))),B2) ) ) ).

% le_divide_eq_numeral1(1)
tff(fact_2035_divide__le__eq__numeral1_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,W: num,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,aa(num,C,numeral_numeral(C),W))),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),W))) ) ) ).

% divide_le_eq_numeral1(1)
tff(fact_2036_eq__divide__eq__numeral1_I1_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,W: num] :
          ( ( A3 = divide_divide(C,B2,aa(num,C,numeral_numeral(C),W)) )
        <=> $ite(aa(num,C,numeral_numeral(C),W) != zero_zero(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),W)) = B2,A3 = zero_zero(C)) ) ) ).

% eq_divide_eq_numeral1(1)
tff(fact_2037_divide__eq__eq__numeral1_I1_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,W: num,A3: C] :
          ( ( divide_divide(C,B2,aa(num,C,numeral_numeral(C),W)) = A3 )
        <=> $ite(aa(num,C,numeral_numeral(C),W) != zero_zero(C),B2 = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),W)),A3 = zero_zero(C)) ) ) ).

% divide_eq_eq_numeral1(1)
tff(fact_2038_div__mult__self1,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),divide_divide(C,A3,B2)) ) ) ) ).

% div_mult_self1
tff(fact_2039_div__mult__self2,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),divide_divide(C,A3,B2)) ) ) ) ).

% div_mult_self2
tff(fact_2040_div__mult__self3,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,C3: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),divide_divide(C,A3,B2)) ) ) ) ).

% div_mult_self3
tff(fact_2041_div__mult__self4,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,C3: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),divide_divide(C,A3,B2)) ) ) ) ).

% div_mult_self4
tff(fact_2042_nonzero__divide__mult__cancel__right,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,B2,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = divide_divide(C,one_one(C),A3) ) ) ) ).

% nonzero_divide_mult_cancel_right
tff(fact_2043_nonzero__divide__mult__cancel__left,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = divide_divide(C,one_one(C),B2) ) ) ) ).

% nonzero_divide_mult_cancel_left
tff(fact_2044_divide__less__eq__numeral1_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,W: num,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,aa(num,C,numeral_numeral(C),W))),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),W))) ) ) ).

% divide_less_eq_numeral1(1)
tff(fact_2045_less__divide__eq__numeral1_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),divide_divide(C,B2,aa(num,C,numeral_numeral(C),W)))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),W))),B2) ) ) ).

% less_divide_eq_numeral1(1)
tff(fact_2046_unit__div__mult__self,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,B2,A3)),A3) = B2 ) ) ) ).

% unit_div_mult_self
tff(fact_2047_unit__mult__div__div,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),B2),divide_divide(C,one_one(C),A3)) = divide_divide(C,B2,A3) ) ) ) ).

% unit_mult_div_div
tff(fact_2048_le__divide__eq__1__pos,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),divide_divide(C,B2,A3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% le_divide_eq_1_pos
tff(fact_2049_le__divide__eq__1__neg,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),divide_divide(C,B2,A3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ).

% le_divide_eq_1_neg
tff(fact_2050_divide__le__eq__1__pos,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,A3)),one_one(C))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ).

% divide_le_eq_1_pos
tff(fact_2051_divide__le__eq__1__neg,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,A3)),one_one(C))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ).

% divide_le_eq_1_neg
tff(fact_2052_even__mult__iff,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
        <=> ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
            | dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),B2) ) ) ) ).

% even_mult_iff
tff(fact_2053_bits__1__div__2,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ( divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))) = zero_zero(C) ) ) ).

% bits_1_div_2
tff(fact_2054_one__div__two__eq__zero,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ( divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))) = zero_zero(C) ) ) ).

% one_div_two_eq_zero
tff(fact_2055_even__plus__one__iff,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)))
        <=> ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3) ) ) ).

% even_plus_one_iff
tff(fact_2056_even__succ__div__2,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),A3),aa(num,C,numeral_numeral(C),bit0(one2))) = divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) ) ) ) ).

% even_succ_div_2
tff(fact_2057_odd__succ__div__two,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C] :
          ( ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)),aa(num,C,numeral_numeral(C),bit0(one2))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),one_one(C)) ) ) ) ).

% odd_succ_div_two
tff(fact_2058_even__succ__div__two,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)),aa(num,C,numeral_numeral(C),bit0(one2))) = divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) ) ) ) ).

% even_succ_div_two
tff(fact_2059_odd__two__times__div__two__succ,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C] :
          ( ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))),one_one(C)) = A3 ) ) ) ).

% odd_two_times_div_two_succ
tff(fact_2060_one__div__2__pow__eq,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [N: nat] : divide_divide(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa($o,C,zero_neq_one_of_bool(C),N = zero_zero(nat)) ) ).

% one_div_2_pow_eq
tff(fact_2061_bits__1__div__exp,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [N: nat] : divide_divide(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa($o,C,zero_neq_one_of_bool(C),N = zero_zero(nat)) ) ).

% bits_1_div_exp
tff(fact_2062_even__succ__div__exp,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C,N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = divide_divide(C,A3,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) ) ) ) ) ).

% even_succ_div_exp
tff(fact_2063_unit__div__cancel,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( ( divide_divide(C,B2,A3) = divide_divide(C,C3,A3) )
          <=> ( B2 = C3 ) ) ) ) ).

% unit_div_cancel
tff(fact_2064_div__unit__dvd__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( dvd_dvd(C,divide_divide(C,A3,B2),C3)
          <=> dvd_dvd(C,A3,C3) ) ) ) ).

% div_unit_dvd_iff
tff(fact_2065_dvd__div__unit__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( dvd_dvd(C,A3,divide_divide(C,C3,B2))
          <=> dvd_dvd(C,A3,C3) ) ) ) ).

% dvd_div_unit_iff
tff(fact_2066_div__mult__div__if__dvd,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,D3: C,C3: C] :
          ( dvd_dvd(C,B2,A3)
         => ( dvd_dvd(C,D3,C3)
           => ( aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),divide_divide(C,C3,D3)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ) ).

% div_mult_div_if_dvd
tff(fact_2067_dvd__mult__imp__div,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,C3: C,B2: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),B2)
         => dvd_dvd(C,A3,divide_divide(C,B2,C3)) ) ) ).

% dvd_mult_imp_div
tff(fact_2068_dvd__div__mult2__eq,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,C3: C,A3: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3),A3)
         => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,divide_divide(C,A3,B2),C3) ) ) ) ).

% dvd_div_mult2_eq
tff(fact_2069_div__div__eq__right,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,B2: C,A3: C] :
          ( dvd_dvd(C,C3,B2)
         => ( dvd_dvd(C,B2,A3)
           => ( divide_divide(C,A3,divide_divide(C,B2,C3)) = aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),C3) ) ) ) ) ).

% div_div_eq_right
tff(fact_2070_div__mult__swap,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,B2: C,A3: C] :
          ( dvd_dvd(C,C3,B2)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),divide_divide(C,B2,C3)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ) ) ).

% div_mult_swap
tff(fact_2071_dvd__div__mult,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,B2: C,A3: C] :
          ( dvd_dvd(C,C3,B2)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,B2,C3)),A3) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3),C3) ) ) ) ).

% dvd_div_mult
tff(fact_2072_dvd__div__div__eq__mult,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,C3: C,B2: C,D3: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( C3 != zero_zero(C) )
           => ( dvd_dvd(C,A3,B2)
             => ( dvd_dvd(C,C3,D3)
               => ( ( divide_divide(C,B2,A3) = divide_divide(C,D3,C3) )
                <=> ( aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),D3) ) ) ) ) ) ) ) ).

% dvd_div_div_eq_mult
tff(fact_2073_dvd__div__iff__mult,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,B2: C,A3: C] :
          ( ( C3 != zero_zero(C) )
         => ( dvd_dvd(C,C3,B2)
           => ( dvd_dvd(C,A3,divide_divide(C,B2,C3))
            <=> dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),B2) ) ) ) ) ).

% dvd_div_iff_mult
tff(fact_2074_div__dvd__iff__mult,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( B2 != zero_zero(C) )
         => ( dvd_dvd(C,B2,A3)
           => ( dvd_dvd(C,divide_divide(C,A3,B2),C3)
            <=> dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ) ) ) ).

% div_dvd_iff_mult
tff(fact_2075_dvd__div__eq__mult,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 != zero_zero(C) )
         => ( dvd_dvd(C,A3,B2)
           => ( ( divide_divide(C,B2,A3) = C3 )
            <=> ( B2 = aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3) ) ) ) ) ) ).

% dvd_div_eq_mult
tff(fact_2076_unit__div__eq__0__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( ( divide_divide(C,A3,B2) = zero_zero(C) )
          <=> ( A3 = zero_zero(C) ) ) ) ) ).

% unit_div_eq_0_iff
tff(fact_2077_is__unit__div__mult2__eq,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,C3: C,A3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( dvd_dvd(C,C3,one_one(C))
           => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,divide_divide(C,A3,B2),C3) ) ) ) ) ).

% is_unit_div_mult2_eq
tff(fact_2078_unit__div__mult__swap,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,A3: C,B2: C] :
          ( dvd_dvd(C,C3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),divide_divide(C,B2,C3)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ) ) ).

% unit_div_mult_swap
tff(fact_2079_unit__div__commute,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),C3) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),B2) ) ) ) ).

% unit_div_commute
tff(fact_2080_div__mult__unit2,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,B2: C,A3: C] :
          ( dvd_dvd(C,C3,one_one(C))
         => ( dvd_dvd(C,B2,A3)
           => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,divide_divide(C,A3,B2),C3) ) ) ) ) ).

% div_mult_unit2
tff(fact_2081_unit__eq__div2,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( ( A3 = divide_divide(C,C3,B2) )
          <=> ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = C3 ) ) ) ) ).

% unit_eq_div2
tff(fact_2082_unit__eq__div1,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( ( divide_divide(C,A3,B2) = C3 )
          <=> ( A3 = aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2) ) ) ) ) ).

% unit_eq_div1
tff(fact_2083_of__bool__conj,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [Pa: $o,Q: $o] :
          aa($o,C,zero_neq_one_of_bool(C),
            ( (Pa)
            & (Q) )) = aa(C,C,aa(C,fun(C,C),times_times(C),aa($o,C,zero_neq_one_of_bool(C),(Pa))),aa($o,C,zero_neq_one_of_bool(C),(Q))) ) ).

% of_bool_conj
tff(fact_2084_dvdE,axiom,
    ! [C: $tType] :
      ( dvd(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,A3)
         => ~ ! [K2: C] : A3 != aa(C,C,aa(C,fun(C,C),times_times(C),B2),K2) ) ) ).

% dvdE
tff(fact_2085_dvdI,axiom,
    ! [C: $tType] :
      ( dvd(C)
     => ! [A3: C,B2: C,K: C] :
          ( ( A3 = aa(C,C,aa(C,fun(C,C),times_times(C),B2),K) )
         => dvd_dvd(C,B2,A3) ) ) ).

% dvdI
tff(fact_2086_dvd__def,axiom,
    ! [C: $tType] :
      ( dvd(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,A3)
        <=> ? [K4: C] : A3 = aa(C,C,aa(C,fun(C,C),times_times(C),B2),K4) ) ) ).

% dvd_def
tff(fact_2087_dvd__mult,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,C3: C,B2: C] :
          ( dvd_dvd(C,A3,C3)
         => dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ).

% dvd_mult
tff(fact_2088_dvd__mult2,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,B2)
         => dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) ) ) ).

% dvd_mult2
tff(fact_2089_dvd__mult__left,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3)
         => dvd_dvd(C,A3,C3) ) ) ).

% dvd_mult_left
tff(fact_2090_dvd__triv__left,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C] : dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ).

% dvd_triv_left
tff(fact_2091_mult__dvd__mono,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C,C3: C,D3: C] :
          ( dvd_dvd(C,A3,B2)
         => ( dvd_dvd(C,C3,D3)
           => dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),D3)) ) ) ) ).

% mult_dvd_mono
tff(fact_2092_dvd__mult__right,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3)
         => dvd_dvd(C,B2,C3) ) ) ).

% dvd_mult_right
tff(fact_2093_dvd__triv__right,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C,B2: C] : dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)) ) ).

% dvd_triv_right
tff(fact_2094_divide__divide__eq__left_H,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,C3: C] : divide_divide(C,divide_divide(C,A3,B2),C3) = divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ).

% divide_divide_eq_left'
tff(fact_2095_divide__divide__times__eq,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C,Y: C,Z2: C,W: C] : divide_divide(C,divide_divide(C,X,Y),divide_divide(C,Z2,W)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),W),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)) ) ).

% divide_divide_times_eq
tff(fact_2096_times__divide__times__eq,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C,Y: C,Z2: C,W: C] : aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,X,Y)),divide_divide(C,Z2,W)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2),aa(C,C,aa(C,fun(C,C),times_times(C),Y),W)) ) ).

% times_divide_times_eq
tff(fact_2097_one__dvd,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: C] : dvd_dvd(C,one_one(C),A3) ) ).

% one_dvd
tff(fact_2098_unit__imp__dvd,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => dvd_dvd(C,B2,A3) ) ) ).

% unit_imp_dvd
tff(fact_2099_dvd__unit__imp__unit,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,B2)
         => ( dvd_dvd(C,B2,one_one(C))
           => dvd_dvd(C,A3,one_one(C)) ) ) ) ).

% dvd_unit_imp_unit
tff(fact_2100_is__unitE,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ~ ( ( A3 != zero_zero(C) )
             => ! [B4: C] :
                  ( ( B4 != zero_zero(C) )
                 => ( dvd_dvd(C,B4,one_one(C))
                   => ( ( divide_divide(C,one_one(C),A3) = B4 )
                     => ( ( divide_divide(C,one_one(C),B4) = A3 )
                       => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B4) = one_one(C) )
                         => ( divide_divide(C,C3,A3) != aa(C,C,aa(C,fun(C,C),times_times(C),C3),B4) ) ) ) ) ) ) ) ) ) ).

% is_unitE
tff(fact_2101_is__unit__div__mult__cancel__left,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( dvd_dvd(C,B2,one_one(C))
           => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = divide_divide(C,one_one(C),B2) ) ) ) ) ).

% is_unit_div_mult_cancel_left
tff(fact_2102_is__unit__div__mult__cancel__right,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( dvd_dvd(C,B2,one_one(C))
           => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)) = divide_divide(C,one_one(C),B2) ) ) ) ) ).

% is_unit_div_mult_cancel_right
tff(fact_2103_even__two__times__div__two,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))) = A3 ) ) ) ).

% even_two_times_div_two
tff(fact_2104_of__bool__less__eq__one,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [Pa: $o] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa($o,C,zero_neq_one_of_bool(C),(Pa))),one_one(C)) ) ).

% of_bool_less_eq_one
tff(fact_2105_split__of__bool__asm,axiom,
    ! [C: $tType] :
      ( zero_neq_one(C)
     => ! [Pa: fun(C,$o),P3: $o] :
          ( aa(C,$o,Pa,aa($o,C,zero_neq_one_of_bool(C),(P3)))
        <=> ~ ( ( (P3)
                & ~ aa(C,$o,Pa,one_one(C)) )
              | ( ~ (P3)
                & ~ aa(C,$o,Pa,zero_zero(C)) ) ) ) ) ).

% split_of_bool_asm
tff(fact_2106_split__of__bool,axiom,
    ! [C: $tType] :
      ( zero_neq_one(C)
     => ! [Pa: fun(C,$o),P3: $o] :
          ( aa(C,$o,Pa,aa($o,C,zero_neq_one_of_bool(C),(P3)))
        <=> ( ( (P3)
             => aa(C,$o,Pa,one_one(C)) )
            & ( ~ (P3)
             => aa(C,$o,Pa,zero_zero(C)) ) ) ) ) ).

% split_of_bool
tff(fact_2107_of__bool__def,axiom,
    ! [C: $tType] :
      ( zero_neq_one(C)
     => ! [P3: $o] :
          aa($o,C,zero_neq_one_of_bool(C),(P3)) = $ite((P3),one_one(C),zero_zero(C)) ) ).

% of_bool_def
tff(fact_2108_not__is__unit__0,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ~ dvd_dvd(C,zero_zero(C),one_one(C)) ) ).

% not_is_unit_0
tff(fact_2109_frac__eq__eq,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [Y: C,Z2: C,X: C,W: C] :
          ( ( Y != zero_zero(C) )
         => ( ( Z2 != zero_zero(C) )
           => ( ( divide_divide(C,X,Y) = divide_divide(C,W,Z2) )
            <=> ( aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2) = aa(C,C,aa(C,fun(C,C),times_times(C),W),Y) ) ) ) ) ) ).

% frac_eq_eq
tff(fact_2110_divide__eq__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,C3: C,A3: C] :
          ( ( divide_divide(C,B2,C3) = A3 )
        <=> $ite(C3 != zero_zero(C),B2 = aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),A3 = zero_zero(C)) ) ) ).

% divide_eq_eq
tff(fact_2111_eq__divide__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 = divide_divide(C,B2,C3) )
        <=> $ite(C3 != zero_zero(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = B2,A3 = zero_zero(C)) ) ) ).

% eq_divide_eq
tff(fact_2112_divide__eq__imp,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [C3: C,B2: C,A3: C] :
          ( ( C3 != zero_zero(C) )
         => ( ( B2 = aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) )
           => ( divide_divide(C,B2,C3) = A3 ) ) ) ) ).

% divide_eq_imp
tff(fact_2113_eq__divide__imp,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = B2 )
           => ( A3 = divide_divide(C,B2,C3) ) ) ) ) ).

% eq_divide_imp
tff(fact_2114_nonzero__divide__eq__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [C3: C,B2: C,A3: C] :
          ( ( C3 != zero_zero(C) )
         => ( ( divide_divide(C,B2,C3) = A3 )
          <=> ( B2 = aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) ) ) ) ) ).

% nonzero_divide_eq_eq
tff(fact_2115_nonzero__eq__divide__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [C3: C,A3: C,B2: C] :
          ( ( C3 != zero_zero(C) )
         => ( ( A3 = divide_divide(C,B2,C3) )
          <=> ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = B2 ) ) ) ) ).

% nonzero_eq_divide_eq
tff(fact_2116_right__inverse__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( divide_divide(C,A3,B2) = one_one(C) )
          <=> ( A3 = B2 ) ) ) ) ).

% right_inverse_eq
tff(fact_2117_unit__mult__right__cancel,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3) )
          <=> ( B2 = C3 ) ) ) ) ).

% unit_mult_right_cancel
tff(fact_2118_unit__mult__left__cancel,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) )
          <=> ( B2 = C3 ) ) ) ) ).

% unit_mult_left_cancel
tff(fact_2119_mult__unit__dvd__iff_H,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3)
          <=> dvd_dvd(C,B2,C3) ) ) ) ).

% mult_unit_dvd_iff'
tff(fact_2120_dvd__mult__unit__iff_H,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
          <=> dvd_dvd(C,A3,C3) ) ) ) ).

% dvd_mult_unit_iff'
tff(fact_2121_mult__unit__dvd__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3)
          <=> dvd_dvd(C,A3,C3) ) ) ) ).

% mult_unit_dvd_iff
tff(fact_2122_dvd__mult__unit__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C,C3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
          <=> dvd_dvd(C,A3,C3) ) ) ) ).

% dvd_mult_unit_iff
tff(fact_2123_is__unit__mult__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),one_one(C))
        <=> ( dvd_dvd(C,A3,one_one(C))
            & dvd_dvd(C,B2,one_one(C)) ) ) ) ).

% is_unit_mult_iff
tff(fact_2124_power__one__over,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),divide_divide(C,one_one(C),A3)),N) = divide_divide(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ).

% power_one_over
tff(fact_2125_bits__induct,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [Pa: fun(C,$o),A3: C] :
          ( ! [A5: C] :
              ( ( divide_divide(C,A5,aa(num,C,numeral_numeral(C),bit0(one2))) = A5 )
             => aa(C,$o,Pa,A5) )
         => ( ! [A5: C,B4: $o] :
                ( aa(C,$o,Pa,A5)
               => ( ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa($o,C,zero_neq_one_of_bool(C),(B4))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),A5)),aa(num,C,numeral_numeral(C),bit0(one2))) = A5 )
                 => aa(C,$o,Pa,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa($o,C,zero_neq_one_of_bool(C),(B4))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),A5))) ) )
           => aa(C,$o,Pa,A3) ) ) ) ).

% bits_induct
tff(fact_2126_unique__euclidean__semiring__numeral__class_Odiv__mult2__eq,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
         => ( divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = divide_divide(C,divide_divide(C,A3,B2),C3) ) ) ) ).

% unique_euclidean_semiring_numeral_class.div_mult2_eq
tff(fact_2127_unity__coeff__ex,axiom,
    ! [C: $tType] :
      ( ( dvd(C)
        & semiring_0(C) )
     => ! [Pa: fun(C,$o),La: C] :
          ( ? [X4: C] : aa(C,$o,Pa,aa(C,C,aa(C,fun(C,C),times_times(C),La),X4))
        <=> ? [X4: C] :
              ( dvd_dvd(C,La,aa(C,C,aa(C,fun(C,C),plus_plus(C),X4),zero_zero(C)))
              & aa(C,$o,Pa,X4) ) ) ) ).

% unity_coeff_ex
tff(fact_2128_divide__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,C3)),A3)
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2),aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)) ) ) ) ).

% divide_less_eq
tff(fact_2129_less__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),divide_divide(C,B2,C3))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))) ) ) ) ).

% less_divide_eq
tff(fact_2130_neg__divide__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,C3)),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2) ) ) ) ).

% neg_divide_less_eq
tff(fact_2131_neg__less__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),divide_divide(C,B2,C3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% neg_less_divide_eq
tff(fact_2132_pos__divide__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,C3)),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% pos_divide_less_eq
tff(fact_2133_pos__less__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),divide_divide(C,B2,C3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2) ) ) ) ).

% pos_less_divide_eq
tff(fact_2134_mult__imp__div__pos__less,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Y: C,X: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,X,Y)),Z2) ) ) ) ).

% mult_imp_div_pos_less
tff(fact_2135_mult__imp__less__div__pos,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Y: C,Z2: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y)),X)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),Z2),divide_divide(C,X,Y)) ) ) ) ).

% mult_imp_less_div_pos
tff(fact_2136_divide__strict__left__mono,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,C3,A3)),divide_divide(C,C3,B2)) ) ) ) ) ).

% divide_strict_left_mono
tff(fact_2137_divide__strict__left__mono__neg,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,C3,A3)),divide_divide(C,C3,B2)) ) ) ) ) ).

% divide_strict_left_mono_neg
tff(fact_2138_unit__dvdE,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ~ ( ( A3 != zero_zero(C) )
             => ! [C2: C] : B2 != aa(C,C,aa(C,fun(C,C),times_times(C),A3),C2) ) ) ) ).

% unit_dvdE
tff(fact_2139_divide__less__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,A3)),one_one(C))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) )
            | ( A3 = zero_zero(C) ) ) ) ) ).

% divide_less_eq_1
tff(fact_2140_less__divide__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),divide_divide(C,B2,A3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) ) ) ) ) ).

% less_divide_eq_1
tff(fact_2141_eq__divide__eq__numeral_I1_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [W: num,B2: C,C3: C] :
          ( ( aa(num,C,numeral_numeral(C),W) = divide_divide(C,B2,C3) )
        <=> $ite(C3 != zero_zero(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3) = B2,aa(num,C,numeral_numeral(C),W) = zero_zero(C)) ) ) ).

% eq_divide_eq_numeral(1)
tff(fact_2142_divide__eq__eq__numeral_I1_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,C3: C,W: num] :
          ( ( divide_divide(C,B2,C3) = aa(num,C,numeral_numeral(C),W) )
        <=> $ite(C3 != zero_zero(C),B2 = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3),aa(num,C,numeral_numeral(C),W) = zero_zero(C)) ) ) ).

% divide_eq_eq_numeral(1)
tff(fact_2143_add__divide__eq__if__simps_I2_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,Z2: C,B2: C] :
          aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,A3,Z2)),B2) = $ite(Z2 = zero_zero(C),B2,divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),Z2)),Z2)) ) ).

% add_divide_eq_if_simps(2)
tff(fact_2144_add__divide__eq__if__simps_I1_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,Z2: C] :
          aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),divide_divide(C,B2,Z2)) = $ite(Z2 = zero_zero(C),A3,divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),Z2)),B2),Z2)) ) ).

% add_divide_eq_if_simps(1)
tff(fact_2145_add__frac__eq,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [Y: C,Z2: C,X: C,W: C] :
          ( ( Y != zero_zero(C) )
         => ( ( Z2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,X,Y)),divide_divide(C,W,Z2)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2)),aa(C,C,aa(C,fun(C,C),times_times(C),W),Y)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)) ) ) ) ) ).

% add_frac_eq
tff(fact_2146_add__frac__num,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [Y: C,X: C,Z2: C] :
          ( ( Y != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,X,Y)),Z2) = divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y)),Y) ) ) ) ).

% add_frac_num
tff(fact_2147_add__num__frac,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [Y: C,Z2: C,X: C] :
          ( ( Y != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),divide_divide(C,X,Y)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y)),Y) ) ) ) ).

% add_num_frac
tff(fact_2148_add__divide__eq__iff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Z2: C,X: C,Y: C] :
          ( ( Z2 != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),X),divide_divide(C,Y,Z2)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2)),Y),Z2) ) ) ) ).

% add_divide_eq_iff
tff(fact_2149_divide__add__eq__iff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Z2: C,X: C,Y: C] :
          ( ( Z2 != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,X,Z2)),Y) = divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)),Z2) ) ) ) ).

% divide_add_eq_iff
tff(fact_2150_div__add__self1,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),A3),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,A3,B2)),one_one(C)) ) ) ) ).

% div_add_self1
tff(fact_2151_div__add__self2,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,A3,B2)),one_one(C)) ) ) ) ).

% div_add_self2
tff(fact_2152_add__divide__eq__if__simps_I4_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,Z2: C] :
          minus_minus(C,A3,divide_divide(C,B2,Z2)) = $ite(Z2 = zero_zero(C),A3,divide_divide(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),Z2),B2),Z2)) ) ).

% add_divide_eq_if_simps(4)
tff(fact_2153_diff__frac__eq,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [Y: C,Z2: C,X: C,W: C] :
          ( ( Y != zero_zero(C) )
         => ( ( Z2 != zero_zero(C) )
           => ( minus_minus(C,divide_divide(C,X,Y),divide_divide(C,W,Z2)) = divide_divide(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2),aa(C,C,aa(C,fun(C,C),times_times(C),W),Y)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)) ) ) ) ) ).

% diff_frac_eq
tff(fact_2154_diff__divide__eq__iff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Z2: C,X: C,Y: C] :
          ( ( Z2 != zero_zero(C) )
         => ( minus_minus(C,X,divide_divide(C,Y,Z2)) = divide_divide(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2),Y),Z2) ) ) ) ).

% diff_divide_eq_iff
tff(fact_2155_divide__diff__eq__iff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Z2: C,X: C,Y: C] :
          ( ( Z2 != zero_zero(C) )
         => ( minus_minus(C,divide_divide(C,X,Z2),Y) = divide_divide(C,minus_minus(C,X,aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)),Z2) ) ) ) ).

% divide_diff_eq_iff
tff(fact_2156_gt__half__sum,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),one_one(C)))),B2) ) ) ).

% gt_half_sum
tff(fact_2157_less__half__sum,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),one_one(C)))) ) ) ).

% less_half_sum
tff(fact_2158_inf__period_I4_J,axiom,
    ! [C: $tType] :
      ( ( comm_ring(C)
        & dvd(C) )
     => ! [D3: C,D2: C,T4: C] :
          ( dvd_dvd(C,D3,D2)
         => ! [X3: C,K3: C] :
              ( ~ dvd_dvd(C,D3,aa(C,C,aa(C,fun(C,C),plus_plus(C),X3),T4))
            <=> ~ dvd_dvd(C,D3,aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,X3,aa(C,C,aa(C,fun(C,C),times_times(C),K3),D2))),T4)) ) ) ) ).

% inf_period(4)
tff(fact_2159_inf__period_I3_J,axiom,
    ! [C: $tType] :
      ( ( comm_ring(C)
        & dvd(C) )
     => ! [D3: C,D2: C,T4: C] :
          ( dvd_dvd(C,D3,D2)
         => ! [X3: C,K3: C] :
              ( dvd_dvd(C,D3,aa(C,C,aa(C,fun(C,C),plus_plus(C),X3),T4))
            <=> dvd_dvd(C,D3,aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,X3,aa(C,C,aa(C,fun(C,C),times_times(C),K3),D2))),T4)) ) ) ) ).

% inf_period(3)
tff(fact_2160_unit__imp__mod__eq__0,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( modulo_modulo(C,A3,B2) = zero_zero(C) ) ) ) ).

% unit_imp_mod_eq_0
tff(fact_2161_mult__div__mod__eq,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [B2: C,A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),divide_divide(C,A3,B2))),modulo_modulo(C,A3,B2)) = A3 ) ).

% mult_div_mod_eq
tff(fact_2162_mod__mult__div__eq,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,B2)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),divide_divide(C,A3,B2))) = A3 ) ).

% mod_mult_div_eq
tff(fact_2163_mod__div__mult__eq,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,B2)),aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2)) = A3 ) ).

% mod_div_mult_eq
tff(fact_2164_div__mult__mod__eq,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2)),modulo_modulo(C,A3,B2)) = A3 ) ).

% div_mult_mod_eq
tff(fact_2165_mod__div__decomp,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : A3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2)),modulo_modulo(C,A3,B2)) ) ).

% mod_div_decomp
tff(fact_2166_cancel__div__mod__rules_I1_J,axiom,
    ! [C: $tType] :
      ( semidom_modulo(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2)),modulo_modulo(C,A3,B2))),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3) ) ).

% cancel_div_mod_rules(1)
tff(fact_2167_cancel__div__mod__rules_I2_J,axiom,
    ! [C: $tType] :
      ( semidom_modulo(C)
     => ! [B2: C,A3: C,C3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),divide_divide(C,A3,B2))),modulo_modulo(C,A3,B2))),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),C3) ) ).

% cancel_div_mod_rules(2)
tff(fact_2168_div__mult1__eq,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [A3: C,B2: C,C3: C] : divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),divide_divide(C,B2,C3))),divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),modulo_modulo(C,B2,C3)),C3)) ) ).

% div_mult1_eq
tff(fact_2169_is__unit__power__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,N: nat] :
          ( dvd_dvd(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N),one_one(C))
        <=> ( dvd_dvd(C,A3,one_one(C))
            | ( N = zero_zero(nat) ) ) ) ) ).

% is_unit_power_iff
tff(fact_2170_minus__mult__div__eq__mod,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),divide_divide(C,A3,B2))) = modulo_modulo(C,A3,B2) ) ).

% minus_mult_div_eq_mod
tff(fact_2171_minus__mod__eq__mult__div,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,modulo_modulo(C,A3,B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),divide_divide(C,A3,B2)) ) ).

% minus_mod_eq_mult_div
tff(fact_2172_minus__mod__eq__div__mult,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,modulo_modulo(C,A3,B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2) ) ).

% minus_mod_eq_div_mult
tff(fact_2173_minus__div__mult__eq__mod,axiom,
    ! [C: $tType] :
      ( semiring_modulo(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2)) = modulo_modulo(C,A3,B2) ) ).

% minus_div_mult_eq_mod
tff(fact_2174_even__mask__div__iff_H,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [M2: nat,N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),divide_divide(C,minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2),one_one(C)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)))
        <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N) ) ) ).

% even_mask_div_iff'
tff(fact_2175_exp__div__exp__eq,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [M2: nat,N: nat] :
          divide_divide(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa(C,C,
            aa(C,fun(C,C),times_times(C),
              aa($o,C,zero_neq_one_of_bool(C),
                ( ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2) != zero_zero(C) )
                & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M2) ))),
            aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),minus_minus(nat,M2,N))) ) ).

% exp_div_exp_eq
tff(fact_2176_even__mask__div__iff,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [M2: nat,N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),divide_divide(C,minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2),one_one(C)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)))
        <=> ( ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N) = zero_zero(C) )
            | aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N) ) ) ) ).

% even_mask_div_iff
tff(fact_2177_divide__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,C3)),A3)
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)) ) ) ) ).

% divide_le_eq
tff(fact_2178_le__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),divide_divide(C,B2,C3))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))) ) ) ) ).

% le_divide_eq
tff(fact_2179_divide__left__mono,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,C3,A3)),divide_divide(C,C3,B2)) ) ) ) ) ).

% divide_left_mono
tff(fact_2180_neg__divide__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,C3)),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2) ) ) ) ).

% neg_divide_le_eq
tff(fact_2181_neg__le__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),divide_divide(C,B2,C3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% neg_le_divide_eq
tff(fact_2182_pos__divide__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,C3)),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% pos_divide_le_eq
tff(fact_2183_pos__le__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),divide_divide(C,B2,C3))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2) ) ) ) ).

% pos_le_divide_eq
tff(fact_2184_mult__imp__div__pos__le,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Y: C,X: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,X,Y)),Z2) ) ) ) ).

% mult_imp_div_pos_le
tff(fact_2185_mult__imp__le__div__pos,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Y: C,Z2: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Y)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),Y)),X)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),divide_divide(C,X,Y)) ) ) ) ).

% mult_imp_le_div_pos
tff(fact_2186_divide__left__mono__neg,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C3),zero_zero(C))
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,C3,A3)),divide_divide(C,C3,B2)) ) ) ) ) ).

% divide_left_mono_neg
tff(fact_2187_divide__le__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,A3)),one_one(C))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) )
            | ( A3 = zero_zero(C) ) ) ) ) ).

% divide_le_eq_1
tff(fact_2188_le__divide__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),divide_divide(C,B2,A3))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) )
            | ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) ) ) ) ) ).

% le_divide_eq_1
tff(fact_2189_frac__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Y: C,Z2: C,X: C,W: C] :
          ( ( Y != zero_zero(C) )
         => ( ( Z2 != zero_zero(C) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,X,Y)),divide_divide(C,W,Z2))
            <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2),aa(C,C,aa(C,fun(C,C),times_times(C),W),Y)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2))),zero_zero(C)) ) ) ) ) ).

% frac_le_eq
tff(fact_2190_less__divide__eq__numeral_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [W: num,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(num,C,numeral_numeral(C),W)),divide_divide(C,B2,C3))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),B2),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(num,C,numeral_numeral(C),W)),zero_zero(C))) ) ) ) ).

% less_divide_eq_numeral(1)
tff(fact_2191_divide__less__eq__numeral_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,C3)),aa(num,C,numeral_numeral(C),W))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),B2),aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(num,C,numeral_numeral(C),W))) ) ) ) ).

% divide_less_eq_numeral(1)
tff(fact_2192_frac__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Y: C,Z2: C,X: C,W: C] :
          ( ( Y != zero_zero(C) )
         => ( ( Z2 != zero_zero(C) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,X,Y)),divide_divide(C,W,Z2))
            <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Z2),aa(C,C,aa(C,fun(C,C),times_times(C),W),Y)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2))),zero_zero(C)) ) ) ) ) ).

% frac_less_eq
tff(fact_2193_evenE,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ~ ! [B4: C] : A3 != aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B4) ) ) ).

% evenE
tff(fact_2194_odd__one,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),one_one(C)) ) ).

% odd_one
tff(fact_2195_dvd__power__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [X: C,M2: nat,N: nat] :
          ( ( X != zero_zero(C) )
         => ( dvd_dvd(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N))
          <=> ( dvd_dvd(C,X,one_one(C))
              | aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N) ) ) ) ) ).

% dvd_power_iff
tff(fact_2196_dvd__power,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [N: nat,X: C] :
          ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
            | ( X = one_one(C) ) )
         => dvd_dvd(C,X,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)) ) ) ).

% dvd_power
tff(fact_2197_even__mult__exp__div__exp__iff,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C,M2: nat,N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)))
        <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2)
            | ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N) = zero_zero(C) )
            | ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
              & dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),divide_divide(C,A3,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),minus_minus(nat,N,M2)))) ) ) ) ) ).

% even_mult_exp_div_exp_iff
tff(fact_2198_divide__le__eq__numeral_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,C3)),aa(num,C,numeral_numeral(C),W))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),B2),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(num,C,numeral_numeral(C),W))) ) ) ) ).

% divide_le_eq_numeral(1)
tff(fact_2199_le__divide__eq__numeral_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [W: num,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(num,C,numeral_numeral(C),W)),divide_divide(C,B2,C3))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),B2),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(num,C,numeral_numeral(C),W)),zero_zero(C))) ) ) ) ).

% le_divide_eq_numeral(1)
tff(fact_2200_scaling__mono,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [U: C,V: C,R3: C,S4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),U),V)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),R3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),R3),S4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),U),divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),R3),minus_minus(C,V,U)),S4))),V) ) ) ) ) ).

% scaling_mono
tff(fact_2201_unique__euclidean__semiring__numeral__class_Omod__mult2__eq,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),C3)
         => ( modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),modulo_modulo(C,divide_divide(C,A3,B2),C3))),modulo_modulo(C,A3,B2)) ) ) ) ).

% unique_euclidean_semiring_numeral_class.mod_mult2_eq
tff(fact_2202_odd__iff__mod__2__eq__one,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
        <=> ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) = one_one(C) ) ) ) ).

% odd_iff_mod_2_eq_one
tff(fact_2203_power__diff__power__eq,axiom,
    ! [C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A3: C,M2: nat,N: nat] :
          ( ( A3 != zero_zero(C) )
         => ( divide_divide(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),minus_minus(nat,M2,N)),divide_divide(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),minus_minus(nat,N,M2)))) ) ) ) ).

% power_diff_power_eq
tff(fact_2204_odd__card__imp__not__empty,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),bit0(one2)),finite_card(C,A4))
     => ( A4 != bot_bot(set(C)) ) ) ).

% odd_card_imp_not_empty
tff(fact_2205_dvd__partition,axiom,
    ! [C: $tType,C4: set(set(C)),K: nat] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4))
     => ( ! [X2: set(C)] :
            ( member2(set(C),X2,C4)
           => dvd_dvd(nat,K,finite_card(C,X2)) )
       => ( ! [X2: set(C)] :
              ( member2(set(C),X2,C4)
             => ! [Xa4: set(C)] :
                  ( member2(set(C),Xa4,C4)
                 => ( ( X2 != Xa4 )
                   => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X2),Xa4) = bot_bot(set(C)) ) ) ) )
         => dvd_dvd(nat,K,finite_card(C,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4))) ) ) ) ).

% dvd_partition
tff(fact_2206_oddE,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ~ ! [B4: C] : A3 != aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B4)),one_one(C)) ) ) ).

% oddE
tff(fact_2207_parity__cases,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          ( ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
           => ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) != zero_zero(C) ) )
         => ~ ( ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
             => ( modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) != one_one(C) ) ) ) ) ).

% parity_cases
tff(fact_2208_mod2__eq__if,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [A3: C] :
          modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) = $ite(dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3),zero_zero(C),one_one(C)) ) ).

% mod2_eq_if
tff(fact_2209_exp__mod__exp,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [M2: nat,N: nat] : modulo_modulo(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa($o,C,zero_neq_one_of_bool(C),aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M2),N))),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2)) ) ).

% exp_mod_exp
tff(fact_2210_divmod__digit__0_I1_J,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2))),B2)
           => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2))) = divide_divide(C,A3,B2) ) ) ) ) ).

% divmod_digit_0(1)
tff(fact_2211_inj__on__Int,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C),B3: set(C)] :
      ( ( inj_on(C,D,F,A4)
        | inj_on(C,D,F,B3) )
     => inj_on(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ).

% inj_on_Int
tff(fact_2212_flip__bit__0,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : bit_se8732182000553998342ip_bit(C,zero_zero(nat),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa($o,C,zero_neq_one_of_bool(C),dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))) ) ).

% flip_bit_0
tff(fact_2213_set__bit__0,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : bit_se5668285175392031749et_bit(C,zero_zero(nat),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))) ) ).

% set_bit_0
tff(fact_2214_unset__bit__0,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : bit_se2638667681897837118et_bit(C,zero_zero(nat),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))) ) ).

% unset_bit_0
tff(fact_2215_set__bit__Suc,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se5668285175392031749et_bit(C,aa(nat,nat,suc,N),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_se5668285175392031749et_bit(C,N,divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))))) ) ).

% set_bit_Suc
tff(fact_2216_flip__bit__Suc,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se8732182000553998342ip_bit(C,aa(nat,nat,suc,N),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_se8732182000553998342ip_bit(C,N,divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))))) ) ).

% flip_bit_Suc
tff(fact_2217_unset__bit__Suc,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se2638667681897837118et_bit(C,aa(nat,nat,suc,N),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_se2638667681897837118et_bit(C,N,divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))))) ) ).

% unset_bit_Suc
tff(fact_2218_signed__take__bit__Suc,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat,A3: C] : bit_ri4674362597316999326ke_bit(C,aa(nat,nat,suc,N),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_ri4674362597316999326ke_bit(C,N,divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))))) ) ).

% signed_take_bit_Suc
tff(fact_2219_signed__take__bit__Suc__1,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat] : bit_ri4674362597316999326ke_bit(C,aa(nat,nat,suc,N),one_one(C)) = one_one(C) ) ).

% signed_take_bit_Suc_1
tff(fact_2220_signed__take__bit__numeral__of__1,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [K: num] : bit_ri4674362597316999326ke_bit(C,aa(num,nat,numeral_numeral(nat),K),one_one(C)) = one_one(C) ) ).

% signed_take_bit_numeral_of_1
tff(fact_2221_signed__take__bit__rec,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat,A3: C] :
          bit_ri4674362597316999326ke_bit(C,N,A3) = $ite(N = zero_zero(nat),aa(C,C,uminus_uminus(C),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),aa(C,C,aa(C,fun(C,C),plus_plus(C),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_ri4674362597316999326ke_bit(C,minus_minus(nat,N,one_one(nat)),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))))) ) ).

% signed_take_bit_rec
tff(fact_2222_take__bit__rec,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] :
          bit_se2584673776208193580ke_bit(C,N,A3) = $ite(N = zero_zero(nat),zero_zero(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),bit_se2584673776208193580ke_bit(C,minus_minus(nat,N,one_one(nat)),divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))),aa(num,C,numeral_numeral(C),bit0(one2)))),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))) ) ).

% take_bit_rec
tff(fact_2223_gbinomial__absorption_H,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
         => ( aa(nat,C,gbinomial(C,A3),K) = aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,aa(nat,C,semiring_1_of_nat(C),K))),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),minus_minus(nat,K,one_one(nat)))) ) ) ) ).

% gbinomial_absorption'
tff(fact_2224_stable__imp__take__bit__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C,N: nat] :
          ( ( divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) = A3 )
         => ( bit_se2584673776208193580ke_bit(C,N,A3) = $ite(dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3),zero_zero(C),minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N),one_one(C))) ) ) ) ).

% stable_imp_take_bit_eq
tff(fact_2225_xor__one__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),A3),one_one(C)) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa($o,C,zero_neq_one_of_bool(C),dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))),aa($o,C,zero_neq_one_of_bool(C),~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))) ) ).

% xor_one_eq
tff(fact_2226_one__xor__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),one_one(C)),A3) = minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa($o,C,zero_neq_one_of_bool(C),dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))),aa($o,C,zero_neq_one_of_bool(C),~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))) ) ).

% one_xor_eq
tff(fact_2227_neg__equal__iff__equal,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,uminus_uminus(C),A3) = aa(C,C,uminus_uminus(C),B2) )
        <=> ( A3 = B2 ) ) ) ).

% neg_equal_iff_equal
tff(fact_2228_add_Oinverse__inverse,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : aa(C,C,uminus_uminus(C),aa(C,C,uminus_uminus(C),A3)) = A3 ) ).

% add.inverse_inverse
tff(fact_2229_uminus__apply,axiom,
    ! [C: $tType,D: $tType] :
      ( uminus(C)
     => ! [A4: fun(D,C),X: D] : aa(D,C,aa(fun(D,C),fun(D,C),uminus_uminus(fun(D,C)),A4),X) = aa(C,C,uminus_uminus(C),aa(D,C,A4,X)) ) ).

% uminus_apply
tff(fact_2230_boolean__algebra__class_Oboolean__algebra_Ocompl__eq__compl__iff,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,uminus_uminus(C),X) = aa(C,C,uminus_uminus(C),Y) )
        <=> ( X = Y ) ) ) ).

% boolean_algebra_class.boolean_algebra.compl_eq_compl_iff
tff(fact_2231_boolean__algebra__class_Oboolean__algebra_Odouble__compl,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,uminus_uminus(C),aa(C,C,uminus_uminus(C),X)) = X ) ).

% boolean_algebra_class.boolean_algebra.double_compl
tff(fact_2232_Compl__subset__Compl__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)),aa(set(C),set(C),uminus_uminus(set(C)),B3))
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4) ) ).

% Compl_subset_Compl_iff
tff(fact_2233_Compl__anti__mono,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),B3)),aa(set(C),set(C),uminus_uminus(set(C)),A4)) ) ).

% Compl_anti_mono
tff(fact_2234_neg__le__iff__le,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,uminus_uminus(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% neg_le_iff_le
tff(fact_2235_compl__le__compl__iff,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,uminus_uminus(C),Y))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),X) ) ) ).

% compl_le_compl_iff
tff(fact_2236_neg__equal__zero,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( ( aa(C,C,uminus_uminus(C),A3) = A3 )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% neg_equal_zero
tff(fact_2237_equal__neg__zero,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( ( A3 = aa(C,C,uminus_uminus(C),A3) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% equal_neg_zero
tff(fact_2238_neg__equal__0__iff__equal,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] :
          ( ( aa(C,C,uminus_uminus(C),A3) = zero_zero(C) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% neg_equal_0_iff_equal
tff(fact_2239_neg__0__equal__iff__equal,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] :
          ( ( zero_zero(C) = aa(C,C,uminus_uminus(C),A3) )
        <=> ( zero_zero(C) = A3 ) ) ) ).

% neg_0_equal_iff_equal
tff(fact_2240_add_Oinverse__neutral,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ( aa(C,C,uminus_uminus(C),zero_zero(C)) = zero_zero(C) ) ) ).

% add.inverse_neutral
tff(fact_2241_neg__less__iff__less,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,uminus_uminus(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% neg_less_iff_less
tff(fact_2242_compl__less__compl__iff,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,uminus_uminus(C),Y))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X) ) ) ).

% compl_less_compl_iff
tff(fact_2243_minus__add__distrib,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),aa(C,C,uminus_uminus(C),B2)) ) ).

% minus_add_distrib
tff(fact_2244_minus__add__cancel,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) = B2 ) ).

% minus_add_cancel
tff(fact_2245_add__minus__cancel,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),B2)) = B2 ) ).

% add_minus_cancel
tff(fact_2246_mult__minus__left,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),A3)),B2) = aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ).

% mult_minus_left
tff(fact_2247_minus__mult__minus,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),A3)),aa(C,C,uminus_uminus(C),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) ) ).

% minus_mult_minus
tff(fact_2248_mult__minus__right,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),B2)) = aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ).

% mult_minus_right
tff(fact_2249_minus__diff__eq,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,uminus_uminus(C),minus_minus(C,A3,B2)) = minus_minus(C,B2,A3) ) ).

% minus_diff_eq
tff(fact_2250_Compl__disjoint2,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)),A4) = bot_bot(set(C)) ).

% Compl_disjoint2
tff(fact_2251_Compl__disjoint,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),A4)) = bot_bot(set(C)) ).

% Compl_disjoint
tff(fact_2252_inter__compl__diff__conv,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),B3)) = minus_minus(set(C),A4,B3) ).

% inter_compl_diff_conv
tff(fact_2253_Diff__Compl,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : minus_minus(set(C),A4,aa(set(C),set(C),uminus_uminus(set(C)),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ).

% Diff_Compl
tff(fact_2254_Compl__Diff__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),minus_minus(set(C),A4,B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)),B3) ).

% Compl_Diff_eq
tff(fact_2255_neg__0__le__iff__le,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,uminus_uminus(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) ) ) ).

% neg_0_le_iff_le
tff(fact_2256_neg__le__0__iff__le,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),zero_zero(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3) ) ) ).

% neg_le_0_iff_le
tff(fact_2257_less__eq__neg__nonpos,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,uminus_uminus(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) ) ) ).

% less_eq_neg_nonpos
tff(fact_2258_neg__less__eq__nonneg,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3) ) ) ).

% neg_less_eq_nonneg
tff(fact_2259_less__neg__neg,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,uminus_uminus(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% less_neg_neg
tff(fact_2260_neg__less__pos,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),A3)),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3) ) ) ).

% neg_less_pos
tff(fact_2261_neg__0__less__iff__less,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,uminus_uminus(C),A3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% neg_0_less_iff_less
tff(fact_2262_neg__less__0__iff__less,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),A3)),zero_zero(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3) ) ) ).

% neg_less_0_iff_less
tff(fact_2263_ab__left__minus,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),A3) = zero_zero(C) ) ).

% ab_left_minus
tff(fact_2264_add_Oright__inverse,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,uminus_uminus(C),A3)) = zero_zero(C) ) ).

% add.right_inverse
tff(fact_2265_diff__0,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C] : minus_minus(C,zero_zero(C),A3) = aa(C,C,uminus_uminus(C),A3) ) ).

% diff_0
tff(fact_2266_mult__minus1__right,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [Z2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),Z2),aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),Z2) ) ).

% mult_minus1_right
tff(fact_2267_mult__minus1,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [Z2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),one_one(C))),Z2) = aa(C,C,uminus_uminus(C),Z2) ) ).

% mult_minus1
tff(fact_2268_uminus__add__conv__diff,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),B2) = minus_minus(C,B2,A3) ) ).

% uminus_add_conv_diff
tff(fact_2269_diff__minus__eq__add,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,aa(C,C,uminus_uminus(C),B2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) ) ).

% diff_minus_eq_add
tff(fact_2270_div__minus1__right,axiom,
    ! [C: $tType] :
      ( euclid8851590272496341667cancel(C)
     => ! [A3: C] : divide_divide(C,A3,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),A3) ) ).

% div_minus1_right
tff(fact_2271_divide__minus1,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C] : divide_divide(C,X,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),X) ) ).

% divide_minus1
tff(fact_2272_inf__compl__bot__left1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)) = bot_bot(C) ) ).

% inf_compl_bot_left1
tff(fact_2273_inf__compl__bot__left2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,uminus_uminus(C),X)),Y)) = bot_bot(C) ) ).

% inf_compl_bot_left2
tff(fact_2274_inf__compl__bot__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,aa(C,fun(C,C),inf_inf(C),Y),aa(C,C,uminus_uminus(C),X))) = bot_bot(C) ) ).

% inf_compl_bot_right
tff(fact_2275_boolean__algebra_Oconj__cancel__left,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,uminus_uminus(C),X)),X) = bot_bot(C) ) ).

% boolean_algebra.conj_cancel_left
tff(fact_2276_boolean__algebra_Oconj__cancel__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,uminus_uminus(C),X)) = bot_bot(C) ) ).

% boolean_algebra.conj_cancel_right
tff(fact_2277_subset__Compl__singleton,axiom,
    ! [C: $tType,A4: set(C),B2: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))))
    <=> ~ member2(C,B2,A4) ) ).

% subset_Compl_singleton
tff(fact_2278_boolean__algebra_Ode__Morgan__disj,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,uminus_uminus(C),Y)) ) ).

% boolean_algebra.de_Morgan_disj
tff(fact_2279_boolean__algebra_Ode__Morgan__conj,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,uminus_uminus(C),Y)) ) ).

% boolean_algebra.de_Morgan_conj
tff(fact_2280_take__bit__Suc__1,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [N: nat] : bit_se2584673776208193580ke_bit(C,aa(nat,nat,suc,N),one_one(C)) = one_one(C) ) ).

% take_bit_Suc_1
tff(fact_2281_take__bit__numeral__1,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [La: num] : bit_se2584673776208193580ke_bit(C,aa(num,nat,numeral_numeral(nat),La),one_one(C)) = one_one(C) ) ).

% take_bit_numeral_1
tff(fact_2282_signed__take__bit__of__minus__1,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat] : bit_ri4674362597316999326ke_bit(C,N,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% signed_take_bit_of_minus_1
tff(fact_2283_dbl__inc__simps_I4_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl_inc(C,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% dbl_inc_simps(4)
tff(fact_2284_add__neg__numeral__special_I7_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,uminus_uminus(C),one_one(C))) = zero_zero(C) ) ) ).

% add_neg_numeral_special(7)
tff(fact_2285_add__neg__numeral__special_I8_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),one_one(C))),one_one(C)) = zero_zero(C) ) ) ).

% add_neg_numeral_special(8)
tff(fact_2286_diff__numeral__special_I12_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( minus_minus(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(C,C,uminus_uminus(C),one_one(C))) = zero_zero(C) ) ) ).

% diff_numeral_special(12)
tff(fact_2287_neg__one__eq__numeral__iff,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ! [N: num] :
          ( ( aa(C,C,uminus_uminus(C),one_one(C)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N)) )
        <=> ( N = one2 ) ) ) ).

% neg_one_eq_numeral_iff
tff(fact_2288_numeral__eq__neg__one__iff,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ! [N: num] :
          ( ( aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N)) = aa(C,C,uminus_uminus(C),one_one(C)) )
        <=> ( N = one2 ) ) ) ).

% numeral_eq_neg_one_iff
tff(fact_2289_mod__minus1__right,axiom,
    ! [C: $tType] :
      ( euclid8851590272496341667cancel(C)
     => ! [A3: C] : modulo_modulo(C,A3,aa(C,C,uminus_uminus(C),one_one(C))) = zero_zero(C) ) ).

% mod_minus1_right
tff(fact_2290_left__minus__one__mult__self,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [N: nat,A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),A3)) = A3 ) ).

% left_minus_one_mult_self
tff(fact_2291_minus__one__mult__self,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)) = one_one(C) ) ).

% minus_one_mult_self
tff(fact_2292_take__bit__of__1__eq__0__iff,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [N: nat] :
          ( ( bit_se2584673776208193580ke_bit(C,N,one_one(C)) = zero_zero(C) )
        <=> ( N = zero_zero(nat) ) ) ) ).

% take_bit_of_1_eq_0_iff
tff(fact_2293_mult__neg__numeral__simps_I3_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [M2: num,N: num] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),M2)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N))) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),M2),N))) ) ).

% mult_neg_numeral_simps(3)
tff(fact_2294_mult__neg__numeral__simps_I2_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [M2: num,N: num] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),aa(num,C,numeral_numeral(C),N)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),M2),N))) ) ).

% mult_neg_numeral_simps(2)
tff(fact_2295_mult__neg__numeral__simps_I1_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [M2: num,N: num] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N))) = aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),M2),N)) ) ).

% mult_neg_numeral_simps(1)
tff(fact_2296_dbl__dec__simps_I2_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl_dec(C,zero_zero(C)) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% dbl_dec_simps(2)
tff(fact_2297_not__neg__one__le__neg__numeral__iff,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] :
          ( ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2)))
        <=> ( M2 != one2 ) ) ) ).

% not_neg_one_le_neg_numeral_iff
tff(fact_2298_divide__le__eq__numeral1_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,W: num,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))),B2) ) ) ).

% divide_le_eq_numeral1(2)
tff(fact_2299_le__divide__eq__numeral1_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),divide_divide(C,B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))) ) ) ).

% le_divide_eq_numeral1(2)
tff(fact_2300_eq__divide__eq__numeral1_I2_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,W: num] :
          ( ( A3 = divide_divide(C,B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))) )
        <=> $ite(aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)) != zero_zero(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))) = B2,A3 = zero_zero(C)) ) ) ).

% eq_divide_eq_numeral1(2)
tff(fact_2301_divide__eq__eq__numeral1_I2_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,W: num,A3: C] :
          ( ( divide_divide(C,B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))) = A3 )
        <=> $ite(aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)) != zero_zero(C),B2 = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),A3 = zero_zero(C)) ) ) ).

% divide_eq_eq_numeral1(2)
tff(fact_2302_neg__numeral__less__neg__one__iff,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),aa(C,C,uminus_uminus(C),one_one(C)))
        <=> ( M2 != one2 ) ) ) ).

% neg_numeral_less_neg_one_iff
tff(fact_2303_divide__less__eq__numeral1_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,W: num,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))),B2) ) ) ).

% divide_less_eq_numeral1(2)
tff(fact_2304_less__divide__eq__numeral1_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),divide_divide(C,B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))) ) ) ).

% less_divide_eq_numeral1(2)
tff(fact_2305_xor__numerals_I3_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),bit0(X))),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y))) ) ).

% xor_numerals(3)
tff(fact_2306_take__bit__of__1,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat] : bit_se2584673776208193580ke_bit(C,N,one_one(C)) = aa($o,C,zero_neq_one_of_bool(C),aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)) ) ).

% take_bit_of_1
tff(fact_2307_add__neg__numeral__special_I9_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),bit0(one2))) ) ) ).

% add_neg_numeral_special(9)
tff(fact_2308_diff__numeral__special_I10_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( minus_minus(C,aa(C,C,uminus_uminus(C),one_one(C)),one_one(C)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),bit0(one2))) ) ) ).

% diff_numeral_special(10)
tff(fact_2309_diff__numeral__special_I11_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( minus_minus(C,one_one(C),aa(C,C,uminus_uminus(C),one_one(C))) = aa(num,C,numeral_numeral(C),bit0(one2)) ) ) ).

% diff_numeral_special(11)
tff(fact_2310_minus__1__div__2__eq,axiom,
    ! [C: $tType] :
      ( euclid8789492081693882211th_nat(C)
     => ( divide_divide(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(num,C,numeral_numeral(C),bit0(one2))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% minus_1_div_2_eq
tff(fact_2311_bits__minus__1__mod__2__eq,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ( modulo_modulo(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(num,C,numeral_numeral(C),bit0(one2))) = one_one(C) ) ) ).

% bits_minus_1_mod_2_eq
tff(fact_2312_minus__1__mod__2__eq,axiom,
    ! [C: $tType] :
      ( euclid8789492081693882211th_nat(C)
     => ( modulo_modulo(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(num,C,numeral_numeral(C),bit0(one2))) = one_one(C) ) ) ).

% minus_1_mod_2_eq
tff(fact_2313_diff__numeral__special_I4_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : minus_minus(C,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2)),one_one(C)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),plus_plus(num),M2),one2))) ) ).

% diff_numeral_special(4)
tff(fact_2314_diff__numeral__special_I3_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : minus_minus(C,one_one(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N))) = aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),N)) ) ).

% diff_numeral_special(3)
tff(fact_2315_dbl__simps_I4_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl(C,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),bit0(one2))) ) ) ).

% dbl_simps(4)
tff(fact_2316_power__minus1__even,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)) = one_one(C) ) ).

% power_minus1_even
tff(fact_2317_neg__one__odd__power,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [N: nat] :
          ( ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),bit0(one2)),N)
         => ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ) ).

% neg_one_odd_power
tff(fact_2318_neg__one__even__power,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [N: nat] :
          ( dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),bit0(one2)),N)
         => ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N) = one_one(C) ) ) ) ).

% neg_one_even_power
tff(fact_2319_take__bit__of__exp,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [M2: nat,N: nat] : bit_se2584673776208193580ke_bit(C,M2,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa($o,C,zero_neq_one_of_bool(C),aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2))),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) ) ).

% take_bit_of_exp
tff(fact_2320_take__bit__of__2,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [N: nat] : bit_se2584673776208193580ke_bit(C,N,aa(num,C,numeral_numeral(C),bit0(one2))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa($o,C,zero_neq_one_of_bool(C),aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N))),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% take_bit_of_2
tff(fact_2321_minus__equation__iff,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,uminus_uminus(C),A3) = B2 )
        <=> ( aa(C,C,uminus_uminus(C),B2) = A3 ) ) ) ).

% minus_equation_iff
tff(fact_2322_equation__minus__iff,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,uminus_uminus(C),B2) )
        <=> ( B2 = aa(C,C,uminus_uminus(C),A3) ) ) ) ).

% equation_minus_iff
tff(fact_2323_fun__Compl__def,axiom,
    ! [D: $tType,C: $tType] :
      ( uminus(D)
     => ! [A4: fun(C,D),X3: C] : aa(C,D,aa(fun(C,D),fun(C,D),uminus_uminus(fun(C,D)),A4),X3) = aa(D,D,uminus_uminus(D),aa(C,D,A4,X3)) ) ).

% fun_Compl_def
tff(fact_2324_le__imp__neg__le,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,uminus_uminus(C),A3)) ) ) ).

% le_imp_neg_le
tff(fact_2325_minus__le__iff,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),A3) ) ) ).

% minus_le_iff
tff(fact_2326_le__minus__iff,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,uminus_uminus(C),B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,uminus_uminus(C),A3)) ) ) ).

% le_minus_iff
tff(fact_2327_compl__le__swap2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),Y)),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),X)),Y) ) ) ).

% compl_le_swap2
tff(fact_2328_compl__le__swap1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y),aa(C,C,uminus_uminus(C),X))
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,uminus_uminus(C),Y)) ) ) ).

% compl_le_swap1
tff(fact_2329_compl__mono,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),Y)),aa(C,C,uminus_uminus(C),X)) ) ) ).

% compl_mono
tff(fact_2330_minus__less__iff,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),A3)),B2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),B2)),A3) ) ) ).

% minus_less_iff
tff(fact_2331_less__minus__iff,axiom,
    ! [C: $tType] :
      ( ordered_ab_group_add(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,uminus_uminus(C),B2))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,uminus_uminus(C),A3)) ) ) ).

% less_minus_iff
tff(fact_2332_compl__less__swap2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),Y)),X)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),X)),Y) ) ) ).

% compl_less_swap2
tff(fact_2333_compl__less__swap1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [Y: C,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),aa(C,C,uminus_uminus(C),X))
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,uminus_uminus(C),Y)) ) ) ).

% compl_less_swap1
tff(fact_2334_add_Oinverse__distrib__swap,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,uminus_uminus(C),A3)) ) ).

% add.inverse_distrib_swap
tff(fact_2335_group__cancel_Oneg1,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A4: C,K: C,A3: C] :
          ( ( A4 = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),A3) )
         => ( aa(C,C,uminus_uminus(C),A4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),K)),aa(C,C,uminus_uminus(C),A3)) ) ) ) ).

% group_cancel.neg1
tff(fact_2336_square__eq__iff,axiom,
    ! [C: $tType] :
      ( idom(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),B2) )
        <=> ( ( A3 = B2 )
            | ( A3 = aa(C,C,uminus_uminus(C),B2) ) ) ) ) ).

% square_eq_iff
tff(fact_2337_minus__mult__commute,axiom,
    ! [C: $tType] :
      ( ring(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),A3)),B2) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,uminus_uminus(C),B2)) ) ).

% minus_mult_commute
tff(fact_2338_one__neq__neg__one,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ( one_one(C) != aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% one_neq_neg_one
tff(fact_2339_minus__diff__commute,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [B2: C,A3: C] : minus_minus(C,aa(C,C,uminus_uminus(C),B2),A3) = minus_minus(C,aa(C,C,uminus_uminus(C),A3),B2) ) ).

% minus_diff_commute
tff(fact_2340_minus__assn__def,axiom,
    ! [A3: assn,B2: assn] : minus_minus(assn,A3,B2) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),A3),aa(assn,assn,uminus_uminus(assn),B2)) ).

% minus_assn_def
tff(fact_2341_div__mult2__eq_H,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C,M2: nat,N: nat] : divide_divide(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),M2)),aa(nat,C,semiring_1_of_nat(C),N))) = divide_divide(C,divide_divide(C,A3,aa(nat,C,semiring_1_of_nat(C),M2)),aa(nat,C,semiring_1_of_nat(C),N)) ) ).

% div_mult2_eq'
tff(fact_2342_neg__eq__iff__add__eq__0,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,uminus_uminus(C),A3) = B2 )
        <=> ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = zero_zero(C) ) ) ) ).

% neg_eq_iff_add_eq_0
tff(fact_2343_eq__neg__iff__add__eq__0,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = aa(C,C,uminus_uminus(C),B2) )
        <=> ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = zero_zero(C) ) ) ) ).

% eq_neg_iff_add_eq_0
tff(fact_2344_add_Oinverse__unique,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = zero_zero(C) )
         => ( aa(C,C,uminus_uminus(C),A3) = B2 ) ) ) ).

% add.inverse_unique
tff(fact_2345_ab__group__add__class_Oab__left__minus,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),A3) = zero_zero(C) ) ).

% ab_group_add_class.ab_left_minus
tff(fact_2346_add__eq__0__iff,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2) = zero_zero(C) )
        <=> ( B2 = aa(C,C,uminus_uminus(C),A3) ) ) ) ).

% add_eq_0_iff
tff(fact_2347_le__minus__one__simps_I4_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% le_minus_one_simps(4)
tff(fact_2348_le__minus__one__simps_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),one_one(C))),one_one(C)) ) ).

% le_minus_one_simps(2)
tff(fact_2349_zero__neq__neg__one,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ( zero_zero(C) != aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% zero_neq_neg_one
tff(fact_2350_less__minus__one__simps_I4_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% less_minus_one_simps(4)
tff(fact_2351_less__minus__one__simps_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),one_one(C))),one_one(C)) ) ).

% less_minus_one_simps(2)
tff(fact_2352_numeral__neq__neg__one,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ! [N: num] : aa(num,C,numeral_numeral(C),N) != aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% numeral_neq_neg_one
tff(fact_2353_one__neq__neg__numeral,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ! [N: num] : one_one(C) != aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N)) ) ).

% one_neq_neg_numeral
tff(fact_2354_square__eq__1__iff,axiom,
    ! [C: $tType] :
      ( ring_15535105094025558882visors(C)
     => ! [X: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),X),X) = one_one(C) )
        <=> ( ( X = one_one(C) )
            | ( X = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ) ) ).

% square_eq_1_iff
tff(fact_2355_ab__group__add__class_Oab__diff__conv__add__uminus,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,uminus_uminus(C),B2)) ) ).

% ab_group_add_class.ab_diff_conv_add_uminus
tff(fact_2356_diff__conv__add__uminus,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => ! [A3: C,B2: C] : minus_minus(C,A3,B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,uminus_uminus(C),B2)) ) ).

% diff_conv_add_uminus
tff(fact_2357_group__cancel_Osub2,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [B3: C,K: C,B2: C,A3: C] :
          ( ( B3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),K),B2) )
         => ( minus_minus(C,A3,B3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),K)),minus_minus(C,A3,B2)) ) ) ) ).

% group_cancel.sub2
tff(fact_2358_inf__cancel__left1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),A3)),aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,uminus_uminus(C),X)),B2)) = bot_bot(C) ) ).

% inf_cancel_left1
tff(fact_2359_inf__cancel__left2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,uminus_uminus(C),X)),A3)),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),B2)) = bot_bot(C) ) ).

% inf_cancel_left2
tff(fact_2360_diff__eq,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : minus_minus(C,X,Y) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,uminus_uminus(C),Y)) ) ).

% diff_eq
tff(fact_2361_subset__Compl__self__eq,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),A4))
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% subset_Compl_self_eq
tff(fact_2362_Compl__Un,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)),aa(set(C),set(C),uminus_uminus(set(C)),B3)) ).

% Compl_Un
tff(fact_2363_Compl__Int,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)),aa(set(C),set(C),uminus_uminus(set(C)),B3)) ).

% Compl_Int
tff(fact_2364_minus__min__eq__max,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [X: C,Y: C] : aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)) = aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,uminus_uminus(C),Y)) ) ).

% minus_min_eq_max
tff(fact_2365_minus__max__eq__min,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [X: C,Y: C] : aa(C,C,uminus_uminus(C),aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y)) = aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,uminus_uminus(C),Y)) ) ).

% minus_max_eq_min
tff(fact_2366_gbinomial__negated__upper,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,A3),K) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),K)),aa(nat,C,gbinomial(C,minus_minus(C,minus_minus(C,aa(nat,C,semiring_1_of_nat(C),K),A3),one_one(C))),K)) ) ).

% gbinomial_negated_upper
tff(fact_2367_gbinomial__index__swap,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),K)),aa(nat,C,gbinomial(C,minus_minus(C,aa(C,C,uminus_uminus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))),K)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),aa(nat,C,gbinomial(C,minus_minus(C,aa(C,C,uminus_uminus(C),aa(nat,C,semiring_1_of_nat(C),K)),one_one(C))),N)) ) ).

% gbinomial_index_swap
tff(fact_2368_coset__def,axiom,
    ! [C: $tType,Xs: list(C)] : coset(C,Xs) = aa(set(C),set(C),uminus_uminus(set(C)),aa(list(C),set(C),set2(C),Xs)) ).

% coset_def
tff(fact_2369_compl__coset,axiom,
    ! [C: $tType,Xs: list(C)] : aa(set(C),set(C),uminus_uminus(set(C)),coset(C,Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% compl_coset
tff(fact_2370_gbinomial__minus,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,aa(C,C,uminus_uminus(C),A3)),K) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),K)),aa(nat,C,gbinomial(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(nat,C,semiring_1_of_nat(C),K)),one_one(C))),K)) ) ).

% gbinomial_minus
tff(fact_2371_le__minus__one__simps_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),one_one(C))),zero_zero(C)) ) ).

% le_minus_one_simps(1)
tff(fact_2372_le__minus__one__simps_I3_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% le_minus_one_simps(3)
tff(fact_2373_less__minus__one__simps_I3_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% less_minus_one_simps(3)
tff(fact_2374_less__minus__one__simps_I1_J,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),one_one(C))),zero_zero(C)) ) ).

% less_minus_one_simps(1)
tff(fact_2375_not__one__le__neg__numeral,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))) ) ).

% not_one_le_neg_numeral
tff(fact_2376_not__numeral__le__neg__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(num,C,numeral_numeral(C),M2)),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% not_numeral_le_neg_one
tff(fact_2377_neg__numeral__le__neg__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% neg_numeral_le_neg_one
tff(fact_2378_neg__one__le__numeral,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(num,C,numeral_numeral(C),M2)) ) ).

% neg_one_le_numeral
tff(fact_2379_neg__numeral__le__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),one_one(C)) ) ).

% neg_numeral_le_one
tff(fact_2380_neg__numeral__less__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),one_one(C)) ) ).

% neg_numeral_less_one
tff(fact_2381_neg__one__less__numeral,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(num,C,numeral_numeral(C),M2)) ) ).

% neg_one_less_numeral
tff(fact_2382_not__numeral__less__neg__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(num,C,numeral_numeral(C),M2)),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% not_numeral_less_neg_one
tff(fact_2383_not__one__less__neg__numeral,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))) ) ).

% not_one_less_neg_numeral
tff(fact_2384_not__neg__one__less__neg__numeral,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [M2: num] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))) ) ).

% not_neg_one_less_neg_numeral
tff(fact_2385_eq__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( A3 = aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)) )
        <=> $ite(C3 != zero_zero(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3) = aa(C,C,uminus_uminus(C),B2),A3 = zero_zero(C)) ) ) ).

% eq_minus_divide_eq
tff(fact_2386_minus__divide__eq__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,C3: C,A3: C] :
          ( ( aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)) = A3 )
        <=> $ite(C3 != zero_zero(C),aa(C,C,uminus_uminus(C),B2) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),A3 = zero_zero(C)) ) ) ).

% minus_divide_eq_eq
tff(fact_2387_nonzero__neg__divide__eq__eq,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,A3: C,C3: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( aa(C,C,uminus_uminus(C),divide_divide(C,A3,B2)) = C3 )
          <=> ( aa(C,C,uminus_uminus(C),A3) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2) ) ) ) ) ).

% nonzero_neg_divide_eq_eq
tff(fact_2388_nonzero__neg__divide__eq__eq2,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,C3: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( C3 = aa(C,C,uminus_uminus(C),divide_divide(C,A3,B2)) )
          <=> ( aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2) = aa(C,C,uminus_uminus(C),A3) ) ) ) ) ).

% nonzero_neg_divide_eq_eq2
tff(fact_2389_mult__1s__ring__1_I2_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),B2),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),one2))) = aa(C,C,uminus_uminus(C),B2) ) ).

% mult_1s_ring_1(2)
tff(fact_2390_mult__1s__ring__1_I1_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),one2))),B2) = aa(C,C,uminus_uminus(C),B2) ) ).

% mult_1s_ring_1(1)
tff(fact_2391_divide__eq__minus__1__iff,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] :
          ( ( divide_divide(C,A3,B2) = aa(C,C,uminus_uminus(C),one_one(C)) )
        <=> ( ( B2 != zero_zero(C) )
            & ( A3 = aa(C,C,uminus_uminus(C),B2) ) ) ) ) ).

% divide_eq_minus_1_iff
tff(fact_2392_inf__shunt,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = bot_bot(C) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,uminus_uminus(C),Y)) ) ) ).

% inf_shunt
tff(fact_2393_uminus__numeral__One,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),one2)) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% uminus_numeral_One
tff(fact_2394_shunt1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)),Z2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),Y)),Z2)) ) ) ).

% shunt1
tff(fact_2395_shunt2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C,Z2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),aa(C,C,uminus_uminus(C),Y))),Z2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),Y),Z2)) ) ) ).

% shunt2
tff(fact_2396_sup__neg__inf,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [P3: C,Q2: C,R3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),P3),aa(C,C,aa(C,fun(C,C),sup_sup(C),Q2),R3))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),P3),aa(C,C,uminus_uminus(C),Q2))),R3) ) ) ).

% sup_neg_inf
tff(fact_2397_power__minus,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [A3: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),A3)),N) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),N)) ) ).

% power_minus
tff(fact_2398_disjoint__eq__subset__Compl,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),B3)) ) ).

% disjoint_eq_subset_Compl
tff(fact_2399_Compl__insert,axiom,
    ! [C: $tType,X: C,A4: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = minus_minus(set(C),aa(set(C),set(C),uminus_uminus(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ).

% Compl_insert
tff(fact_2400_take__bit__Suc__minus__1__eq,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat] : bit_se2584673776208193580ke_bit(C,aa(nat,nat,suc,N),aa(C,C,uminus_uminus(C),one_one(C))) = minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(nat,nat,suc,N)),one_one(C)) ) ).

% take_bit_Suc_minus_1_eq
tff(fact_2401_take__bit__numeral__minus__1__eq,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [K: num] : bit_se2584673776208193580ke_bit(C,aa(num,nat,numeral_numeral(nat),K),aa(C,C,uminus_uminus(C),one_one(C))) = minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(num,nat,numeral_numeral(nat),K)),one_one(C)) ) ).

% take_bit_numeral_minus_1_eq
tff(fact_2402_mod__mult2__eq_H,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C,M2: nat,N: nat] : modulo_modulo(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),M2)),aa(nat,C,semiring_1_of_nat(C),N))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),M2)),modulo_modulo(C,divide_divide(C,A3,aa(nat,C,semiring_1_of_nat(C),M2)),aa(nat,C,semiring_1_of_nat(C),N)))),modulo_modulo(C,A3,aa(nat,C,semiring_1_of_nat(C),M2))) ) ).

% mod_mult2_eq'
tff(fact_2403_pos__minus__divide__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3))),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% pos_minus_divide_less_eq
tff(fact_2404_pos__less__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)) ) ) ) ).

% pos_less_minus_divide_eq
tff(fact_2405_neg__minus__divide__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3))),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)) ) ) ) ).

% neg_minus_divide_less_eq
tff(fact_2406_neg__less__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% neg_less_minus_divide_eq
tff(fact_2407_minus__divide__less__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3))),A3)
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)) ) ) ) ).

% minus_divide_less_eq
tff(fact_2408_less__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))) ) ) ) ).

% less_minus_divide_eq
tff(fact_2409_divide__eq__eq__numeral_I2_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [B2: C,C3: C,W: num] :
          ( ( divide_divide(C,B2,C3) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)) )
        <=> $ite(C3 != zero_zero(C),B2 = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)) = zero_zero(C)) ) ) ).

% divide_eq_eq_numeral(2)
tff(fact_2410_eq__divide__eq__numeral_I2_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [W: num,B2: C,C3: C] :
          ( ( aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)) = divide_divide(C,B2,C3) )
        <=> $ite(C3 != zero_zero(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3) = B2,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)) = zero_zero(C)) ) ) ).

% eq_divide_eq_numeral(2)
tff(fact_2411_add__divide__eq__if__simps_I3_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,Z2: C,B2: C] :
          aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),divide_divide(C,A3,Z2))),B2) = $ite(Z2 = zero_zero(C),B2,divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),Z2)),Z2)) ) ).

% add_divide_eq_if_simps(3)
tff(fact_2412_minus__divide__add__eq__iff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Z2: C,X: C,Y: C] :
          ( ( Z2 != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),divide_divide(C,X,Z2))),Y) = divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)),Z2) ) ) ) ).

% minus_divide_add_eq_iff
tff(fact_2413_add__divide__eq__if__simps_I6_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,Z2: C,B2: C] :
          minus_minus(C,aa(C,C,uminus_uminus(C),divide_divide(C,A3,Z2)),B2) = $ite(Z2 = zero_zero(C),aa(C,C,uminus_uminus(C),B2),divide_divide(C,minus_minus(C,aa(C,C,uminus_uminus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),Z2)),Z2)) ) ).

% add_divide_eq_if_simps(6)
tff(fact_2414_add__divide__eq__if__simps_I5_J,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,Z2: C,B2: C] :
          minus_minus(C,divide_divide(C,A3,Z2),B2) = $ite(Z2 = zero_zero(C),aa(C,C,uminus_uminus(C),B2),divide_divide(C,minus_minus(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),Z2)),Z2)) ) ).

% add_divide_eq_if_simps(5)
tff(fact_2415_minus__divide__diff__eq__iff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Z2: C,X: C,Y: C] :
          ( ( Z2 != zero_zero(C) )
         => ( minus_minus(C,aa(C,C,uminus_uminus(C),divide_divide(C,X,Z2)),Y) = divide_divide(C,minus_minus(C,aa(C,C,uminus_uminus(C),X),aa(C,C,aa(C,fun(C,C),times_times(C),Y),Z2)),Z2) ) ) ) ).

% minus_divide_diff_eq_iff
tff(fact_2416_gbinomial__absorb__comp,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,A3,aa(nat,C,semiring_1_of_nat(C),K))),aa(nat,C,gbinomial(C,A3),K)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),K)) ) ).

% gbinomial_absorb_comp
tff(fact_2417_gbinomial__mult__1,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,gbinomial(C,A3),K)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),K)),aa(nat,C,gbinomial(C,A3),K))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,K))),aa(nat,C,gbinomial(C,A3),aa(nat,nat,suc,K)))) ) ).

% gbinomial_mult_1
tff(fact_2418_gbinomial__mult__1_H,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,A3),K)),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),K)),aa(nat,C,gbinomial(C,A3),K))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,K))),aa(nat,C,gbinomial(C,A3),aa(nat,nat,suc,K)))) ) ).

% gbinomial_mult_1'
tff(fact_2419_take__bit__Suc__bit0,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [N: nat,K: num] : bit_se2584673776208193580ke_bit(C,aa(nat,nat,suc,N),aa(num,C,numeral_numeral(C),bit0(K))) = aa(C,C,aa(C,fun(C,C),times_times(C),bit_se2584673776208193580ke_bit(C,N,aa(num,C,numeral_numeral(C),K))),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% take_bit_Suc_bit0
tff(fact_2420_le__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))) ) ) ) ).

% le_minus_divide_eq
tff(fact_2421_minus__divide__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3))),A3)
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)) ) ) ) ).

% minus_divide_le_eq
tff(fact_2422_neg__le__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% neg_le_minus_divide_eq
tff(fact_2423_neg__minus__divide__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3))),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)) ) ) ) ).

% neg_minus_divide_le_eq
tff(fact_2424_pos__le__minus__divide__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3)))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,uminus_uminus(C),B2)) ) ) ) ).

% pos_le_minus_divide_eq
tff(fact_2425_pos__minus__divide__le__eq,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),divide_divide(C,B2,C3))),A3)
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),B2)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)) ) ) ) ).

% pos_minus_divide_le_eq
tff(fact_2426_less__divide__eq__numeral_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [W: num,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),divide_divide(C,B2,C3))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),B2),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),zero_zero(C))) ) ) ) ).

% less_divide_eq_numeral(2)
tff(fact_2427_divide__less__eq__numeral_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,B2,C3)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),B2),aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))) ) ) ) ).

% divide_less_eq_numeral(2)
tff(fact_2428_Suc__times__gbinomial,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,K))),aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),aa(nat,nat,suc,K))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),aa(nat,C,gbinomial(C,A3),K)) ) ).

% Suc_times_gbinomial
tff(fact_2429_gbinomial__absorption,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,K))),aa(nat,C,gbinomial(C,A3),aa(nat,nat,suc,K))) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),K)) ) ).

% gbinomial_absorption
tff(fact_2430_gbinomial__trinomial__revision,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,M2: nat,A3: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),M2)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,A3),M2)),aa(nat,C,gbinomial(C,aa(nat,C,semiring_1_of_nat(C),M2)),K)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,A3),K)),aa(nat,C,gbinomial(C,minus_minus(C,A3,aa(nat,C,semiring_1_of_nat(C),K))),minus_minus(nat,M2,K))) ) ) ) ).

% gbinomial_trinomial_revision
tff(fact_2431_power2__eq__1__iff,axiom,
    ! [C: $tType] :
      ( ring_15535105094025558882visors(C)
     => ! [A3: C] :
          ( ( aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),bit0(one2))) = one_one(C) )
        <=> ( ( A3 = one_one(C) )
            | ( A3 = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ) ) ).

% power2_eq_1_iff
tff(fact_2432_neg__one__power__add__eq__neg__one__power__diff,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [K: nat,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N)
         => ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K)) = aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),minus_minus(nat,N,K)) ) ) ) ).

% neg_one_power_add_eq_neg_one_power_diff
tff(fact_2433_divide__le__eq__numeral_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [B2: C,C3: C,W: num] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,B2,C3)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),B2),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W)))) ) ) ) ).

% divide_le_eq_numeral(2)
tff(fact_2434_le__divide__eq__numeral_I2_J,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [W: num,B2: C,C3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),divide_divide(C,B2,C3))
        <=> $ite(
              aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
              aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),B2),
              $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),C3),zero_zero(C)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),C3)),aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),zero_zero(C))) ) ) ) ).

% le_divide_eq_numeral(2)
tff(fact_2435_gbinomial__factors,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),aa(nat,nat,suc,K)) = aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,K)))),aa(nat,C,gbinomial(C,A3),K)) ) ).

% gbinomial_factors
tff(fact_2436_gbinomial__rec,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))),aa(nat,nat,suc,K)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,A3),K)),divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,K)))) ) ).

% gbinomial_rec
tff(fact_2437_square__le__1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),one_one(C))),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(one2)))),one_one(C)) ) ) ) ).

% square_le_1
tff(fact_2438_minus__power__mult__self,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [A3: C,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),A3)),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),A3)),N)) = aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)) ) ).

% minus_power_mult_self
tff(fact_2439_minus__one__power__iff,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [N: nat] :
          aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N) = $ite(dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),bit0(one2)),N),one_one(C),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% minus_one_power_iff
tff(fact_2440_power__minus1__odd,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% power_minus1_odd
tff(fact_2441_take__bit__Suc,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se2584673776208193580ke_bit(C,aa(nat,nat,suc,N),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),bit_se2584673776208193580ke_bit(C,N,divide_divide(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))))),aa(num,C,numeral_numeral(C),bit0(one2)))),modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2)))) ) ).

% take_bit_Suc
tff(fact_2442_semiring__norm_I170_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [V: num,W: num,Y: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),V))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),Y)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),V),W)))),Y) ) ).

% semiring_norm(170)
tff(fact_2443_semiring__norm_I171_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [V: num,W: num,Y: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),V)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),Y)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),V),W)))),Y) ) ).

% semiring_norm(171)
tff(fact_2444_semiring__norm_I172_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [V: num,W: num,Y: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),V))),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))),Y)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),times_times(num),V),W))),Y) ) ).

% semiring_norm(172)
tff(fact_2445_of__nat__Suc,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [M2: nat] : aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,M2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(nat,C,semiring_1_of_nat(C),M2)) ) ).

% of_nat_Suc
tff(fact_2446_of__nat__1,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ( aa(nat,C,semiring_1_of_nat(C),one_one(nat)) = one_one(C) ) ) ).

% of_nat_1
tff(fact_2447_of__nat__1__eq__iff,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [N: nat] :
          ( ( one_one(C) = aa(nat,C,semiring_1_of_nat(C),N) )
        <=> ( N = one_one(nat) ) ) ) ).

% of_nat_1_eq_iff
tff(fact_2448_Compl__eq__Compl__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),uminus_uminus(set(C)),A4) = aa(set(C),set(C),uminus_uminus(set(C)),B3) )
    <=> ( A4 = B3 ) ) ).

% Compl_eq_Compl_iff
tff(fact_2449_Compl__iff,axiom,
    ! [C: $tType,C3: C,A4: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),uminus_uminus(set(C)),A4))
    <=> ~ member2(C,C3,A4) ) ).

% Compl_iff
tff(fact_2450_ComplI,axiom,
    ! [C: $tType,C3: C,A4: set(C)] :
      ( ~ member2(C,C3,A4)
     => member2(C,C3,aa(set(C),set(C),uminus_uminus(set(C)),A4)) ) ).

% ComplI
tff(fact_2451_of__nat__mult,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [M2: nat,N: nat] : aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M2),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),M2)),aa(nat,C,semiring_1_of_nat(C),N)) ) ).

% of_nat_mult
tff(fact_2452_of__nat__eq__1__iff,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [N: nat] :
          ( ( aa(nat,C,semiring_1_of_nat(C),N) = one_one(C) )
        <=> ( N = one_one(nat) ) ) ) ).

% of_nat_eq_1_iff
tff(fact_2453_double__complement,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)) = A4 ).

% double_complement
tff(fact_2454_ComplD,axiom,
    ! [C: $tType,C3: C,A4: set(C)] :
      ( member2(C,C3,aa(set(C),set(C),uminus_uminus(set(C)),A4))
     => ~ member2(C,C3,A4) ) ).

% ComplD
tff(fact_2455_inf__nat__def,axiom,
    inf_inf(nat) = ord_min(nat) ).

% inf_nat_def
tff(fact_2456_mult__of__nat__commute,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [X: nat,Y: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),X)),Y) = aa(C,C,aa(C,fun(C,C),times_times(C),Y),aa(nat,C,semiring_1_of_nat(C),X)) ) ).

% mult_of_nat_commute
tff(fact_2457_numeral__times__minus__swap,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [W: num,X: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),aa(C,C,uminus_uminus(C),X)) = aa(C,C,aa(C,fun(C,C),times_times(C),X),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))) ) ).

% numeral_times_minus_swap
tff(fact_2458_nat__approx__posE,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [E4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),E4)
         => ~ ! [N7: nat] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),divide_divide(C,one_one(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,N7)))),E4) ) ) ).

% nat_approx_posE
tff(fact_2459_ex__less__of__nat__mult,axiom,
    ! [C: $tType] :
      ( archim462609752435547400_field(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),X)
         => ? [N7: nat] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N7)),X)) ) ) ).

% ex_less_of_nat_mult
tff(fact_2460_pochhammer__double,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Z2: C,N: nat] : comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Z2),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)))),comm_s3205402744901411588hammer(C,Z2,N))),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2)))),N)) ) ).

% pochhammer_double
tff(fact_2461_push__bit__numeral__minus__1,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: num] : bit_se4730199178511100633sh_bit(C,aa(num,nat,numeral_numeral(nat),N),aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(num,nat,numeral_numeral(nat),N))) ) ).

% push_bit_numeral_minus_1
tff(fact_2462_xor__numerals_I4_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),bit0(X))),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y)))) ) ).

% xor_numerals(4)
tff(fact_2463_xor__numerals_I6_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),bit1(X))),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y)))) ) ).

% xor_numerals(6)
tff(fact_2464_pochhammer__0,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [A3: C] : comm_s3205402744901411588hammer(C,A3,zero_zero(nat)) = one_one(C) ) ).

% pochhammer_0
tff(fact_2465_xor__numerals_I1_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),one_one(C)),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(num,C,numeral_numeral(C),bit1(Y)) ) ).

% xor_numerals(1)
tff(fact_2466_xor__numerals_I2_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),one_one(C)),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(num,C,numeral_numeral(C),bit0(Y)) ) ).

% xor_numerals(2)
tff(fact_2467_xor__numerals_I5_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),bit0(X))),one_one(C)) = aa(num,C,numeral_numeral(C),bit1(X)) ) ).

% xor_numerals(5)
tff(fact_2468_xor__numerals_I8_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),bit1(X))),one_one(C)) = aa(num,C,numeral_numeral(C),bit0(X)) ) ).

% xor_numerals(8)
tff(fact_2469_dbl__inc__simps_I3_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl_inc(C,one_one(C)) = aa(num,C,numeral_numeral(C),bit1(one2)) ) ) ).

% dbl_inc_simps(3)
tff(fact_2470_push__bit__Suc,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se4730199178511100633sh_bit(C,aa(nat,nat,suc,N),A3) = bit_se4730199178511100633sh_bit(C,N,aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),bit0(one2)))) ) ).

% push_bit_Suc
tff(fact_2471_xor__numerals_I7_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),bit1(X))),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y))) ) ).

% xor_numerals(7)
tff(fact_2472_push__bit__of__1,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat] : bit_se4730199178511100633sh_bit(C,N,one_one(C)) = aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N) ) ).

% push_bit_of_1
tff(fact_2473_dbl__dec__simps_I4_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ( neg_numeral_dbl_dec(C,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),bit1(one2))) ) ) ).

% dbl_dec_simps(4)
tff(fact_2474_numeral__Bit1,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ! [N: num] : aa(num,C,numeral_numeral(C),bit1(N)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),N)),aa(num,C,numeral_numeral(C),N))),one_one(C)) ) ).

% numeral_Bit1
tff(fact_2475_pochhammer__0__left,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [N: nat] :
          comm_s3205402744901411588hammer(C,zero_zero(C),N) = $ite(N = zero_zero(nat),one_one(C),zero_zero(C)) ) ).

% pochhammer_0_left
tff(fact_2476_flip__bit__eq__xor,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se8732182000553998342ip_bit(C,N,A3) = aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),A3),bit_se4730199178511100633sh_bit(C,N,one_one(C))) ) ).

% flip_bit_eq_xor
tff(fact_2477_power3__eq__cube,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [A3: C] : aa(nat,C,aa(C,fun(nat,C),power_power(C),A3),aa(num,nat,numeral_numeral(nat),bit1(one2))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),A3)),A3) ) ).

% power3_eq_cube
tff(fact_2478_push__bit__double,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se4730199178511100633sh_bit(C,N,aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(num,C,numeral_numeral(C),bit0(one2)))) = aa(C,C,aa(C,fun(C,C),times_times(C),bit_se4730199178511100633sh_bit(C,N,A3)),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% push_bit_double
tff(fact_2479_pochhammer__rec,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [A3: C,N: nat] : comm_s3205402744901411588hammer(C,A3,aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)),N)) ) ).

% pochhammer_rec
tff(fact_2480_pochhammer__rec_H,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [Z2: C,N: nat] : comm_s3205402744901411588hammer(C,Z2,aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),aa(nat,C,semiring_1_of_nat(C),N))),comm_s3205402744901411588hammer(C,Z2,N)) ) ).

% pochhammer_rec'
tff(fact_2481_pochhammer__Suc,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [A3: C,N: nat] : comm_s3205402744901411588hammer(C,A3,aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),comm_s3205402744901411588hammer(C,A3,N)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(nat,C,semiring_1_of_nat(C),N))) ) ).

% pochhammer_Suc
tff(fact_2482_pochhammer__product_H,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [Z2: C,N: nat,M2: nat] : comm_s3205402744901411588hammer(C,Z2,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M2)) = aa(C,C,aa(C,fun(C,C),times_times(C),comm_s3205402744901411588hammer(C,Z2,N)),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),aa(nat,C,semiring_1_of_nat(C),N)),M2)) ) ).

% pochhammer_product'
tff(fact_2483_card__3__iff,axiom,
    ! [C: $tType,S: set(C)] :
      ( ( finite_card(C,S) = aa(num,nat,numeral_numeral(nat),bit1(one2)) )
    <=> ? [X4: C,Y3: C,Z3: C] :
          ( ( S = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Z3),bot_bot(set(C))))) )
          & ( X4 != Y3 )
          & ( Y3 != Z3 )
          & ( X4 != Z3 ) ) ) ).

% card_3_iff
tff(fact_2484_push__bit__eq__mult,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se4730199178511100633sh_bit(C,N,A3) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) ) ).

% push_bit_eq_mult
tff(fact_2485_pochhammer__product,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [M2: nat,N: nat,Z2: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( comm_s3205402744901411588hammer(C,Z2,N) = aa(C,C,aa(C,fun(C,C),times_times(C),comm_s3205402744901411588hammer(C,Z2,M2)),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),aa(nat,C,semiring_1_of_nat(C),M2)),minus_minus(nat,N,M2))) ) ) ) ).

% pochhammer_product
tff(fact_2486_pochhammer__absorb__comp,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [R3: C,K: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,R3,aa(nat,C,semiring_1_of_nat(C),K))),comm_s3205402744901411588hammer(C,aa(C,C,uminus_uminus(C),R3),K)) = aa(C,C,aa(C,fun(C,C),times_times(C),R3),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),R3)),one_one(C)),K)) ) ).

% pochhammer_absorb_comp
tff(fact_2487_pochhammer__minus,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [B2: C,K: nat] : comm_s3205402744901411588hammer(C,aa(C,C,uminus_uminus(C),B2),K) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),K)),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,B2,aa(nat,C,semiring_1_of_nat(C),K))),one_one(C)),K)) ) ).

% pochhammer_minus
tff(fact_2488_pochhammer__minus_H,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [B2: C,K: nat] : comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,B2,aa(nat,C,semiring_1_of_nat(C),K))),one_one(C)),K) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),K)),comm_s3205402744901411588hammer(C,aa(C,C,uminus_uminus(C),B2),K)) ) ).

% pochhammer_minus'
tff(fact_2489_take__bit__Suc__bit1,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [N: nat,K: num] : bit_se2584673776208193580ke_bit(C,aa(nat,nat,suc,N),aa(num,C,numeral_numeral(C),bit1(K))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),bit_se2584673776208193580ke_bit(C,N,aa(num,C,numeral_numeral(C),K))),aa(num,C,numeral_numeral(C),bit0(one2)))),one_one(C)) ) ).

% take_bit_Suc_bit1
tff(fact_2490_fact__double,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [N: nat] : semiring_char_0_fact(C,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N))),comm_s3205402744901411588hammer(C,divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))),N))),semiring_char_0_fact(C,N)) ) ).

% fact_double
tff(fact_2491_take__bit__numeral__bit1,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [La: num,K: num] : bit_se2584673776208193580ke_bit(C,aa(num,nat,numeral_numeral(nat),La),aa(num,C,numeral_numeral(C),bit1(K))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),bit_se2584673776208193580ke_bit(C,pred_numeral(La),aa(num,C,numeral_numeral(C),K))),aa(num,C,numeral_numeral(C),bit0(one2)))),one_one(C)) ) ).

% take_bit_numeral_bit1
tff(fact_2492_or__numerals_I7_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),bit1(X))),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y)))) ) ).

% or_numerals(7)
tff(fact_2493_or__numerals_I6_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),bit1(X))),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y)))) ) ).

% or_numerals(6)
tff(fact_2494_or__numerals_I4_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),bit0(X))),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y)))) ) ).

% or_numerals(4)
tff(fact_2495_and__numerals_I7_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),bit1(X))),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y)))) ) ).

% and_numerals(7)
tff(fact_2496_bit_Oconj__one__right,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),X),aa(C,C,uminus_uminus(C),one_one(C))) = X ) ).

% bit.conj_one_right
tff(fact_2497_and_Oright__neutral,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),aa(C,C,uminus_uminus(C),one_one(C))) = A3 ) ).

% and.right_neutral
tff(fact_2498_and_Oleft__neutral,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(C,C,uminus_uminus(C),one_one(C))),A3) = A3 ) ).

% and.left_neutral
tff(fact_2499_bit_Odisj__one__right,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),X),aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% bit.disj_one_right
tff(fact_2500_bit_Odisj__one__left,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(C,C,uminus_uminus(C),one_one(C))),X) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% bit.disj_one_left
tff(fact_2501_fact__0,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ( semiring_char_0_fact(C,zero_zero(nat)) = one_one(C) ) ) ).

% fact_0
tff(fact_2502_fact__1,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ( semiring_char_0_fact(C,one_one(nat)) = one_one(C) ) ) ).

% fact_1
tff(fact_2503_and__numerals_I2_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),one_one(C)),aa(num,C,numeral_numeral(C),bit1(Y))) = one_one(C) ) ).

% and_numerals(2)
tff(fact_2504_and__numerals_I8_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),bit1(X))),one_one(C)) = one_one(C) ) ).

% and_numerals(8)
tff(fact_2505_or__numerals_I2_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [Y: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),one_one(C)),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(num,C,numeral_numeral(C),bit1(Y)) ) ).

% or_numerals(2)
tff(fact_2506_or__numerals_I8_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),bit1(X))),one_one(C)) = aa(num,C,numeral_numeral(C),bit1(X)) ) ).

% or_numerals(8)
tff(fact_2507_fact__Suc__0,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ( semiring_char_0_fact(C,aa(nat,nat,suc,zero_zero(nat))) = one_one(C) ) ) ).

% fact_Suc_0
tff(fact_2508_fact__Suc,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [N: nat] : semiring_char_0_fact(C,aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,N))),semiring_char_0_fact(C,N)) ) ).

% fact_Suc
tff(fact_2509_and__numerals_I5_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),bit0(X))),one_one(C)) = zero_zero(C) ) ).

% and_numerals(5)
tff(fact_2510_and__numerals_I1_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),one_one(C)),aa(num,C,numeral_numeral(C),bit0(Y))) = zero_zero(C) ) ).

% and_numerals(1)
tff(fact_2511_and__numerals_I3_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),bit0(X))),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y))) ) ).

% and_numerals(3)
tff(fact_2512_or__numerals_I3_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),bit0(X))),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y))) ) ).

% or_numerals(3)
tff(fact_2513_or__numerals_I5_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(num,C,numeral_numeral(C),bit0(X))),one_one(C)) = aa(num,C,numeral_numeral(C),bit1(X)) ) ).

% or_numerals(5)
tff(fact_2514_or__numerals_I1_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [Y: num] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),one_one(C)),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(num,C,numeral_numeral(C),bit1(Y)) ) ).

% or_numerals(1)
tff(fact_2515_and__numerals_I6_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),bit1(X))),aa(num,C,numeral_numeral(C),bit0(Y))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y))) ) ).

% and_numerals(6)
tff(fact_2516_and__numerals_I4_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [X: num,Y: num] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),bit0(X))),aa(num,C,numeral_numeral(C),bit1(Y))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),aa(num,C,numeral_numeral(C),X)),aa(num,C,numeral_numeral(C),Y))) ) ).

% and_numerals(4)
tff(fact_2517_bit_Ocomplement__unique,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C,X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),X) = zero_zero(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),A3),X) = aa(C,C,uminus_uminus(C),one_one(C)) )
           => ( ( aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),Y) = zero_zero(C) )
             => ( ( aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),A3),Y) = aa(C,C,uminus_uminus(C),one_one(C)) )
               => ( X = Y ) ) ) ) ) ) ).

% bit.complement_unique
tff(fact_2518_fact__numeral,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [K: num] : semiring_char_0_fact(C,aa(num,nat,numeral_numeral(nat),K)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),K)),semiring_char_0_fact(C,pred_numeral(K))) ) ).

% fact_numeral
tff(fact_2519_and__eq__minus__1__iff,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),B2) = aa(C,C,uminus_uminus(C),one_one(C)) )
        <=> ( ( A3 = aa(C,C,uminus_uminus(C),one_one(C)) )
            & ( B2 = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ) ) ).

% and_eq_minus_1_iff
tff(fact_2520_fact__ge__1,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [N: nat] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),semiring_char_0_fact(C,N)) ) ).

% fact_ge_1
tff(fact_2521_pochhammer__fact,axiom,
    ! [C: $tType] :
      ( ( semiring_char_0(C)
        & comm_semiring_1(C) )
     => ! [N: nat] : semiring_char_0_fact(C,N) = comm_s3205402744901411588hammer(C,one_one(C),N) ) ).

% pochhammer_fact
tff(fact_2522_fact__fact__dvd__fact,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [K: nat,N: nat] : dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),semiring_char_0_fact(C,K)),semiring_char_0_fact(C,N)),semiring_char_0_fact(C,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N))) ) ).

% fact_fact_dvd_fact
tff(fact_2523_set__bit__eq__or,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat,A3: C] : bit_se5668285175392031749et_bit(C,N,A3) = aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),A3),bit_se4730199178511100633sh_bit(C,N,one_one(C))) ) ).

% set_bit_eq_or
tff(fact_2524_choose__dvd,axiom,
    ! [C: $tType] :
      ( linordered_semidom(C)
     => ! [K: nat,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N)
         => dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),semiring_char_0_fact(C,K)),semiring_char_0_fact(C,minus_minus(nat,N,K))),semiring_char_0_fact(C,N)) ) ) ).

% choose_dvd
tff(fact_2525_and__one__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),one_one(C)) = modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% and_one_eq
tff(fact_2526_one__and__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),one_one(C)),A3) = modulo_modulo(C,A3,aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% one_and_eq
tff(fact_2527_fact__num__eq__if,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [M2: nat] :
          semiring_char_0_fact(C,M2) = $ite(M2 = zero_zero(nat),one_one(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),M2)),semiring_char_0_fact(C,minus_minus(nat,M2,one_one(nat))))) ) ).

% fact_num_eq_if
tff(fact_2528_fact__reduce,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( semiring_char_0_fact(C,N) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),semiring_char_0_fact(C,minus_minus(nat,N,one_one(nat)))) ) ) ) ).

% fact_reduce
tff(fact_2529_pochhammer__same,axiom,
    ! [C: $tType] :
      ( ( semiring_char_0(C)
        & comm_ring_1(C)
        & semiri3467727345109120633visors(C) )
     => ! [N: nat] : comm_s3205402744901411588hammer(C,aa(C,C,uminus_uminus(C),aa(nat,C,semiring_1_of_nat(C),N)),N) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),semiring_char_0_fact(C,N)) ) ).

% pochhammer_same
tff(fact_2530_take__bit__numeral__bit0,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [La: num,K: num] : bit_se2584673776208193580ke_bit(C,aa(num,nat,numeral_numeral(nat),La),aa(num,C,numeral_numeral(C),bit0(K))) = aa(C,C,aa(C,fun(C,C),times_times(C),bit_se2584673776208193580ke_bit(C,pred_numeral(La),aa(num,C,numeral_numeral(C),K))),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% take_bit_numeral_bit0
tff(fact_2531_or__one__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),A3),one_one(C)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa($o,C,zero_neq_one_of_bool(C),dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))) ) ).

% or_one_eq
tff(fact_2532_one__or__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),one_one(C)),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa($o,C,zero_neq_one_of_bool(C),dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3))) ) ).

% one_or_eq
tff(fact_2533_gbinomial__pochhammer_H,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,A3),K) = divide_divide(C,comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),minus_minus(C,A3,aa(nat,C,semiring_1_of_nat(C),K))),one_one(C)),K),semiring_char_0_fact(C,K)) ) ).

% gbinomial_pochhammer'
tff(fact_2534_gbinomial__pochhammer,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(nat,C,gbinomial(C,A3),K) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),K)),comm_s3205402744901411588hammer(C,aa(C,C,uminus_uminus(C),A3),K)),semiring_char_0_fact(C,K)) ) ).

% gbinomial_pochhammer
tff(fact_2535_mask__numeral,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: num] : bit_se2239418461657761734s_mask(C,aa(num,nat,numeral_numeral(nat),N)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_se2239418461657761734s_mask(C,pred_numeral(N)))) ) ).

% mask_numeral
tff(fact_2536_mask__Suc__double,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat] : bit_se2239418461657761734s_mask(C,aa(nat,nat,suc,N)) = aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),one_one(C)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),bit_se2239418461657761734s_mask(C,N))) ) ).

% mask_Suc_double
tff(fact_2537_mask__eq__exp__minus__1,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat] : bit_se2239418461657761734s_mask(C,N) = minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N),one_one(C)) ) ).

% mask_eq_exp_minus_1
tff(fact_2538_bit__sum__mult__2__cases,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C,B2: C,N: nat] :
          ( ! [J3: nat] : ~ bit_se5641148757651400278ts_bit(C,A3,aa(nat,nat,suc,J3))
         => ( bit_se5641148757651400278ts_bit(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2)),N)
          <=> $ite(N = zero_zero(nat),~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3),bit_se5641148757651400278ts_bit(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),B2),N)) ) ) ) ).

% bit_sum_mult_2_cases
tff(fact_2539_diff__numeral__special_I8_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : minus_minus(C,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2)),aa(C,C,uminus_uminus(C),one_one(C))) = neg_numeral_sub(C,one2,M2) ) ).

% diff_numeral_special(8)
tff(fact_2540_diff__numeral__special_I7_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : minus_minus(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N))) = neg_numeral_sub(C,N,one2) ) ).

% diff_numeral_special(7)
tff(fact_2541_mask__Suc__0,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ( bit_se2239418461657761734s_mask(C,aa(nat,nat,suc,zero_zero(nat))) = one_one(C) ) ) ).

% mask_Suc_0
tff(fact_2542_take__bit__minus__one__eq__mask,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat] : bit_se2584673776208193580ke_bit(C,N,aa(C,C,uminus_uminus(C),one_one(C))) = bit_se2239418461657761734s_mask(C,N) ) ).

% take_bit_minus_one_eq_mask
tff(fact_2543_diff__numeral__special_I1_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : minus_minus(C,one_one(C),aa(num,C,numeral_numeral(C),N)) = neg_numeral_sub(C,one2,N) ) ).

% diff_numeral_special(1)
tff(fact_2544_diff__numeral__special_I2_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : minus_minus(C,aa(num,C,numeral_numeral(C),M2),one_one(C)) = neg_numeral_sub(C,M2,one2) ) ).

% diff_numeral_special(2)
tff(fact_2545_add__neg__numeral__special_I1_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))) = neg_numeral_sub(C,one2,M2) ) ).

% add_neg_numeral_special(1)
tff(fact_2546_add__neg__numeral__special_I2_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),one_one(C)) = neg_numeral_sub(C,one2,M2) ) ).

% add_neg_numeral_special(2)
tff(fact_2547_add__neg__numeral__special_I3_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),M2)),aa(C,C,uminus_uminus(C),one_one(C))) = neg_numeral_sub(C,M2,one2) ) ).

% add_neg_numeral_special(3)
tff(fact_2548_add__neg__numeral__special_I4_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(num,C,numeral_numeral(C),N)) = neg_numeral_sub(C,N,one2) ) ).

% add_neg_numeral_special(4)
tff(fact_2549_minus__sub__one__diff__one,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [M2: num] : minus_minus(C,aa(C,C,uminus_uminus(C),neg_numeral_sub(C,M2,one2)),one_one(C)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2)) ) ).

% minus_sub_one_diff_one
tff(fact_2550_bit__1__iff,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [N: nat] :
          ( bit_se5641148757651400278ts_bit(C,one_one(C),N)
        <=> ( N = zero_zero(nat) ) ) ) ).

% bit_1_iff
tff(fact_2551_not__bit__1__Suc,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat] : ~ bit_se5641148757651400278ts_bit(C,one_one(C),aa(nat,nat,suc,N)) ) ).

% not_bit_1_Suc
tff(fact_2552_bit__numeral__simps_I1_J,axiom,
    ! [C: $tType] :
      ( bit_un5681908812861735899ations(C)
     => ! [N: num] : ~ bit_se5641148757651400278ts_bit(C,one_one(C),aa(num,nat,numeral_numeral(nat),N)) ) ).

% bit_numeral_simps(1)
tff(fact_2553_bit__iff__and__push__bit__not__eq__0,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C,N: nat] :
          ( bit_se5641148757651400278ts_bit(C,A3,N)
        <=> ( aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),bit_se4730199178511100633sh_bit(C,N,one_one(C))) != zero_zero(C) ) ) ) ).

% bit_iff_and_push_bit_not_eq_0
tff(fact_2554_even__bit__succ__iff,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C,N: nat] :
          ( dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( bit_se5641148757651400278ts_bit(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),A3),N)
          <=> ( bit_se5641148757651400278ts_bit(C,A3,N)
              | ( N = zero_zero(nat) ) ) ) ) ) ).

% even_bit_succ_iff
tff(fact_2555_odd__bit__iff__bit__pred,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C,N: nat] :
          ( ~ dvd_dvd(C,aa(num,C,numeral_numeral(C),bit0(one2)),A3)
         => ( bit_se5641148757651400278ts_bit(C,A3,N)
          <=> ( bit_se5641148757651400278ts_bit(C,minus_minus(C,A3,one_one(C)),N)
              | ( N = zero_zero(nat) ) ) ) ) ) ).

% odd_bit_iff_bit_pred
tff(fact_2556_signed__take__bit__def,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat,A3: C] : bit_ri4674362597316999326ke_bit(C,N,A3) = aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),bit_se2584673776208193580ke_bit(C,N,A3)),aa(C,C,aa(C,fun(C,C),times_times(C),aa($o,C,zero_neq_one_of_bool(C),bit_se5641148757651400278ts_bit(C,A3,N))),aa(C,C,bit_ri4277139882892585799ns_not(C),bit_se2239418461657761734s_mask(C,N)))) ) ).

% signed_take_bit_def
tff(fact_2557_sorted__list__of__set__atMost__Suc,axiom,
    ! [K: nat] : aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_ord_atMost(nat,aa(nat,nat,suc,K))) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_ord_atMost(nat,K))),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),aa(nat,nat,suc,K)),nil(nat))) ).

% sorted_list_of_set_atMost_Suc
tff(fact_2558_power__minus_H,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [X: C,N: nat] :
          ( nO_MATCH(C,C,one_one(C),X)
         => ( aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),X)),N) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)) ) ) ) ).

% power_minus'
tff(fact_2559_eq__numeral__iff__iszero_I8_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [Y: num] :
          ( ( one_one(C) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),Y)) )
        <=> ring_1_iszero(C,aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),Y))) ) ) ).

% eq_numeral_iff_iszero(8)
tff(fact_2560_eq__numeral__iff__iszero_I7_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [X: num] :
          ( ( aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),X)) = one_one(C) )
        <=> ring_1_iszero(C,aa(num,C,numeral_numeral(C),aa(num,num,aa(num,fun(num,num),plus_plus(num),X),one2))) ) ) ).

% eq_numeral_iff_iszero(7)
tff(fact_2561_division__decomp,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
         => ? [B10: C,C7: C] :
              ( ( A3 = aa(C,C,aa(C,fun(C,C),times_times(C),B10),C7) )
              & dvd_dvd(C,B10,B2)
              & dvd_dvd(C,C7,C3) ) ) ) ).

% division_decomp
tff(fact_2562_Int__atMost,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atMost(C,A3)),set_ord_atMost(C,B2)) = set_ord_atMost(C,aa(C,C,aa(C,fun(C,C),ord_min(C),A3),B2)) ) ).

% Int_atMost
tff(fact_2563_bit_Ocompl__one,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ( aa(C,C,bit_ri4277139882892585799ns_not(C),aa(C,C,uminus_uminus(C),one_one(C))) = zero_zero(C) ) ) ).

% bit.compl_one
tff(fact_2564_bit_Ocompl__zero,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ( aa(C,C,bit_ri4277139882892585799ns_not(C),zero_zero(C)) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% bit.compl_zero
tff(fact_2565_bit_Odisj__cancel__right,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),X),aa(C,C,bit_ri4277139882892585799ns_not(C),X)) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% bit.disj_cancel_right
tff(fact_2566_bit_Odisj__cancel__left,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),aa(C,C,bit_ri4277139882892585799ns_not(C),X)),X) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% bit.disj_cancel_left
tff(fact_2567_bit_Oxor__cancel__right,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),X),aa(C,C,bit_ri4277139882892585799ns_not(C),X)) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% bit.xor_cancel_right
tff(fact_2568_bit_Oxor__cancel__left,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(C,C,bit_ri4277139882892585799ns_not(C),X)),X) = aa(C,C,uminus_uminus(C),one_one(C)) ) ).

% bit.xor_cancel_left
tff(fact_2569_bit_Oxor__one__right,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),X),aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,bit_ri4277139882892585799ns_not(C),X) ) ).

% bit.xor_one_right
tff(fact_2570_bit_Oxor__one__left,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),bit_se5824344971392196577ns_xor(C),aa(C,C,uminus_uminus(C),one_one(C))),X) = aa(C,C,bit_ri4277139882892585799ns_not(C),X) ) ).

% bit.xor_one_left
tff(fact_2571_push__bit__minus__one__eq__not__mask,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat] : bit_se4730199178511100633sh_bit(C,N,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,bit_ri4277139882892585799ns_not(C),bit_se2239418461657761734s_mask(C,N)) ) ).

% push_bit_minus_one_eq_not_mask
tff(fact_2572_not__one__eq,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ( aa(C,C,bit_ri4277139882892585799ns_not(C),one_one(C)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),bit0(one2))) ) ) ).

% not_one_eq
tff(fact_2573_not__empty__eq__Iic__eq__empty,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [H: C] : bot_bot(set(C)) != set_ord_atMost(C,H) ) ).

% not_empty_eq_Iic_eq_empty
tff(fact_2574_not__iszero__1,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ~ ring_1_iszero(C,one_one(C)) ) ).

% not_iszero_1
tff(fact_2575_not__iszero__neg__1,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ~ ring_1_iszero(C,aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% not_iszero_neg_1
tff(fact_2576_minus__eq__not__plus__1,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C] : aa(C,C,uminus_uminus(C),A3) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,bit_ri4277139882892585799ns_not(C),A3)),one_one(C)) ) ).

% minus_eq_not_plus_1
tff(fact_2577_not__eq__complement,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C] : aa(C,C,bit_ri4277139882892585799ns_not(C),A3) = minus_minus(C,aa(C,C,uminus_uminus(C),A3),one_one(C)) ) ).

% not_eq_complement
tff(fact_2578_minus__eq__not__minus__1,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C] : aa(C,C,uminus_uminus(C),A3) = aa(C,C,bit_ri4277139882892585799ns_not(C),minus_minus(C,A3,one_one(C))) ) ).

% minus_eq_not_minus_1
tff(fact_2579_ivl__disj__int__one_I3_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atMost(C,La)),set_or3652927894154168847AtMost(C,La,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(3)
tff(fact_2580_ivl__disj__int__one_I1_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atMost(C,La)),set_or5935395276787703475ssThan(C,La,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(1)
tff(fact_2581_unset__bit__eq__and__not,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat,A3: C] : bit_se2638667681897837118et_bit(C,N,A3) = aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),A3),aa(C,C,bit_ri4277139882892585799ns_not(C),bit_se4730199178511100633sh_bit(C,N,one_one(C)))) ) ).

% unset_bit_eq_and_not
tff(fact_2582_ivl__disj__un__singleton_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),set_ord_lessThan(C,U)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),U),bot_bot(set(C)))) = set_ord_atMost(C,U) ) ).

% ivl_disj_un_singleton(2)
tff(fact_2583_bit_Ocompl__unique,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),X),Y) = zero_zero(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),bit_se1065995026697491101ons_or(C),X),Y) = aa(C,C,uminus_uminus(C),one_one(C)) )
           => ( aa(C,C,bit_ri4277139882892585799ns_not(C),X) = Y ) ) ) ) ).

% bit.compl_unique
tff(fact_2584_distrib__left__NO__MATCH,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring(D)
     => ! [X: C,Y: C,A3: D,B2: D,C3: D] :
          ( nO_MATCH(C,D,divide_divide(C,X,Y),A3)
         => ( aa(D,D,aa(D,fun(D,D),times_times(D),A3),aa(D,D,aa(D,fun(D,D),plus_plus(D),B2),C3)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(D,D,aa(D,fun(D,D),times_times(D),A3),B2)),aa(D,D,aa(D,fun(D,D),times_times(D),A3),C3)) ) ) ) ).

% distrib_left_NO_MATCH
tff(fact_2585_distrib__right__NO__MATCH,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring(D)
     => ! [X: C,Y: C,C3: D,A3: D,B2: D] :
          ( nO_MATCH(C,D,divide_divide(C,X,Y),C3)
         => ( aa(D,D,aa(D,fun(D,D),times_times(D),aa(D,D,aa(D,fun(D,D),plus_plus(D),A3),B2)),C3) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(D,D,aa(D,fun(D,D),times_times(D),A3),C3)),aa(D,D,aa(D,fun(D,D),times_times(D),B2),C3)) ) ) ) ).

% distrib_right_NO_MATCH
tff(fact_2586_left__diff__distrib__NO__MATCH,axiom,
    ! [C: $tType,D: $tType] :
      ( ring(D)
     => ! [X: C,Y: C,C3: D,A3: D,B2: D] :
          ( nO_MATCH(C,D,divide_divide(C,X,Y),C3)
         => ( aa(D,D,aa(D,fun(D,D),times_times(D),minus_minus(D,A3,B2)),C3) = minus_minus(D,aa(D,D,aa(D,fun(D,D),times_times(D),A3),C3),aa(D,D,aa(D,fun(D,D),times_times(D),B2),C3)) ) ) ) ).

% left_diff_distrib_NO_MATCH
tff(fact_2587_right__diff__distrib__NO__MATCH,axiom,
    ! [C: $tType,D: $tType] :
      ( ring(D)
     => ! [X: C,Y: C,A3: D,B2: D,C3: D] :
          ( nO_MATCH(C,D,divide_divide(C,X,Y),A3)
         => ( aa(D,D,aa(D,fun(D,D),times_times(D),A3),minus_minus(D,B2,C3)) = minus_minus(D,aa(D,D,aa(D,fun(D,D),times_times(D),A3),B2),aa(D,D,aa(D,fun(D,D),times_times(D),A3),C3)) ) ) ) ).

% right_diff_distrib_NO_MATCH
tff(fact_2588_eq__numeral__iff__iszero_I6_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [Y: num] :
          ( ( one_one(C) = aa(num,C,numeral_numeral(C),Y) )
        <=> ring_1_iszero(C,neg_numeral_sub(C,one2,Y)) ) ) ).

% eq_numeral_iff_iszero(6)
tff(fact_2589_eq__numeral__iff__iszero_I5_J,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [X: num] :
          ( ( aa(num,C,numeral_numeral(C),X) = one_one(C) )
        <=> ring_1_iszero(C,neg_numeral_sub(C,X,one2)) ) ) ).

% eq_numeral_iff_iszero(5)
tff(fact_2590_dvd__productE,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [P3: C,A3: C,B2: C] :
          ( dvd_dvd(C,P3,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
         => ~ ! [X2: C,Y2: C] :
                ( ( P3 = aa(C,C,aa(C,fun(C,C),times_times(C),X2),Y2) )
               => ( dvd_dvd(C,X2,A3)
                 => ~ dvd_dvd(C,Y2,B2) ) ) ) ) ).

% dvd_productE
tff(fact_2591_div__add__self2__no__field,axiom,
    ! [C: $tType,D: $tType] :
      ( ( euclid4440199948858584721cancel(D)
        & field(C) )
     => ! [X: C,B2: D,A3: D] :
          ( nO_MATCH(C,D,X,B2)
         => ( ( B2 != zero_zero(D) )
           => ( divide_divide(D,aa(D,D,aa(D,fun(D,D),plus_plus(D),A3),B2),B2) = aa(D,D,aa(D,fun(D,D),plus_plus(D),divide_divide(D,A3,B2)),one_one(D)) ) ) ) ) ).

% div_add_self2_no_field
tff(fact_2592_div__add__self1__no__field,axiom,
    ! [C: $tType,D: $tType] :
      ( ( euclid4440199948858584721cancel(D)
        & field(C) )
     => ! [X: C,B2: D,A3: D] :
          ( nO_MATCH(C,D,X,B2)
         => ( ( B2 != zero_zero(D) )
           => ( divide_divide(D,aa(D,D,aa(D,fun(D,D),plus_plus(D),B2),A3),B2) = aa(D,D,aa(D,fun(D,D),plus_plus(D),divide_divide(D,A3,B2)),one_one(D)) ) ) ) ) ).

% div_add_self1_no_field
tff(fact_2593_bit_Oabstract__boolean__algebra__sym__diff__axioms,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => boolea3799213064322606851m_diff(C,bit_se5824344872417868541ns_and(C),bit_se1065995026697491101ons_or(C),bit_ri4277139882892585799ns_not(C),zero_zero(C),aa(C,C,uminus_uminus(C),one_one(C)),bit_se5824344971392196577ns_xor(C)) ) ).

% bit.abstract_boolean_algebra_sym_diff_axioms
tff(fact_2594_bit_Oabstract__boolean__algebra__axioms,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => boolea2506097494486148201lgebra(C,bit_se5824344872417868541ns_and(C),bit_se1065995026697491101ons_or(C),bit_ri4277139882892585799ns_not(C),zero_zero(C),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% bit.abstract_boolean_algebra_axioms
tff(fact_2595_product__nth,axiom,
    ! [C: $tType,D: $tType,N: nat,Xs: list(C),Ys: list(D)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(D),nat,size_size(list(D)),Ys)))
     => ( aa(nat,product_prod(C,D),nth(product_prod(C,D),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),Xs),Ys)),N) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(nat,C,nth(C,Xs),divide_divide(nat,N,aa(list(D),nat,size_size(list(D)),Ys)))),aa(nat,D,nth(D,Ys),modulo_modulo(nat,N,aa(list(D),nat,size_size(list(D)),Ys)))) ) ) ).

% product_nth
tff(fact_2596_rotate__drop__take,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),modulo_modulo(nat,N,aa(list(C),nat,size_size(list(C)),Xs))),Xs)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),modulo_modulo(nat,N,aa(list(C),nat,size_size(list(C)),Xs))),Xs)) ).

% rotate_drop_take
tff(fact_2597_rotate__is__Nil__conv,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs) = nil(C) )
    <=> ( Xs = nil(C) ) ) ).

% rotate_is_Nil_conv
tff(fact_2598_set__rotate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% set_rotate
tff(fact_2599_length__rotate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) ).

% length_rotate
tff(fact_2600_distinct__rotate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs))
    <=> aa(list(C),$o,distinct(C),Xs) ) ).

% distinct_rotate
tff(fact_2601_rotate__Suc,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),aa(nat,nat,suc,N)),Xs) = aa(list(C),list(C),rotate1(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs)) ).

% rotate_Suc
tff(fact_2602_rotate__length01,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Xs)),one_one(nat))
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs) = Xs ) ) ).

% rotate_length01
tff(fact_2603_rotate__id,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] :
      ( ( modulo_modulo(nat,N,aa(list(C),nat,size_size(list(C)),Xs)) = zero_zero(nat) )
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs) = Xs ) ) ).

% rotate_id
tff(fact_2604_map__tailrec__rev_Ocases,axiom,
    ! [C: $tType,D: $tType,X: product_prod(fun(C,D),product_prod(list(C),list(D)))] :
      ( ! [F5: fun(C,D),Bs2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,D),product_prod(list(C),list(D))),aa(fun(C,D),fun(product_prod(list(C),list(D)),product_prod(fun(C,D),product_prod(list(C),list(D)))),product_Pair(fun(C,D),product_prod(list(C),list(D))),F5),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),Bs2))
     => ~ ! [F5: fun(C,D),A5: C,As: list(C),Bs2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,D),product_prod(list(C),list(D))),aa(fun(C,D),fun(product_prod(list(C),list(D)),product_prod(fun(C,D),product_prod(list(C),list(D)))),product_Pair(fun(C,D),product_prod(list(C),list(D))),F5),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),Bs2)) ) ).

% map_tailrec_rev.cases
tff(fact_2605_zipf_Ocases,axiom,
    ! [E2: $tType,C: $tType,D: $tType,X: product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D)))] :
      ( ! [F5: fun(C,fun(D,E2))] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D))),aa(fun(C,fun(D,E2)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,E2)),product_prod(list(C),list(D))),F5),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)))
     => ( ! [F5: fun(C,fun(D,E2)),A5: C,As: list(C),B4: D,Bs2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D))),aa(fun(C,fun(D,E2)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,E2)),product_prod(list(C),list(D))),F5),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2)))
       => ( ! [A5: fun(C,fun(D,E2)),V2: C,Va2: list(C)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D))),aa(fun(C,fun(D,E2)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,E2)),product_prod(list(C),list(D))),A5),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(D)))
         => ~ ! [A5: fun(C,fun(D,E2)),V2: D,Va2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D))),aa(fun(C,fun(D,E2)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,E2)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,E2)),product_prod(list(C),list(D))),A5),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2))) ) ) ) ).

% zipf.cases
tff(fact_2606_list__assn_Ocases,axiom,
    ! [C: $tType,D: $tType,X: product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))] :
      ( ! [P: fun(C,fun(D,assn))] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),P),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)))
     => ( ! [P: fun(C,fun(D,assn)),A5: C,As: list(C),C2: D,Cs: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),P),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),C2),Cs)))
       => ( ! [Uu2: fun(C,fun(D,assn)),V2: C,Va2: list(C)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),Uu2),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(D)))
         => ~ ! [Uu2: fun(C,fun(D,assn)),V2: D,Va2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),Uu2),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2))) ) ) ) ).

% list_assn.cases
tff(fact_2607_mergesort__by__rel__merge_Ocases,axiom,
    ! [C: $tType,X: product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))] :
      ( ! [R4: fun(C,fun(C,$o)),X2: C,Xs2: list(C),Y2: C,Ys2: list(C)] : X != aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)))
     => ( ! [R4: fun(C,fun(C,$o)),Xs2: list(C)] : X != aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs2),nil(C)))
       => ~ ! [R4: fun(C,fun(C,$o)),V2: C,Va2: list(C)] : X != aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2))) ) ) ).

% mergesort_by_rel_merge.cases
tff(fact_2608_quicksort__by__rel_Ocases,axiom,
    ! [C: $tType,X: product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))] :
      ( ! [R4: fun(C,fun(C,$o)),Sl: list(C)] : X != aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Sl),nil(C)))
     => ~ ! [R4: fun(C,fun(C,$o)),Sl: list(C),X2: C,Xs2: list(C)] : X != aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Sl),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2))) ) ).

% quicksort_by_rel.cases
tff(fact_2609_list__all__zip_Ocases,axiom,
    ! [C: $tType,D: $tType,X: product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))] :
      ( ! [P: fun(C,fun(D,$o))] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),P),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)))
     => ( ! [P: fun(C,fun(D,$o)),A5: C,As: list(C),B4: D,Bs2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),P),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2)))
       => ( ! [P: fun(C,fun(D,$o)),V2: C,Va2: list(C)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),P),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(D)))
         => ~ ! [P: fun(C,fun(D,$o)),V2: D,Va2: list(D)] : X != aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),P),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2))) ) ) ) ).

% list_all_zip.cases
tff(fact_2610_bex2I,axiom,
    ! [C: $tType,D: $tType,A3: C,B2: D,S: set(product_prod(C,D)),Pa: fun(C,fun(D,$o))] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2),S)
     => ( ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2),S)
         => aa(D,$o,aa(C,fun(D,$o),Pa,A3),B2) )
       => ? [A5: C,B4: D] :
            ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A5),B4),S)
            & aa(D,$o,aa(C,fun(D,$o),Pa,A5),B4) ) ) ) ).

% bex2I
tff(fact_2611_pairself_Ocases,axiom,
    ! [D: $tType,C: $tType,X: product_prod(fun(C,D),product_prod(C,C))] :
      ~ ! [F5: fun(C,D),A5: C,B4: C] : X != aa(product_prod(C,C),product_prod(fun(C,D),product_prod(C,C)),aa(fun(C,D),fun(product_prod(C,C),product_prod(fun(C,D),product_prod(C,C))),product_Pair(fun(C,D),product_prod(C,C)),F5),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A5),B4)) ).

% pairself.cases
tff(fact_2612_abstract__boolean__algebra__sym__diff_Oconj__xor__distrib2,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),Y: C,Z2: C,X: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Xor,Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),Xor,aa(C,C,aa(C,fun(C,C),Conj,Y),X)),aa(C,C,aa(C,fun(C,C),Conj,Z2),X)) ) ) ).

% abstract_boolean_algebra_sym_diff.conj_xor_distrib2
tff(fact_2613_abstract__boolean__algebra__sym__diff_Oxor__cancel__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),aa(C,C,Compl,X)) = One ) ) ).

% abstract_boolean_algebra_sym_diff.xor_cancel_right
tff(fact_2614_abstract__boolean__algebra__sym__diff_Oconj__xor__distrib,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C,Y: C,Z2: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Conj,X),aa(C,C,aa(C,fun(C,C),Xor,Y),Z2)) = aa(C,C,aa(C,fun(C,C),Xor,aa(C,C,aa(C,fun(C,C),Conj,X),Y)),aa(C,C,aa(C,fun(C,C),Conj,X),Z2)) ) ) ).

% abstract_boolean_algebra_sym_diff.conj_xor_distrib
tff(fact_2615_abstract__boolean__algebra__sym__diff_Oxor__compl__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C,Y: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),aa(C,C,Compl,Y)) = aa(C,C,Compl,aa(C,C,aa(C,fun(C,C),Xor,X),Y)) ) ) ).

% abstract_boolean_algebra_sym_diff.xor_compl_right
tff(fact_2616_abstract__boolean__algebra__sym__diff_Oxor__cancel__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,aa(C,C,Compl,X)),X) = One ) ) ).

% abstract_boolean_algebra_sym_diff.xor_cancel_left
tff(fact_2617_abstract__boolean__algebra__sym__diff_Oxor__compl__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C,Y: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,aa(C,C,Compl,X)),Y) = aa(C,C,Compl,aa(C,C,aa(C,fun(C,C),Xor,X),Y)) ) ) ).

% abstract_boolean_algebra_sym_diff.xor_compl_left
tff(fact_2618_abstract__boolean__algebra__sym__diff_Oxor__one__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),One) = aa(C,C,Compl,X) ) ) ).

% abstract_boolean_algebra_sym_diff.xor_one_right
tff(fact_2619_abstract__boolean__algebra__sym__diff_Oxor__left__self,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C,Y: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),aa(C,C,aa(C,fun(C,C),Xor,X),Y)) = Y ) ) ).

% abstract_boolean_algebra_sym_diff.xor_left_self
tff(fact_2620_abstract__boolean__algebra__sym__diff_Oxor__one__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,One),X) = aa(C,C,Compl,X) ) ) ).

% abstract_boolean_algebra_sym_diff.xor_one_left
tff(fact_2621_abstract__boolean__algebra_Odisj__conj__distrib2,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Y: C,Z2: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Disj,Y),X)),aa(C,C,aa(C,fun(C,C),Disj,Z2),X)) ) ) ).

% abstract_boolean_algebra.disj_conj_distrib2
tff(fact_2622_abstract__boolean__algebra_Oconj__disj__distrib2,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Y: C,Z2: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Disj,Y),Z2)),X) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,Y),X)),aa(C,C,aa(C,fun(C,C),Conj,Z2),X)) ) ) ).

% abstract_boolean_algebra.conj_disj_distrib2
tff(fact_2623_abstract__boolean__algebra_Ocompl__eq__compl__iff,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C,Y: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( ( aa(C,C,Compl,X) = aa(C,C,Compl,Y) )
      <=> ( X = Y ) ) ) ).

% abstract_boolean_algebra.compl_eq_compl_iff
tff(fact_2624_abstract__boolean__algebra__sym__diff_Oxor__self,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),X) = Zero ) ) ).

% abstract_boolean_algebra_sym_diff.xor_self
tff(fact_2625_abstract__boolean__algebra__sym__diff_Oxor__def2,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C,Y: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),Y) = aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Disj,X),Y)),aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,Compl,X)),aa(C,C,Compl,Y))) ) ) ).

% abstract_boolean_algebra_sym_diff.xor_def2
tff(fact_2626_abstract__boolean__algebra_Odisj__conj__distrib,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C,Y: C,Z2: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,X),aa(C,C,aa(C,fun(C,C),Conj,Y),Z2)) = aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Disj,X),Y)),aa(C,C,aa(C,fun(C,C),Disj,X),Z2)) ) ) ).

% abstract_boolean_algebra.disj_conj_distrib
tff(fact_2627_abstract__boolean__algebra_Odisj__cancel__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,X),aa(C,C,Compl,X)) = One ) ) ).

% abstract_boolean_algebra.disj_cancel_right
tff(fact_2628_abstract__boolean__algebra_Oconj__disj__distrib,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C,Y: C,Z2: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,X),aa(C,C,aa(C,fun(C,C),Disj,Y),Z2)) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,X),Y)),aa(C,C,aa(C,fun(C,C),Conj,X),Z2)) ) ) ).

% abstract_boolean_algebra.conj_disj_distrib
tff(fact_2629_abstract__boolean__algebra_Oconj__cancel__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,X),aa(C,C,Compl,X)) = Zero ) ) ).

% abstract_boolean_algebra.conj_cancel_right
tff(fact_2630_abstract__boolean__algebra_Ocomplement__unique,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,A3: C,X: C,Y: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( ( aa(C,C,aa(C,fun(C,C),Conj,A3),X) = Zero )
       => ( ( aa(C,C,aa(C,fun(C,C),Disj,A3),X) = One )
         => ( ( aa(C,C,aa(C,fun(C,C),Conj,A3),Y) = Zero )
           => ( ( aa(C,C,aa(C,fun(C,C),Disj,A3),Y) = One )
             => ( X = Y ) ) ) ) ) ) ).

% abstract_boolean_algebra.complement_unique
tff(fact_2631_abstract__boolean__algebra__sym__diff_Oxor__def,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C)),X: C,Y: C] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => ( aa(C,C,aa(C,fun(C,C),Xor,X),Y) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,X),aa(C,C,Compl,Y))),aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,Compl,X)),Y)) ) ) ).

% abstract_boolean_algebra_sym_diff.xor_def
tff(fact_2632_abstract__boolean__algebra_Odisj__cancel__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,Compl,X)),X) = One ) ) ).

% abstract_boolean_algebra.disj_cancel_left
tff(fact_2633_abstract__boolean__algebra_Oconj__cancel__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,Compl,X)),X) = Zero ) ) ).

% abstract_boolean_algebra.conj_cancel_left
tff(fact_2634_abstract__boolean__algebra_Odisj__zero__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,X),Zero) = X ) ) ).

% abstract_boolean_algebra.disj_zero_right
tff(fact_2635_abstract__boolean__algebra_Oconj__zero__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,X),Zero) = Zero ) ) ).

% abstract_boolean_algebra.conj_zero_right
tff(fact_2636_abstract__boolean__algebra_Odisj__one__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,X),One) = One ) ) ).

% abstract_boolean_algebra.disj_one_right
tff(fact_2637_abstract__boolean__algebra_Ode__Morgan__disj,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C,Y: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,Compl,aa(C,C,aa(C,fun(C,C),Disj,X),Y)) = aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,Compl,X)),aa(C,C,Compl,Y)) ) ) ).

% abstract_boolean_algebra.de_Morgan_disj
tff(fact_2638_abstract__boolean__algebra_Ode__Morgan__conj,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C,Y: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,Compl,aa(C,C,aa(C,fun(C,C),Conj,X),Y)) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,Compl,X)),aa(C,C,Compl,Y)) ) ) ).

% abstract_boolean_algebra.de_Morgan_conj
tff(fact_2639_abstract__boolean__algebra_Oconj__zero__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,Zero),X) = Zero ) ) ).

% abstract_boolean_algebra.conj_zero_left
tff(fact_2640_abstract__boolean__algebra_Oconj__one__right,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Conj,X),One) = X ) ) ).

% abstract_boolean_algebra.conj_one_right
tff(fact_2641_abstract__boolean__algebra_Odisj__one__left,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,aa(C,fun(C,C),Disj,One),X) = One ) ) ).

% abstract_boolean_algebra.disj_one_left
tff(fact_2642_abstract__boolean__algebra_Odouble__compl,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,Compl,aa(C,C,Compl,X)) = X ) ) ).

% abstract_boolean_algebra.double_compl
tff(fact_2643_abstract__boolean__algebra_Ocompl__unique,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,X: C,Y: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( ( aa(C,C,aa(C,fun(C,C),Conj,X),Y) = Zero )
       => ( ( aa(C,C,aa(C,fun(C,C),Disj,X),Y) = One )
         => ( aa(C,C,Compl,X) = Y ) ) ) ) ).

% abstract_boolean_algebra.compl_unique
tff(fact_2644_abstract__boolean__algebra_Ocompl__zero,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,Compl,Zero) = One ) ) ).

% abstract_boolean_algebra.compl_zero
tff(fact_2645_abstract__boolean__algebra_Ocompl__one,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( aa(C,C,Compl,One) = Zero ) ) ).

% abstract_boolean_algebra.compl_one
tff(fact_2646_abstract__boolean__algebra__sym__diff_Oaxioms_I1_J,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C))] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One) ) ).

% abstract_boolean_algebra_sym_diff.axioms(1)
tff(fact_2647_partition__rev_Ocases,axiom,
    ! [C: $tType,X: product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C)))] :
      ( ! [P: fun(C,$o),Yes: list(C),No: list(C)] : X != aa(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),aa(fun(C,$o),fun(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C)))),product_Pair(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),P),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No)),nil(C)))
     => ~ ! [P: fun(C,$o),Yes: list(C),No: list(C),X2: C,Xs2: list(C)] : X != aa(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),aa(fun(C,$o),fun(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C)))),product_Pair(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),P),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2))) ) ).

% partition_rev.cases
tff(fact_2648_mergesort__by__rel__split_Ocases,axiom,
    ! [C: $tType,X: product_prod(product_prod(list(C),list(C)),list(C))] :
      ( ! [Xs12: list(C),Xs22: list(C)] : X != aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22)),nil(C))
     => ( ! [Xs12: list(C),Xs22: list(C),X2: C] : X != aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))
       => ~ ! [Xs12: list(C),Xs22: list(C),X1: C,X23: C,Xs2: list(C)] : X != aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs2))) ) ) ).

% mergesort_by_rel_split.cases
tff(fact_2649_rotate__rotate,axiom,
    ! [C: $tType,M2: nat,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),M2),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N)),Xs) ).

% rotate_rotate
tff(fact_2650_rotate__map,axiom,
    ! [C: $tType,D: $tType,N: nat,F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),rotate(D),N),Xs)) ).

% rotate_map
tff(fact_2651_rotate1__rotate__swap,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),rotate1(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),aa(list(C),list(C),rotate1(C),Xs)) ).

% rotate1_rotate_swap
tff(fact_2652_arg__min__list_Ocases,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [X: product_prod(fun(C,D),list(C))] :
          ( ! [F5: fun(C,D),X2: C] : X != aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),F5),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))
         => ( ! [F5: fun(C,D),X2: C,Y2: C,Zs3: list(C)] : X != aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),F5),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Zs3)))
           => ~ ! [A5: fun(C,D)] : X != aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),A5),nil(C)) ) ) ) ).

% arg_min_list.cases
tff(fact_2653_sorted__wrt_Ocases,axiom,
    ! [C: $tType,X: product_prod(fun(C,fun(C,$o)),list(C))] :
      ( ! [P: fun(C,fun(C,$o))] : X != aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),P),nil(C))
     => ~ ! [P: fun(C,fun(C,$o)),X2: C,Ys2: list(C)] : X != aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),P),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2)) ) ).

% sorted_wrt.cases
tff(fact_2654_successively_Ocases,axiom,
    ! [C: $tType,X: product_prod(fun(C,fun(C,$o)),list(C))] :
      ( ! [P: fun(C,fun(C,$o))] : X != aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),P),nil(C))
     => ( ! [P: fun(C,fun(C,$o)),X2: C] : X != aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),P),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))
       => ~ ! [P: fun(C,fun(C,$o)),X2: C,Y2: C,Xs2: list(C)] : X != aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),P),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2))) ) ) ).

% successively.cases
tff(fact_2655_shuffles_Ocases,axiom,
    ! [C: $tType,X: product_prod(list(C),list(C))] :
      ( ! [Ys2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys2)
     => ( ! [Xs2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs2),nil(C))
       => ~ ! [X2: C,Xs2: list(C),Y2: C,Ys2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)) ) ) ).

% shuffles.cases
tff(fact_2656_merge_Ocases,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: product_prod(list(C),list(C))] :
          ( ! [L2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),L2)
         => ( ! [V2: C,Va2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(C))
           => ~ ! [X1: C,L1: list(C),X23: C,L2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),L1)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),L2)) ) ) ) ).

% merge.cases
tff(fact_2657_merge__list_Ocases,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: product_prod(list(list(C)),list(list(C)))] :
          ( ( X != aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),nil(list(C))) )
         => ( ! [L: list(C)] : X != aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))))
           => ( ! [La2: list(C),Acc2: list(list(C))] : X != aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),nil(list(C)))
             => ( ! [La2: list(C),Acc2: list(list(C)),L: list(C)] : X != aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))))
               => ~ ! [Acc2: list(list(C)),L1: list(C),L2: list(C),Ls2: list(list(C))] : X != aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),Acc2),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L2),Ls2))) ) ) ) ) ) ).

% merge_list.cases
tff(fact_2658_product_Osimps_I2_J,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(C),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(fun(D,product_prod(C,D)),fun(list(D),list(product_prod(C,D))),map(D,product_prod(C,D)),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X)),Ys)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),Xs),Ys)) ).

% product.simps(2)
tff(fact_2659_rotate__append,axiom,
    ! [C: $tType,La: list(C),Q2: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),aa(list(C),nat,size_size(list(C)),La)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),La),Q2)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Q2),La) ).

% rotate_append
tff(fact_2660_rotate__conv__mod,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),modulo_modulo(nat,N,aa(list(C),nat,size_size(list(C)),Xs))),Xs) ).

% rotate_conv_mod
tff(fact_2661_rotate__rev,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),modulo_modulo(nat,N,aa(list(C),nat,size_size(list(C)),Xs)))),Xs)) ).

% rotate_rev
tff(fact_2662_nth__rotate,axiom,
    ! [C: $tType,N: nat,Xs: list(C),M2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),M2),Xs)),N) = aa(nat,C,nth(C,Xs),modulo_modulo(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N),aa(list(C),nat,size_size(list(C)),Xs))) ) ) ).

% nth_rotate
tff(fact_2663_hd__rotate__conv__nth,axiom,
    ! [C: $tType,Xs: list(C),N: nat] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),C,hd(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),N),Xs)) = aa(nat,C,nth(C,Xs),modulo_modulo(nat,N,aa(list(C),nat,size_size(list(C)),Xs))) ) ) ).

% hd_rotate_conv_nth
tff(fact_2664_divmod__step__eq,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [La: num,Q2: C,R3: C] :
          unique1321980374590559556d_step(C,La,aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),R3)) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(num,C,numeral_numeral(C),La)),R3),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Q2)),one_one(C))),minus_minus(C,R3,aa(num,C,numeral_numeral(C),La))),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Q2)),R3)) ) ).

% divmod_step_eq
tff(fact_2665_lexord__take__index__conv,axiom,
    ! [C: $tType,X: list(C),Y: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lexord(C,R3))
    <=> ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),X)),aa(list(C),nat,size_size(list(C)),Y))
          & ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(list(C),nat,size_size(list(C)),X)),Y) = X ) )
        | ? [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(C),nat,size_size(list(C)),X)),aa(list(C),nat,size_size(list(C)),Y)))
            & ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I2),X) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I2),Y) )
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(nat,C,nth(C,X),I2)),aa(nat,C,nth(C,Y),I2)),R3) ) ) ) ).

% lexord_take_index_conv
tff(fact_2666_lex__take__index,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lex(C,R3))
     => ~ ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Xs))
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Ys))
             => ( ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I3),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I3),Ys) )
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(nat,C,nth(C,Xs),I3)),aa(nat,C,nth(C,Ys),I3)),R3) ) ) ) ) ).

% lex_take_index
tff(fact_2667_subset__eq__mset__impl_Ocases,axiom,
    ! [C: $tType,X: product_prod(list(C),list(C))] :
      ( ! [Ys2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys2)
     => ~ ! [X2: C,Xs2: list(C),Ys2: list(C)] : X != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2) ) ).

% subset_eq_mset_impl.cases
tff(fact_2668_diff__numeral__special_I5_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : minus_minus(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(num,C,numeral_numeral(C),N)) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),inc(N))) ) ).

% diff_numeral_special(5)
tff(fact_2669_diff__numeral__special_I6_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : minus_minus(C,aa(num,C,numeral_numeral(C),M2),aa(C,C,uminus_uminus(C),one_one(C))) = aa(num,C,numeral_numeral(C),inc(M2)) ) ).

% diff_numeral_special(6)
tff(fact_2670_lexord__cons__cons,axiom,
    ! [C: $tType,A3: C,X: list(C),B2: C,Y: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),X)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B2),Y)),lexord(C,R3))
    <=> ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3)
        | ( ( A3 = B2 )
          & member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lexord(C,R3)) ) ) ) ).

% lexord_cons_cons
tff(fact_2671_lexord__Nil__left,axiom,
    ! [C: $tType,Y: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Y),lexord(C,R3))
    <=> ? [A6: C,X4: list(C)] : Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A6),X4) ) ).

% lexord_Nil_left
tff(fact_2672_add__neg__numeral__special_I6_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [M2: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),M2))),aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),inc(M2))) ) ).

% add_neg_numeral_special(6)
tff(fact_2673_add__neg__numeral__special_I5_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),one_one(C))),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),N))) = aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),inc(N))) ) ).

% add_neg_numeral_special(5)
tff(fact_2674_Cons__in__lex,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C,Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),lex(C,R3))
    <=> ( ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3)
          & ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) ) )
        | ( ( X = Y )
          & member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lex(C,R3)) ) ) ) ).

% Cons_in_lex
tff(fact_2675_lexord__lex,axiom,
    ! [C: $tType,X: list(C),Y: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lex(C,R3))
    <=> ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lexord(C,R3))
        & ( aa(list(C),nat,size_size(list(C)),X) = aa(list(C),nat,size_size(list(C)),Y) ) ) ) ).

% lexord_lex
tff(fact_2676_mergesort__by__rel_Ocases,axiom,
    ! [C: $tType,X: product_prod(fun(C,fun(C,$o)),list(C))] :
      ~ ! [R4: fun(C,fun(C,$o)),Xs2: list(C)] : X != aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),R4),Xs2) ).

% mergesort_by_rel.cases
tff(fact_2677_lexord__linear,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),X: list(C),Y: list(C)] :
      ( ! [A5: C,B4: C] :
          ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A5),B4),R3)
          | ( A5 = B4 )
          | member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B4),A5),R3) )
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lexord(C,R3))
        | ( X = Y )
        | member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Y),X),lexord(C,R3)) ) ) ).

% lexord_linear
tff(fact_2678_lexord__irreflexive,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),Xs: list(C)] :
      ( ! [X2: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),X2),R3)
     => ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Xs),lexord(C,R3)) ) ).

% lexord_irreflexive
tff(fact_2679_lexord__Nil__right,axiom,
    ! [C: $tType,X: list(C),R3: set(product_prod(C,C))] : ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),nil(C)),lexord(C,R3)) ).

% lexord_Nil_right
tff(fact_2680_lexord__append__leftI,axiom,
    ! [C: $tType,U: list(C),V: list(C),R3: set(product_prod(C,C)),X: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),U),V),lexord(C,R3))
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),X),U)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),X),V)),lexord(C,R3)) ) ).

% lexord_append_leftI
tff(fact_2681_Nil2__notin__lex,axiom,
    ! [C: $tType,Xs: list(C),R3: set(product_prod(C,C))] : ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),nil(C)),lex(C,R3)) ).

% Nil2_notin_lex
tff(fact_2682_Nil__notin__lex,axiom,
    ! [C: $tType,Ys: list(C),R3: set(product_prod(C,C))] : ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys),lex(C,R3)) ).

% Nil_notin_lex
tff(fact_2683_lex__append__leftI,axiom,
    ! [C: $tType,Ys: list(C),Zs: list(C),R3: set(product_prod(C,C)),Xs: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),lex(C,R3))
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs)),lex(C,R3)) ) ).

% lex_append_leftI
tff(fact_2684_lexord__partial__trans,axiom,
    ! [C: $tType,Xs: list(C),R3: set(product_prod(C,C)),Ys: list(C),Zs: list(C)] :
      ( ! [X2: C,Y2: C,Z4: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),Y2),R3)
           => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y2),Z4),R3)
             => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),Z4),R3) ) ) )
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lexord(C,R3))
       => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),lexord(C,R3))
         => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Zs),lexord(C,R3)) ) ) ) ).

% lexord_partial_trans
tff(fact_2685_lexord__append__leftD,axiom,
    ! [C: $tType,X: list(C),U: list(C),V: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),X),U)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),X),V)),lexord(C,R3))
     => ( ! [A5: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A5),A5),R3)
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),U),V),lexord(C,R3)) ) ) ).

% lexord_append_leftD
tff(fact_2686_lexord__append__rightI,axiom,
    ! [C: $tType,Y: list(C),X: list(C),R3: set(product_prod(C,C))] :
      ( ? [B11: C,Z5: list(C)] : Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B11),Z5)
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),X),Y)),lexord(C,R3)) ) ).

% lexord_append_rightI
tff(fact_2687_lexord__sufE,axiom,
    ! [C: $tType,Xs: list(C),Zs: list(C),Ys: list(C),Qs: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Qs)),lexord(C,R3))
     => ( ( Xs != Ys )
       => ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) )
         => ( ( aa(list(C),nat,size_size(list(C)),Zs) = aa(list(C),nat,size_size(list(C)),Qs) )
           => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lexord(C,R3)) ) ) ) ) ).

% lexord_sufE
tff(fact_2688_lex__append__left__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ! [X2: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),X2),R3)
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs)),lex(C,R3))
      <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),lex(C,R3)) ) ) ).

% lex_append_left_iff
tff(fact_2689_lex__append__leftD,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ! [X2: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),X2),R3)
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs)),lex(C,R3))
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),lex(C,R3)) ) ) ).

% lex_append_leftD
tff(fact_2690_lex__append__rightI,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C)),Vs: list(C),Us2: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lex(C,R3))
     => ( ( aa(list(C),nat,size_size(list(C)),Vs) = aa(list(C),nat,size_size(list(C)),Us2) )
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Vs)),lex(C,R3)) ) ) ).

% lex_append_rightI
tff(fact_2691_lexord__append__left__rightI,axiom,
    ! [C: $tType,A3: C,B2: C,R3: set(product_prod(C,C)),U: list(C),X: list(C),Y: list(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3)
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),X))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B2),Y))),lexord(C,R3)) ) ).

% lexord_append_left_rightI
tff(fact_2692_lexord__same__pref__iff,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs)),lexord(C,R3))
    <=> ( ? [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),X4),R3) )
        | member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),lexord(C,R3)) ) ) ).

% lexord_same_pref_iff
tff(fact_2693_lexord__sufI,axiom,
    ! [C: $tType,U: list(C),W: list(C),R3: set(product_prod(C,C)),V: list(C),Z2: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),U),W),lexord(C,R3))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),W)),aa(list(C),nat,size_size(list(C)),U))
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U),V)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),W),Z2)),lexord(C,R3)) ) ) ).

% lexord_sufI
tff(fact_2694_numeral__inc,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ! [X: num] : aa(num,C,numeral_numeral(C),inc(X)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),X)),one_one(C)) ) ).

% numeral_inc
tff(fact_2695_Cons__lenlex__iff,axiom,
    ! [C: $tType,M2: C,Ms: list(C),N: C,Ns: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),M2),Ms)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),N),Ns)),lenlex(C,R3))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Ms)),aa(list(C),nat,size_size(list(C)),Ns))
        | ( ( aa(list(C),nat,size_size(list(C)),Ms) = aa(list(C),nat,size_size(list(C)),Ns) )
          & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),M2),N),R3) )
        | ( ( M2 = N )
          & member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ms),Ns),lenlex(C,R3)) ) ) ) ).

% Cons_lenlex_iff
tff(fact_2696_listrel1__iff__update,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
    <=> ? [Y3: C,N3: nat] :
          ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(nat,C,nth(C,Xs),N3)),Y3),R3)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(C),nat,size_size(list(C)),Xs))
          & ( Ys = aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),N3),Y3) ) ) ) ).

% listrel1_iff_update
tff(fact_2697_nth__step__trancl,axiom,
    ! [C: $tType,Xs: list(C),R: set(product_prod(C,C)),N: nat,M2: nat] :
      ( ! [N7: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N7),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),one_one(nat)))
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(nat,C,nth(C,Xs),aa(nat,nat,suc,N7))),aa(nat,C,nth(C,Xs),N7)),R) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M2),N)
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(nat,C,nth(C,Xs),N)),aa(nat,C,nth(C,Xs),M2)),transitive_trancl(C,R)) ) ) ) ).

% nth_step_trancl
tff(fact_2698_nth__zip,axiom,
    ! [C: $tType,D: $tType,I: nat,Xs: list(C),Ys: list(D)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(D),nat,size_size(list(D)),Ys))
       => ( aa(nat,product_prod(C,D),nth(product_prod(C,D),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)),I) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(nat,C,nth(C,Xs),I)),aa(nat,D,nth(D,Ys),I)) ) ) ) ).

% nth_zip
tff(fact_2699_list__assn_Opelims,axiom,
    ! [C: $tType,D: $tType,X: fun(C,fun(D,assn)),Xa: list(C),Xb: list(D),Y: assn] :
      ( ( vEBT_List_list_assn(C,D,X,Xa,Xb) = Y )
     => ( accp(product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),vEBT_L4249061453398456502sn_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xa),Xb)))
       => ( ( ( Xa = nil(C) )
           => ( ( Xb = nil(D) )
             => ( ( Y = one_one(assn) )
               => ~ accp(product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),vEBT_L4249061453398456502sn_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)))) ) ) )
         => ( ! [A5: C,As: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
               => ! [C2: D,Cs: list(D)] :
                    ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),C2),Cs) )
                   => ( ( Y = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),X,A5),C2)),vEBT_List_list_assn(C,D,X,As,Cs)) )
                     => ~ accp(product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),vEBT_L4249061453398456502sn_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),C2),Cs)))) ) ) )
           => ( ! [V2: C,Va2: list(C)] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                 => ( ( Xb = nil(D) )
                   => ( ( Y = bot_bot(assn) )
                     => ~ accp(product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),vEBT_L4249061453398456502sn_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(D)))) ) ) )
             => ~ ( ( Xa = nil(C) )
                 => ! [V2: D,Va2: list(D)] :
                      ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2) )
                     => ( ( Y = bot_bot(assn) )
                       => ~ accp(product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),vEBT_L4249061453398456502sn_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D))),aa(fun(C,fun(D,assn)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,assn)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,assn)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)))) ) ) ) ) ) ) ) ) ).

% list_assn.pelims
tff(fact_2700_Gcd__0__iff,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] :
          ( ( gcd_Gcd(C,A4) = zero_zero(C) )
        <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),zero_zero(C)),bot_bot(set(C)))) ) ) ).

% Gcd_0_iff
tff(fact_2701_trancl__single,axiom,
    ! [C: $tType,A3: C,B2: C] : transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2)),bot_bot(set(product_prod(C,C))))) = aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2)),bot_bot(set(product_prod(C,C)))) ).

% trancl_single
tff(fact_2702_zip__eq__zip__same__len,axiom,
    ! [C: $tType,D: $tType,A3: list(C),B2: list(D),A10: list(C),B8: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),A3) = aa(list(D),nat,size_size(list(D)),B2) )
     => ( ( aa(list(C),nat,size_size(list(C)),A10) = aa(list(D),nat,size_size(list(D)),B8) )
       => ( ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),A3),B2) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),A10),B8) )
        <=> ( ( A3 = A10 )
            & ( B2 = B8 ) ) ) ) ) ).

% zip_eq_zip_same_len
tff(fact_2703_zip__Cons__Cons,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(C),Y: D,Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys)) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) ).

% zip_Cons_Cons
tff(fact_2704_Gcd__empty,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ( gcd_Gcd(C,bot_bot(set(C))) = zero_zero(C) ) ) ).

% Gcd_empty
tff(fact_2705_Nil__lenlex__iff1,axiom,
    ! [C: $tType,Ns: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ns),lenlex(C,R3))
    <=> ( Ns != nil(C) ) ) ).

% Nil_lenlex_iff1
tff(fact_2706_zip__eq__Nil__iff,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys) = nil(product_prod(C,D)) )
    <=> ( ( Xs = nil(C) )
        | ( Ys = nil(D) ) ) ) ).

% zip_eq_Nil_iff
tff(fact_2707_Nil__eq__zip__iff,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( ( nil(product_prod(C,D)) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys) )
    <=> ( ( Xs = nil(C) )
        | ( Ys = nil(D) ) ) ) ).

% Nil_eq_zip_iff
tff(fact_2708_zip__Nil,axiom,
    ! [D: $tType,C: $tType,Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),nil(C)),Ys) = nil(product_prod(C,D)) ).

% zip_Nil
tff(fact_2709_Cons__listrel1__Cons,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C,Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),listrel1(C,R3))
    <=> ( ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3)
          & ( Xs = Ys ) )
        | ( ( X = Y )
          & member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3)) ) ) ) ).

% Cons_listrel1_Cons
tff(fact_2710_zip__append,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Us2: list(D),Ys: list(C),Vs: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Us2) )
     => ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Us2),Vs)) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Us2)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Ys),Vs)) ) ) ).

% zip_append
tff(fact_2711_length__zip,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),nat,size_size(list(product_prod(C,D))),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(D),nat,size_size(list(D)),Ys)) ).

% length_zip
tff(fact_2712_listrel1__mono,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),S4: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R3),S4)
     => aa(set(product_prod(list(C),list(C))),$o,aa(set(product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),$o),ord_less_eq(set(product_prod(list(C),list(C)))),listrel1(C,R3)),listrel1(C,S4)) ) ).

% listrel1_mono
tff(fact_2713_trancl__sub,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),transitive_trancl(C,R)) ).

% trancl_sub
tff(fact_2714_trancl__mono__mp,axiom,
    ! [C: $tType,U2: set(product_prod(C,C)),V3: set(product_prod(C,C)),X: product_prod(C,C)] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),U2),V3)
     => ( member2(product_prod(C,C),X,transitive_trancl(C,U2))
       => member2(product_prod(C,C),X,transitive_trancl(C,V3)) ) ) ).

% trancl_mono_mp
tff(fact_2715_trancl__sub__insert__trancl,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),X: product_prod(C,C)] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),transitive_trancl(C,R)),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),X),R))) ).

% trancl_sub_insert_trancl
tff(fact_2716_zip__inj,axiom,
    ! [C: $tType,D: $tType,A3: list(C),B2: list(D),A10: list(C),B8: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),A3) = aa(list(D),nat,size_size(list(D)),B2) )
     => ( ( aa(list(C),nat,size_size(list(C)),A10) = aa(list(D),nat,size_size(list(D)),B8) )
       => ( ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),A3),B2) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),A10),B8) )
         => ( ( A3 = A10 )
            & ( B2 = B8 ) ) ) ) ) ).

% zip_inj
tff(fact_2717_take__zip,axiom,
    ! [C: $tType,D: $tType,N: nat,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(nat,fun(list(product_prod(C,D)),list(product_prod(C,D))),take(product_prod(C,D)),N),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),N),Ys)) ).

% take_zip
tff(fact_2718_drop__zip,axiom,
    ! [C: $tType,D: $tType,N: nat,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(nat,fun(list(product_prod(C,D)),list(product_prod(C,D))),drop(product_prod(C,D)),N),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),drop(D),N),Ys)) ).

% drop_zip
tff(fact_2719_Gcd__1,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] :
          ( member2(C,one_one(C),A4)
         => ( gcd_Gcd(C,A4) = one_one(C) ) ) ) ).

% Gcd_1
tff(fact_2720_zip__eq__ConsE,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Xy: product_prod(C,D),Xys: list(product_prod(C,D))] :
      ( ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),Xy),Xys) )
     => ~ ! [X2: C,Xs4: list(C)] :
            ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs4) )
           => ! [Y2: D,Ys4: list(D)] :
                ( ( Ys = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys4) )
               => ( ( Xy = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X2),Y2) )
                 => ( Xys != aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs4),Ys4) ) ) ) ) ) ).

% zip_eq_ConsE
tff(fact_2721_zip__same,axiom,
    ! [C: $tType,A3: C,B2: C,Xs: list(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),aa(list(C),list(product_prod(C,C)),aa(list(C),fun(list(C),list(product_prod(C,C))),zip(C,C),Xs),Xs)))
    <=> ( member2(C,A3,aa(list(C),set(C),set2(C),Xs))
        & ( A3 = B2 ) ) ) ).

% zip_same
tff(fact_2722_in__set__zipE,axiom,
    ! [C: $tType,D: $tType,X: C,Y: D,Xs: list(C),Ys: list(D)] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)))
     => ~ ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
         => ~ member2(D,Y,aa(list(D),set(D),set2(D),Ys)) ) ) ).

% in_set_zipE
tff(fact_2723_set__zip__leftD,axiom,
    ! [D: $tType,C: $tType,X: C,Y: D,Xs: list(C),Ys: list(D)] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% set_zip_leftD
tff(fact_2724_set__zip__rightD,axiom,
    ! [C: $tType,D: $tType,X: C,Y: D,Xs: list(C),Ys: list(D)] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)))
     => member2(D,Y,aa(list(D),set(D),set2(D),Ys)) ) ).

% set_zip_rightD
tff(fact_2725_zip__update,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),I: nat,X: C,Ys: list(D),Y: D] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),aa(D,list(D),aa(nat,fun(D,list(D)),aa(list(D),fun(nat,fun(D,list(D))),list_update(D),Ys),I),Y)) = aa(product_prod(C,D),list(product_prod(C,D)),aa(nat,fun(product_prod(C,D),list(product_prod(C,D))),aa(list(product_prod(C,D)),fun(nat,fun(product_prod(C,D),list(product_prod(C,D)))),list_update(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)),I),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)) ).

% zip_update
tff(fact_2726_zip__rev,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),rev(C),Xs)),aa(list(D),list(D),rev(D),Ys)) = aa(list(product_prod(C,D)),list(product_prod(C,D)),rev(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) ) ) ).

% zip_rev
tff(fact_2727_zip_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType,Xs: list(C)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),nil(D)) = nil(product_prod(C,D)) ).

% zip.simps(1)
tff(fact_2728_listrel1I2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C)),X: C] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys)),listrel1(C,R3)) ) ).

% listrel1I2
tff(fact_2729_not__Nil__listrel1,axiom,
    ! [C: $tType,Xs: list(C),R3: set(product_prod(C,C))] : ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Xs),listrel1(C,R3)) ).

% not_Nil_listrel1
tff(fact_2730_not__listrel1__Nil,axiom,
    ! [C: $tType,Xs: list(C),R3: set(product_prod(C,C))] : ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),nil(C)),listrel1(C,R3)) ).

% not_listrel1_Nil
tff(fact_2731_listrel1__eq__len,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
     => ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) ) ) ).

% listrel1_eq_len
tff(fact_2732_append__listrel1I,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C)),Us2: list(C),Vs: list(C)] :
      ( ( ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
          & ( Us2 = Vs ) )
        | ( ( Xs = Ys )
          & member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Us2),Vs),listrel1(C,R3)) ) )
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Vs)),listrel1(C,R3)) ) ).

% append_listrel1I
tff(fact_2733_pair__list__split,axiom,
    ! [C: $tType,D: $tType,La: list(product_prod(C,D))] :
      ~ ! [L1: list(C),L2: list(D)] :
          ( ( La = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),L1),L2) )
         => ( ( aa(list(C),nat,size_size(list(C)),L1) = aa(list(D),nat,size_size(list(D)),L2) )
           => ( aa(list(product_prod(C,D)),nat,size_size(list(product_prod(C,D))),La) != aa(list(D),nat,size_size(list(D)),L2) ) ) ) ).

% pair_list_split
tff(fact_2734_Gcd__eq__1__I,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A3: C,A4: set(C)] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( member2(C,A3,A4)
           => ( gcd_Gcd(C,A4) = one_one(C) ) ) ) ) ).

% Gcd_eq_1_I
tff(fact_2735_distinct__zipI2,axiom,
    ! [D: $tType,C: $tType,Ys: list(C),Xs: list(D)] :
      ( aa(list(C),$o,distinct(C),Ys)
     => aa(list(product_prod(D,C)),$o,distinct(product_prod(D,C)),aa(list(C),list(product_prod(D,C)),aa(list(D),fun(list(C),list(product_prod(D,C))),zip(D,C),Xs),Ys)) ) ).

% distinct_zipI2
tff(fact_2736_distinct__zipI1,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(product_prod(C,D)),$o,distinct(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) ) ).

% distinct_zipI1
tff(fact_2737_in__set__impl__in__set__zip2,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Y: D] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( member2(D,Y,aa(list(D),set(D),set2(D),Ys))
       => ~ ! [X2: C] : ~ member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X2),Y),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys))) ) ) ).

% in_set_impl_in_set_zip2
tff(fact_2738_in__set__impl__in__set__zip1,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),X: C] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => ~ ! [Y2: D] : ~ member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y2),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys))) ) ) ).

% in_set_impl_in_set_zip1
tff(fact_2739_hd__zip,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( ( Xs != nil(C) )
     => ( ( Ys != nil(D) )
       => ( aa(list(product_prod(C,D)),product_prod(C,D),hd(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(list(C),C,hd(C),Xs)),aa(list(D),D,hd(D),Ys)) ) ) ) ).

% hd_zip
tff(fact_2740_lenlex__irreflexive,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),Xs: list(C)] :
      ( ! [X2: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),X2),R3)
     => ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Xs),lenlex(C,R3)) ) ).

% lenlex_irreflexive
tff(fact_2741_zip__obtain__same__length,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Pa: fun(list(product_prod(C,D)),$o)] :
      ( ! [Zs3: list(C),Ws3: list(D),N7: nat] :
          ( ( aa(list(C),nat,size_size(list(C)),Zs3) = aa(list(D),nat,size_size(list(D)),Ws3) )
         => ( ( N7 = aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(D),nat,size_size(list(D)),Ys)) )
           => ( ( Zs3 = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N7),Xs) )
             => ( ( Ws3 = aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),N7),Ys) )
               => aa(list(product_prod(C,D)),$o,Pa,aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Zs3),Ws3)) ) ) ) )
     => aa(list(product_prod(C,D)),$o,Pa,aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) ) ).

% zip_obtain_same_length
tff(fact_2742_Nil__lenlex__iff2,axiom,
    ! [C: $tType,Ns: list(C),R3: set(product_prod(C,C))] : ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ns),nil(C)),lenlex(C,R3)) ).

% Nil_lenlex_iff2
tff(fact_2743_Cons__listrel1E2,axiom,
    ! [C: $tType,Xs: list(C),Y: C,Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),listrel1(C,R3))
     => ( ! [X2: C] :
            ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys) )
           => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),Y),R3) )
       => ~ ! [Zs3: list(C)] :
              ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs3) )
             => ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Zs3),Ys),listrel1(C,R3)) ) ) ) ).

% Cons_listrel1E2
tff(fact_2744_Cons__listrel1E1,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys),listrel1(C,R3))
     => ( ! [Y2: C] :
            ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs) )
           => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y2),R3) )
       => ~ ! [Zs3: list(C)] :
              ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Zs3) )
             => ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Zs3),listrel1(C,R3)) ) ) ) ).

% Cons_listrel1E1
tff(fact_2745_listrel1I1,axiom,
    ! [C: $tType,X: C,Y: C,R3: set(product_prod(C,C)),Xs: list(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3)
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)),listrel1(C,R3)) ) ).

% listrel1I1
tff(fact_2746_last__zip,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( ( Xs != nil(C) )
     => ( ( Ys != nil(D) )
       => ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
         => ( last(product_prod(C,D),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),last(C,Xs)),last(D,Ys)) ) ) ) ) ).

% last_zip
tff(fact_2747_listrel1I,axiom,
    ! [C: $tType,X: C,Y: C,R3: set(product_prod(C,C)),Xs: list(C),Us2: list(C),Vs: list(C),Ys: list(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3)
     => ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Vs)) )
       => ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Vs)) )
         => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3)) ) ) ) ).

% listrel1I
tff(fact_2748_listrel1E,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
     => ~ ! [X2: C,Y2: C] :
            ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),Y2),R3)
           => ! [Us3: list(C),Vs3: list(C)] :
                ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Vs3)) )
               => ( Ys != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Vs3)) ) ) ) ) ).

% listrel1E
tff(fact_2749_lenlex__length,axiom,
    ! [C: $tType,Ms: list(C),Ns: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ms),Ns),lenlex(C,R3))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Ms)),aa(list(C),nat,size_size(list(C)),Ns)) ) ).

% lenlex_length
tff(fact_2750_lenlex__append1,axiom,
    ! [C: $tType,Us2: list(C),Xs: list(C),R: set(product_prod(C,C)),Vs: list(C),Ys: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Us2),Xs),lenlex(C,R))
     => ( ( aa(list(C),nat,size_size(list(C)),Vs) = aa(list(C),nat,size_size(list(C)),Ys) )
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),Vs)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),lenlex(C,R)) ) ) ).

% lenlex_append1
tff(fact_2751_zip__append1,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(C),Zs: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),Zs) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),aa(list(C),nat,size_size(list(C)),Xs)),Zs))),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Ys),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),drop(D),aa(list(C),nat,size_size(list(C)),Xs)),Zs))) ).

% zip_append1
tff(fact_2752_zip__append2,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Zs: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys),Zs)) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(list(D),nat,size_size(list(D)),Ys)),Xs)),Ys)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(list(D),nat,size_size(list(D)),Ys)),Xs)),Zs)) ).

% zip_append2
tff(fact_2753_snoc__listrel1__snoc__iff,axiom,
    ! [C: $tType,Xs: list(C),X: C,Ys: list(C),Y: C,R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C)))),listrel1(C,R3))
    <=> ( ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
          & ( X = Y ) )
        | ( ( Xs = Ys )
          & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3) ) ) ) ).

% snoc_listrel1_snoc_iff
tff(fact_2754_map__tailrec__rev_Opelims,axiom,
    ! [D: $tType,C: $tType,X: fun(D,C),Xa: list(D),Xb: list(C),Y: list(C)] :
      ( ( map_tailrec_rev(D,C,X,Xa,Xb) = Y )
     => ( accp(product_prod(fun(D,C),product_prod(list(D),list(C))),map_tailrec_rev_rel(D,C),aa(product_prod(list(D),list(C)),product_prod(fun(D,C),product_prod(list(D),list(C))),aa(fun(D,C),fun(product_prod(list(D),list(C)),product_prod(fun(D,C),product_prod(list(D),list(C)))),product_Pair(fun(D,C),product_prod(list(D),list(C))),X),aa(list(C),product_prod(list(D),list(C)),aa(list(D),fun(list(C),product_prod(list(D),list(C))),product_Pair(list(D),list(C)),Xa),Xb)))
       => ( ( ( Xa = nil(D) )
           => ( ( Y = Xb )
             => ~ accp(product_prod(fun(D,C),product_prod(list(D),list(C))),map_tailrec_rev_rel(D,C),aa(product_prod(list(D),list(C)),product_prod(fun(D,C),product_prod(list(D),list(C))),aa(fun(D,C),fun(product_prod(list(D),list(C)),product_prod(fun(D,C),product_prod(list(D),list(C)))),product_Pair(fun(D,C),product_prod(list(D),list(C))),X),aa(list(C),product_prod(list(D),list(C)),aa(list(D),fun(list(C),product_prod(list(D),list(C))),product_Pair(list(D),list(C)),nil(D)),Xb))) ) )
         => ~ ! [A5: D,As: list(D)] :
                ( ( Xa = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),As) )
               => ( ( Y = map_tailrec_rev(D,C,X,As,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,X,A5)),Xb)) )
                 => ~ accp(product_prod(fun(D,C),product_prod(list(D),list(C))),map_tailrec_rev_rel(D,C),aa(product_prod(list(D),list(C)),product_prod(fun(D,C),product_prod(list(D),list(C))),aa(fun(D,C),fun(product_prod(list(D),list(C)),product_prod(fun(D,C),product_prod(list(D),list(C)))),product_Pair(fun(D,C),product_prod(list(D),list(C))),X),aa(list(C),product_prod(list(D),list(C)),aa(list(D),fun(list(C),product_prod(list(D),list(C))),product_Pair(list(D),list(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),As)),Xb))) ) ) ) ) ) ).

% map_tailrec_rev.pelims
tff(fact_2755_trancl__set__ntrancl,axiom,
    ! [C: $tType,Xs: list(product_prod(C,C))] : transitive_trancl(C,aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),Xs)) = transitive_ntrancl(C,minus_minus(nat,finite_card(product_prod(C,C),aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),Xs)),one_one(nat)),aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),Xs)) ).

% trancl_set_ntrancl
tff(fact_2756_abstract__boolean__algebra__sym__diff__def,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C))] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
    <=> ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
        & boolea5476839437570043046axioms(C,Conj,Disj,Compl,Xor) ) ) ).

% abstract_boolean_algebra_sym_diff_def
tff(fact_2757_abstract__boolean__algebra__sym__diff_Ointro,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C))] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => ( boolea5476839437570043046axioms(C,Conj,Disj,Compl,Xor)
       => boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor) ) ) ).

% abstract_boolean_algebra_sym_diff.intro
tff(fact_2758_lenlex__append2,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),Us2: list(C),Xs: list(C),Ys: list(C)] :
      ( irrefl(C,R)
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),Xs)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),Ys)),lenlex(C,R))
      <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lenlex(C,R)) ) ) ).

% lenlex_append2
tff(fact_2759_minus__Max__eq__Min,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [S: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ( aa(C,C,uminus_uminus(C),lattic643756798349783984er_Max(C,S)) = lattic643756798350308766er_Min(C,aa(set(C),set(C),image2(C,C,uminus_uminus(C)),S)) ) ) ) ) ).

% minus_Max_eq_Min
tff(fact_2760_image__eqI,axiom,
    ! [C: $tType,D: $tType,B2: C,F: fun(D,C),X: D,A4: set(D)] :
      ( ( B2 = aa(D,C,F,X) )
     => ( member2(D,X,A4)
       => member2(C,B2,aa(set(D),set(C),image2(D,C,F),A4)) ) ) ).

% image_eqI
tff(fact_2761_image__is__empty,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] :
      ( ( aa(set(D),set(C),image2(D,C,F),A4) = bot_bot(set(C)) )
    <=> ( A4 = bot_bot(set(D)) ) ) ).

% image_is_empty
tff(fact_2762_empty__is__image,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] :
      ( ( bot_bot(set(C)) = aa(set(D),set(C),image2(D,C,F),A4) )
    <=> ( A4 = bot_bot(set(D)) ) ) ).

% empty_is_image
tff(fact_2763_image__empty,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C)] : aa(set(D),set(C),image2(D,C,F),bot_bot(set(D))) = bot_bot(set(C)) ).

% image_empty
tff(fact_2764_image__insert,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A3: D,B3: set(D)] : aa(set(D),set(C),image2(D,C,F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),B3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(D,C,F,A3)),aa(set(D),set(C),image2(D,C,F),B3)) ).

% image_insert
tff(fact_2765_insert__image,axiom,
    ! [D: $tType,C: $tType,X: C,A4: set(C),F: fun(C,D)] :
      ( member2(C,X,A4)
     => ( aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),aa(C,D,F,X)),aa(set(C),set(D),image2(C,D,F),A4)) = aa(set(C),set(D),image2(C,D,F),A4) ) ) ).

% insert_image
tff(fact_2766_op__conc__empty__img__id,axiom,
    ! [C: $tType,L6: set(list(C))] : aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),nil(C))),L6) = L6 ).

% op_conc_empty_img_id
tff(fact_2767_image__update,axiom,
    ! [D: $tType,C: $tType,X: C,A4: set(C),F: fun(C,D),N: D] :
      ( ~ member2(C,X,A4)
     => ( aa(set(C),set(D),image2(C,D,fun_upd(C,D,F,X,N)),A4) = aa(set(C),set(D),image2(C,D,F),A4) ) ) ).

% image_update
tff(fact_2768_image__add__0,axiom,
    ! [C: $tType] :
      ( comm_monoid_add(C)
     => ! [S: set(C)] : aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),plus_plus(C),zero_zero(C))),S) = S ) ).

% image_add_0
tff(fact_2769_list_Oset__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),V: list(D)] : aa(list(C),set(C),set2(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),V)) = aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),V)) ).

% list.set_map
tff(fact_2770_lexord__same__pref__if__irrefl,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( irrefl(C,R3)
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Zs)),lexord(C,R3))
      <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),lexord(C,R3)) ) ) ).

% lexord_same_pref_if_irrefl
tff(fact_2771_inj__on__insert,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A3: C,A4: set(C)] :
      ( inj_on(C,D,F,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4))
    <=> ( inj_on(C,D,F,A4)
        & ~ member2(D,aa(C,D,F,A3),aa(set(C),set(D),image2(C,D,F),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ).

% inj_on_insert
tff(fact_2772_minus__Min__eq__Max,axiom,
    ! [C: $tType] :
      ( linord5086331880401160121up_add(C)
     => ! [S: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ( aa(C,C,uminus_uminus(C),lattic643756798350308766er_Min(C,S)) = lattic643756798349783984er_Max(C,aa(set(C),set(C),image2(C,C,uminus_uminus(C)),S)) ) ) ) ) ).

% minus_Min_eq_Max
tff(fact_2773_abstract__boolean__algebra__sym__diff__axioms_Ointro,axiom,
    ! [C: $tType,Xor: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Conj: fun(C,fun(C,C)),Compl: fun(C,C)] :
      ( ! [X2: C,Y2: C] : aa(C,C,aa(C,fun(C,C),Xor,X2),Y2) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,X2),aa(C,C,Compl,Y2))),aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,Compl,X2)),Y2))
     => boolea5476839437570043046axioms(C,Conj,Disj,Compl,Xor) ) ).

% abstract_boolean_algebra_sym_diff_axioms.intro
tff(fact_2774_abstract__boolean__algebra__sym__diff__axioms__def,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Xor: fun(C,fun(C,C))] :
      ( boolea5476839437570043046axioms(C,Conj,Disj,Compl,Xor)
    <=> ! [X4: C,Y3: C] : aa(C,C,aa(C,fun(C,C),Xor,X4),Y3) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,X4),aa(C,C,Compl,Y3))),aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,Compl,X4)),Y3)) ) ).

% abstract_boolean_algebra_sym_diff_axioms_def
tff(fact_2775_imageI,axiom,
    ! [D: $tType,C: $tType,X: C,A4: set(C),F: fun(C,D)] :
      ( member2(C,X,A4)
     => member2(D,aa(C,D,F,X),aa(set(C),set(D),image2(C,D,F),A4)) ) ).

% imageI
tff(fact_2776_image__iff,axiom,
    ! [C: $tType,D: $tType,Z2: C,F: fun(D,C),A4: set(D)] :
      ( member2(C,Z2,aa(set(D),set(C),image2(D,C,F),A4))
    <=> ? [X4: D] :
          ( member2(D,X4,A4)
          & ( Z2 = aa(D,C,F,X4) ) ) ) ).

% image_iff
tff(fact_2777_bex__imageD,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D),Pa: fun(C,$o)] :
      ( ? [X3: C] :
          ( member2(C,X3,aa(set(D),set(C),image2(D,C,F),A4))
          & aa(C,$o,Pa,X3) )
     => ? [X2: D] :
          ( member2(D,X2,A4)
          & aa(C,$o,Pa,aa(D,C,F,X2)) ) ) ).

% bex_imageD
tff(fact_2778_image__cong,axiom,
    ! [D: $tType,C: $tType,M: set(C),N4: set(C),F: fun(C,D),G: fun(C,D)] :
      ( ( M = N4 )
     => ( ! [X2: C] :
            ( member2(C,X2,N4)
           => ( aa(C,D,F,X2) = aa(C,D,G,X2) ) )
       => ( aa(set(C),set(D),image2(C,D,F),M) = aa(set(C),set(D),image2(C,D,G),N4) ) ) ) ).

% image_cong
tff(fact_2779_ball__imageD,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D),Pa: fun(C,$o)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(set(D),set(C),image2(D,C,F),A4))
         => aa(C,$o,Pa,X2) )
     => ! [X3: D] :
          ( member2(D,X3,A4)
         => aa(C,$o,Pa,aa(D,C,F,X3)) ) ) ).

% ball_imageD
tff(fact_2780_rev__image__eqI,axiom,
    ! [D: $tType,C: $tType,X: C,A4: set(C),B2: D,F: fun(C,D)] :
      ( member2(C,X,A4)
     => ( ( B2 = aa(C,D,F,X) )
       => member2(D,B2,aa(set(C),set(D),image2(C,D,F),A4)) ) ) ).

% rev_image_eqI
tff(fact_2781_image__Pow__surj,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D),B3: set(C)] :
      ( ( aa(set(D),set(C),image2(D,C,F),A4) = B3 )
     => ( aa(set(set(D)),set(set(C)),image2(set(D),set(C),image2(D,C,F)),pow(D,A4)) = pow(C,B3) ) ) ).

% image_Pow_surj
tff(fact_2782_lexord__irrefl,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( irrefl(C,R)
     => irrefl(list(C),lexord(C,R)) ) ).

% lexord_irrefl
tff(fact_2783_irrefl__lex,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( irrefl(C,R3)
     => irrefl(list(C),lex(C,R3)) ) ).

% irrefl_lex
tff(fact_2784_image__mono,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(C),F: fun(C,D)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(C),set(D),image2(C,D,F),A4)),aa(set(C),set(D),image2(C,D,F),B3)) ) ).

% image_mono
tff(fact_2785_image__subsetI,axiom,
    ! [C: $tType,D: $tType,A4: set(C),F: fun(C,D),B3: set(D)] :
      ( ! [X2: C] :
          ( member2(C,X2,A4)
         => member2(D,aa(C,D,F,X2),B3) )
     => aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(C),set(D),image2(C,D,F),A4)),B3) ) ).

% image_subsetI
tff(fact_2786_subset__imageE,axiom,
    ! [C: $tType,D: $tType,B3: set(C),F: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),aa(set(D),set(C),image2(D,C,F),A4))
     => ~ ! [C8: set(D)] :
            ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),C8),A4)
           => ( B3 != aa(set(D),set(C),image2(D,C,F),C8) ) ) ) ).

% subset_imageE
tff(fact_2787_image__subset__iff,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),image2(D,C,F),A4)),B3)
    <=> ! [X4: D] :
          ( member2(D,X4,A4)
         => member2(C,aa(D,C,F,X4),B3) ) ) ).

% image_subset_iff
tff(fact_2788_subset__image__iff,axiom,
    ! [C: $tType,D: $tType,B3: set(C),F: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),aa(set(D),set(C),image2(D,C,F),A4))
    <=> ? [AA: set(D)] :
          ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),AA),A4)
          & ( B3 = aa(set(D),set(C),image2(D,C,F),AA) ) ) ) ).

% subset_image_iff
tff(fact_2789_image__Un,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D),B3: set(D)] : aa(set(D),set(C),image2(D,C,F),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(D),set(C),image2(D,C,F),A4)),aa(set(D),set(C),image2(D,C,F),B3)) ).

% image_Un
tff(fact_2790_image__Pow__mono,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),image2(D,C,F),A4)),B3)
     => aa(set(set(C)),$o,aa(set(set(C)),fun(set(set(C)),$o),ord_less_eq(set(set(C))),aa(set(set(D)),set(set(C)),image2(set(D),set(C),image2(D,C,F)),pow(D,A4))),pow(C,B3)) ) ).

% image_Pow_mono
tff(fact_2791_f__inv__on__f,axiom,
    ! [D: $tType,C: $tType,Y: C,F: fun(D,C),A4: set(D)] :
      ( member2(C,Y,aa(set(D),set(C),image2(D,C,F),A4))
     => ( aa(D,C,F,aa(C,D,inv_on(D,C,F,A4),Y)) = Y ) ) ).

% f_inv_on_f
tff(fact_2792_inv__on__f__range,axiom,
    ! [C: $tType,D: $tType,Y: C,F: fun(D,C),A4: set(D)] :
      ( member2(C,Y,aa(set(D),set(C),image2(D,C,F),A4))
     => member2(D,aa(C,D,inv_on(D,C,F,A4),Y),A4) ) ).

% inv_on_f_range
tff(fact_2793_SUP__eq__const,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [I5: set(C),F: fun(C,D),X: D] :
          ( ( I5 != bot_bot(set(C)) )
         => ( ! [I3: C] :
                ( member2(C,I3,I5)
               => ( aa(C,D,F,I3) = X ) )
           => ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),I5)) = X ) ) ) ) ).

% SUP_eq_const
tff(fact_2794_translation__Int,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C,S4: set(C),T4: set(C)] : aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),plus_plus(C),A3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S4),T4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),plus_plus(C),A3)),S4)),aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),plus_plus(C),A3)),T4)) ) ).

% translation_Int
tff(fact_2795_inf__Sup,axiom,
    ! [C: $tType] :
      ( comple592849572758109894attice(C)
     => ! [A3: C,B3: set(C)] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Sup_Sup(C),B3)) = aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),inf_inf(C),A3)),B3)) ) ).

% inf_Sup
tff(fact_2796_image__Int__subset,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D),B3: set(D)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),image2(D,C,F),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),image2(D,C,F),A4)),aa(set(D),set(C),image2(D,C,F),B3))) ).

% image_Int_subset
tff(fact_2797_image__diff__subset,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D),B3: set(D)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),minus_minus(set(C),aa(set(D),set(C),image2(D,C,F),A4),aa(set(D),set(C),image2(D,C,F),B3))),aa(set(D),set(C),image2(D,C,F),minus_minus(set(D),A4,B3))) ).

% image_diff_subset
tff(fact_2798_image__set,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),Xs)) = aa(list(C),set(C),set2(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) ).

% image_set
tff(fact_2799_finite__UNION__then__finite,axiom,
    ! [C: $tType,D: $tType,B3: fun(D,set(C)),A4: set(D),A3: D] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),A4)))
     => ( member2(D,A3,A4)
       => aa(set(C),$o,finite_finite2(C),aa(D,set(C),B3,A3)) ) ) ).

% finite_UNION_then_finite
tff(fact_2800_insort__insert__key__triv,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),X: D,Xs: list(D)] :
          ( member2(C,aa(D,C,F,X),aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),Xs)))
         => ( linord329482645794927042rt_key(D,C,F,X,Xs) = Xs ) ) ) ).

% insort_insert_key_triv
tff(fact_2801_the__elem__image__unique,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,D),X: C] :
      ( ( A4 != bot_bot(set(C)) )
     => ( ! [Y2: C] :
            ( member2(C,Y2,A4)
           => ( aa(C,D,F,Y2) = aa(C,D,F,X) ) )
       => ( the_elem(D,aa(set(C),set(D),image2(C,D,F),A4)) = aa(C,D,F,X) ) ) ) ).

% the_elem_image_unique
tff(fact_2802_SUP__eq__iff,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [I5: set(C),C3: D,F: fun(C,D)] :
          ( ( I5 != bot_bot(set(C)) )
         => ( ! [I3: C] :
                ( member2(C,I3,I5)
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),C3),aa(C,D,F,I3)) )
           => ( ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),I5)) = C3 )
            <=> ! [X4: C] :
                  ( member2(C,X4,I5)
                 => ( aa(C,D,F,X4) = C3 ) ) ) ) ) ) ).

% SUP_eq_iff
tff(fact_2803_cSUP__least,axiom,
    ! [C: $tType,D: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),M: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),M) )
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),M) ) ) ) ).

% cSUP_least
tff(fact_2804_inj__on__iff__surj,axiom,
    ! [D: $tType,C: $tType,A4: set(C),A12: set(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( ? [F6: fun(C,D)] :
            ( inj_on(C,D,F6,A4)
            & aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(C),set(D),image2(C,D,F6),A4)),A12) )
      <=> ? [G3: fun(D,C)] : aa(set(D),set(C),image2(D,C,G3),A12) = A4 ) ) ).

% inj_on_iff_surj
tff(fact_2805_in__image__insert__iff,axiom,
    ! [C: $tType,B3: set(set(C)),X: C,A4: set(C)] :
      ( ! [C8: set(C)] :
          ( member2(set(C),C8,B3)
         => ~ member2(C,X,C8) )
     => ( member2(set(C),A4,aa(set(set(C)),set(set(C)),image2(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X)),B3))
      <=> ( member2(C,X,A4)
          & member2(set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))),B3) ) ) ) ).

% in_image_insert_iff
tff(fact_2806_inj__on__image__Int,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),C4: set(C),A4: set(C),B3: set(C)] :
      ( inj_on(C,D,F,C4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
         => ( aa(set(C),set(D),image2(C,D,F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),image2(C,D,F),A4)),aa(set(C),set(D),image2(C,D,F),B3)) ) ) ) ) ).

% inj_on_image_Int
tff(fact_2807_lexl__not__refl,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),X: list(C)] :
      ( irrefl(C,R3)
     => ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),X),lex(C,R3)) ) ).

% lexl_not_refl
tff(fact_2808_abstract__boolean__algebra__sym__diff_Oaxioms_I2_J,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C,Xor: fun(C,fun(C,C))] :
      ( boolea3799213064322606851m_diff(C,Conj,Disj,Compl,Zero,One,Xor)
     => boolea5476839437570043046axioms(C,Conj,Disj,Compl,Xor) ) ).

% abstract_boolean_algebra_sym_diff.axioms(2)
tff(fact_2809_Pow__insert,axiom,
    ! [C: $tType,A3: C,A4: set(C)] : pow(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),sup_sup(set(set(C))),pow(C,A4)),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3)),pow(C,A4))) ).

% Pow_insert
tff(fact_2810_set__image__eq__pointwiseI,axiom,
    ! [D: $tType,C: $tType,La: list(C),L_a: list(C),F: fun(C,D)] :
      ( ( aa(list(C),nat,size_size(list(C)),La) = aa(list(C),nat,size_size(list(C)),L_a) )
     => ( ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),La))
           => ( aa(C,D,F,aa(nat,C,nth(C,La),I3)) = aa(C,D,F,aa(nat,C,nth(C,L_a),I3)) ) )
       => ( aa(set(C),set(D),image2(C,D,F),aa(list(C),set(C),set2(C),La)) = aa(set(C),set(D),image2(C,D,F),aa(list(C),set(C),set2(C),L_a)) ) ) ) ).

% set_image_eq_pointwiseI
tff(fact_2811_in__set__image__conv__nth,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),X: D,La: list(D)] :
      ( member2(C,aa(D,C,F,X),aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),La)))
    <=> ? [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(D),nat,size_size(list(D)),La))
          & ( aa(D,C,F,aa(nat,D,nth(D,La),I2)) = aa(D,C,F,X) ) ) ) ).

% in_set_image_conv_nth
tff(fact_2812_fun__upd__image,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),X: D,Y: C,A4: set(D)] :
      aa(set(D),set(C),image2(D,C,fun_upd(D,C,F,X,Y)),A4) = $ite(member2(D,X,A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),aa(set(D),set(C),image2(D,C,F),minus_minus(set(D),A4,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D)))))),aa(set(D),set(C),image2(D,C,F),A4)) ).

% fun_upd_image
tff(fact_2813_Inf__fin_Ohom__commute,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [H: fun(C,C),N4: set(C)] :
          ( ! [X2: C,Y2: C] : aa(C,C,H,aa(C,C,aa(C,fun(C,C),inf_inf(C),X2),Y2)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(C,C,H,X2)),aa(C,C,H,Y2))
         => ( aa(set(C),$o,finite_finite2(C),N4)
           => ( ( N4 != bot_bot(set(C)) )
             => ( aa(C,C,H,aa(set(C),C,lattic7752659483105999362nf_fin(C),N4)) = aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),image2(C,C,H),N4)) ) ) ) ) ) ).

% Inf_fin.hom_commute
tff(fact_2814_Sup__fin_Ohom__commute,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [H: fun(C,C),N4: set(C)] :
          ( ! [X2: C,Y2: C] : aa(C,C,H,aa(C,C,aa(C,fun(C,C),sup_sup(C),X2),Y2)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,H,X2)),aa(C,C,H,Y2))
         => ( aa(set(C),$o,finite_finite2(C),N4)
           => ( ( N4 != bot_bot(set(C)) )
             => ( aa(C,C,H,lattic5882676163264333800up_fin(C,N4)) = lattic5882676163264333800up_fin(C,aa(set(C),set(C),image2(C,C,H),N4)) ) ) ) ) ) ).

% Sup_fin.hom_commute
tff(fact_2815_hom__Max__commute,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [H: fun(C,C),N4: set(C)] :
          ( ! [X2: C,Y2: C] : aa(C,C,H,aa(C,C,aa(C,fun(C,C),ord_max(C),X2),Y2)) = aa(C,C,aa(C,fun(C,C),ord_max(C),aa(C,C,H,X2)),aa(C,C,H,Y2))
         => ( aa(set(C),$o,finite_finite2(C),N4)
           => ( ( N4 != bot_bot(set(C)) )
             => ( aa(C,C,H,lattic643756798349783984er_Max(C,N4)) = lattic643756798349783984er_Max(C,aa(set(C),set(C),image2(C,C,H),N4)) ) ) ) ) ) ).

% hom_Max_commute
tff(fact_2816_hom__Min__commute,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [H: fun(C,C),N4: set(C)] :
          ( ! [X2: C,Y2: C] : aa(C,C,H,aa(C,C,aa(C,fun(C,C),ord_min(C),X2),Y2)) = aa(C,C,aa(C,fun(C,C),ord_min(C),aa(C,C,H,X2)),aa(C,C,H,Y2))
         => ( aa(set(C),$o,finite_finite2(C),N4)
           => ( ( N4 != bot_bot(set(C)) )
             => ( aa(C,C,H,lattic643756798350308766er_Min(C,N4)) = lattic643756798350308766er_Min(C,aa(set(C),set(C),image2(C,C,H),N4)) ) ) ) ) ) ).

% hom_Min_commute
tff(fact_2817_semilattice__set_Ohom__commute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),H: fun(C,C),N4: set(C)] :
      ( lattic149705377957585745ce_set(C,F)
     => ( ! [X2: C,Y2: C] : aa(C,C,H,aa(C,C,aa(C,fun(C,C),F,X2),Y2)) = aa(C,C,aa(C,fun(C,C),F,aa(C,C,H,X2)),aa(C,C,H,Y2))
       => ( aa(set(C),$o,finite_finite2(C),N4)
         => ( ( N4 != bot_bot(set(C)) )
           => ( aa(C,C,H,aa(set(C),C,lattic1715443433743089157tice_F(C,F),N4)) = aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(set(C),set(C),image2(C,C,H),N4)) ) ) ) ) ) ).

% semilattice_set.hom_commute
tff(fact_2818_f__arg__min__list__f,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Xs: list(C),F: fun(C,D)] :
          ( ( Xs != nil(C) )
         => ( aa(C,D,F,arg_min_list(C,D,F,Xs)) = lattic643756798350308766er_Min(D,aa(set(C),set(D),image2(C,D,F),aa(list(C),set(C),set2(C),Xs))) ) ) ) ).

% f_arg_min_list_f
tff(fact_2819_subset__subseqs,axiom,
    ! [C: $tType,X5: set(C),Xs: list(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),X5),aa(list(C),set(C),set2(C),Xs))
     => member2(set(C),X5,aa(set(list(C)),set(set(C)),image2(list(C),set(C),set2(C)),aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(C),list(list(C)),subseqs(C),Xs)))) ) ).

% subset_subseqs
tff(fact_2820_finite__set__image,axiom,
    ! [C: $tType,A4: set(list(C))] :
      ( aa(set(set(C)),$o,finite_finite2(set(C)),aa(set(list(C)),set(set(C)),image2(list(C),set(C),set2(C)),A4))
     => ( ! [Xs2: list(C)] :
            ( member2(list(C),Xs2,A4)
           => aa(list(C),$o,distinct(C),Xs2) )
       => aa(set(list(C)),$o,finite_finite2(list(C)),A4) ) ) ).

% finite_set_image
tff(fact_2821_subseqs__powset,axiom,
    ! [C: $tType,Xs: list(C)] : aa(set(list(C)),set(set(C)),image2(list(C),set(C),set2(C)),aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(C),list(list(C)),subseqs(C),Xs))) = pow(C,aa(list(C),set(C),set2(C),Xs)) ).

% subseqs_powset
tff(fact_2822_inj__on__Un,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(C),B3: set(C)] :
      ( inj_on(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
    <=> ( inj_on(C,D,F,A4)
        & inj_on(C,D,F,B3)
        & ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),image2(C,D,F),minus_minus(set(C),A4,B3))),aa(set(C),set(D),image2(C,D,F),minus_minus(set(C),B3,A4))) = bot_bot(set(D)) ) ) ) ).

% inj_on_Un
tff(fact_2823_UNION__fun__upd,axiom,
    ! [D: $tType,C: $tType,A4: fun(D,set(C)),I: D,B3: set(C),J4: set(D)] :
      aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),fun_upd(D,set(C),A4,I,B3)),J4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),minus_minus(set(D),J4,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),I),bot_bot(set(D))))))),
        $ite(member2(D,I,J4),B3,bot_bot(set(C)))) ).

% UNION_fun_upd
tff(fact_2824_inj__on__mapI,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(list(C))] :
      ( inj_on(C,D,F,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(list(C)),set(set(C)),image2(list(C),set(C),set2(C)),A4)))
     => inj_on(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),A4) ) ).

% inj_on_mapI
tff(fact_2825_Union__image__empty,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(D,set(C))] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),F),bot_bot(set(D))))) = A4 ).

% Union_image_empty
tff(fact_2826_bijective__Empty,axiom,
    ! [D: $tType,C: $tType] : bijective(C,D,bot_bot(set(product_prod(C,D)))) ).

% bijective_Empty
tff(fact_2827_total__on__singleton,axiom,
    ! [C: $tType,X: C] : total_on(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),X)),bot_bot(set(product_prod(C,C))))) ).

% total_on_singleton
tff(fact_2828_Field__insert,axiom,
    ! [C: $tType,A3: C,B2: C,R3: set(product_prod(C,C))] : field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2)),R3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))),field2(C,R3)) ).

% Field_insert
tff(fact_2829_upt__rec__numeral,axiom,
    ! [M2: num,N: num] :
      upt(aa(num,nat,numeral_numeral(nat),M2),aa(num,nat,numeral_numeral(nat),N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(num,nat,numeral_numeral(nat),M2)),aa(num,nat,numeral_numeral(nat),N)),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),aa(num,nat,numeral_numeral(nat),M2)),upt(aa(nat,nat,suc,aa(num,nat,numeral_numeral(nat),M2)),aa(num,nat,numeral_numeral(nat),N))),nil(nat)) ).

% upt_rec_numeral
tff(fact_2830_nth__enumerate__eq,axiom,
    ! [C: $tType,M2: nat,Xs: list(C),N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M2),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(nat,product_prod(nat,C),nth(product_prod(nat,C),enumerate(C,N,Xs)),M2) = aa(C,product_prod(nat,C),aa(nat,fun(C,product_prod(nat,C)),product_Pair(nat,C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M2)),aa(nat,C,nth(C,Xs),M2)) ) ) ).

% nth_enumerate_eq
tff(fact_2831_finite__Field__eq__finite,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( aa(set(C),$o,finite_finite2(C),field2(C,R))
    <=> aa(set(product_prod(C,C)),$o,finite_finite2(product_prod(C,C)),R) ) ).

% finite_Field_eq_finite
tff(fact_2832_tl__upt,axiom,
    ! [M2: nat,N: nat] : aa(list(nat),list(nat),tl(nat),upt(M2,N)) = upt(aa(nat,nat,suc,M2),N) ).

% tl_upt
tff(fact_2833_hd__upt,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => ( aa(list(nat),nat,hd(nat),upt(I,J)) = I ) ) ).

% hd_upt
tff(fact_2834_drop__upt,axiom,
    ! [M2: nat,I: nat,J: nat] : aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),drop(nat),M2),upt(I,J)) = upt(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),M2),J) ).

% drop_upt
tff(fact_2835_enumerate__simps_I1_J,axiom,
    ! [C: $tType,N: nat] : enumerate(C,N,nil(C)) = nil(product_prod(nat,C)) ).

% enumerate_simps(1)
tff(fact_2836_length__enumerate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(product_prod(nat,C)),nat,size_size(list(product_prod(nat,C))),enumerate(C,N,Xs)) = aa(list(C),nat,size_size(list(C)),Xs) ).

% length_enumerate
tff(fact_2837_Field__empty,axiom,
    ! [C: $tType] : field2(C,bot_bot(set(product_prod(C,C)))) = bot_bot(set(C)) ).

% Field_empty
tff(fact_2838_take__upt,axiom,
    ! [I: nat,M2: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),M2)),N)
     => ( aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),take(nat),M2),upt(I,N)) = upt(I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),M2)) ) ) ).

% take_upt
tff(fact_2839_upt__0__eq__Nil__conv,axiom,
    ! [J: nat] :
      ( ( upt(zero_zero(nat),J) = nil(nat) )
    <=> ( J = zero_zero(nat) ) ) ).

% upt_0_eq_Nil_conv
tff(fact_2840_upt__conv__Nil,axiom,
    ! [J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( upt(I,J) = nil(nat) ) ) ).

% upt_conv_Nil
tff(fact_2841_upt__merge,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),K) )
     => ( aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),upt(I,J)),upt(J,K)) = upt(I,K) ) ) ).

% upt_merge
tff(fact_2842_length__upt,axiom,
    ! [I: nat,J: nat] : aa(list(nat),nat,size_size(list(nat)),upt(I,J)) = minus_minus(nat,J,I) ).

% length_upt
tff(fact_2843_last__upt,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => ( last(nat,upt(I,J)) = minus_minus(nat,J,one_one(nat)) ) ) ).

% last_upt
tff(fact_2844_upt__eq__Nil__conv,axiom,
    ! [I: nat,J: nat] :
      ( ( upt(I,J) = nil(nat) )
    <=> ( ( J = zero_zero(nat) )
        | aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I) ) ) ).

% upt_eq_Nil_conv
tff(fact_2845_enumerate__simps_I2_J,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : enumerate(C,N,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(product_prod(nat,C)),list(product_prod(nat,C)),aa(product_prod(nat,C),fun(list(product_prod(nat,C)),list(product_prod(nat,C))),cons(product_prod(nat,C)),aa(C,product_prod(nat,C),aa(nat,fun(C,product_prod(nat,C)),product_Pair(nat,C),N),X)),enumerate(C,aa(nat,nat,suc,N),Xs)) ).

% enumerate_simps(2)
tff(fact_2846_nth__upt,axiom,
    ! [I: nat,K: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),J)
     => ( aa(nat,nat,nth(nat,upt(I,J)),K) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K) ) ) ).

% nth_upt
tff(fact_2847_map__Suc__upt,axiom,
    ! [M2: nat,N: nat] : aa(list(nat),list(nat),aa(fun(nat,nat),fun(list(nat),list(nat)),map(nat,nat),suc),upt(M2,N)) = upt(aa(nat,nat,suc,M2),aa(nat,nat,suc,N)) ).

% map_Suc_upt
tff(fact_2848_distinct__enumerate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(product_prod(nat,C)),$o,distinct(product_prod(nat,C)),enumerate(C,N,Xs)) ).

% distinct_enumerate
tff(fact_2849_distinct__upt,axiom,
    ! [I: nat,J: nat] : aa(list(nat),$o,distinct(nat),upt(I,J)) ).

% distinct_upt
tff(fact_2850_enumerate__eq__zip,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : enumerate(C,N,Xs) = aa(list(C),list(product_prod(nat,C)),aa(list(nat),fun(list(C),list(product_prod(nat,C))),zip(nat,C),upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(C),nat,size_size(list(C)),Xs)))),Xs) ).

% enumerate_eq_zip
tff(fact_2851_total__on__empty,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : total_on(C,bot_bot(set(C)),R3) ).

% total_on_empty
tff(fact_2852_butlast__upt,axiom,
    ! [M2: nat,N: nat] : aa(list(nat),list(nat),butlast(nat),upt(M2,N)) = upt(M2,minus_minus(nat,N,one_one(nat))) ).

% butlast_upt
tff(fact_2853_atLeast__upt,axiom,
    ! [N: nat] : set_ord_lessThan(nat,N) = aa(list(nat),set(nat),set2(nat),upt(zero_zero(nat),N)) ).

% atLeast_upt
tff(fact_2854_upt__conv__Cons__Cons,axiom,
    ! [M2: nat,N: nat,Ns: list(nat),Q2: nat] :
      ( ( aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),M2),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),N),Ns)) = upt(M2,Q2) )
    <=> ( aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),N),Ns) = upt(aa(nat,nat,suc,M2),Q2) ) ) ).

% upt_conv_Cons_Cons
tff(fact_2855_upt__0,axiom,
    ! [I: nat] : upt(I,zero_zero(nat)) = nil(nat) ).

% upt_0
tff(fact_2856_sorted__wrt__upt,axiom,
    ! [M2: nat,N: nat] : sorted_wrt(nat,ord_less(nat),upt(M2,N)) ).

% sorted_wrt_upt
tff(fact_2857_sorted__upt,axiom,
    ! [M2: nat,N: nat] : sorted_wrt(nat,ord_less_eq(nat),upt(M2,N)) ).

% sorted_upt
tff(fact_2858_greaterThanAtMost__upt,axiom,
    ! [N: nat,M2: nat] : set_or3652927894154168847AtMost(nat,N,M2) = aa(list(nat),set(nat),set2(nat),upt(aa(nat,nat,suc,N),aa(nat,nat,suc,M2))) ).

% greaterThanAtMost_upt
tff(fact_2859_upt__eq__append__conv,axiom,
    ! [I: nat,J: nat,Xs: list(nat),Ys: list(nat)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( ( upt(I,J) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),Xs),Ys) )
      <=> ? [K4: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),K4)
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K4),J)
            & ( upt(I,K4) = Xs )
            & ( upt(K4,J) = Ys ) ) ) ) ).

% upt_eq_append_conv
tff(fact_2860_greaterThanLessThan__upt,axiom,
    ! [N: nat,M2: nat] : set_or5935395276787703475ssThan(nat,N,M2) = aa(list(nat),set(nat),set2(nat),upt(aa(nat,nat,suc,N),M2)) ).

% greaterThanLessThan_upt
tff(fact_2861_atMost__upto,axiom,
    ! [N: nat] : set_ord_atMost(nat,N) = aa(list(nat),set(nat),set2(nat),upt(zero_zero(nat),aa(nat,nat,suc,N))) ).

% atMost_upto
tff(fact_2862_upt__conv__Cons,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => ( upt(I,J) = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),I),upt(aa(nat,nat,suc,I),J)) ) ) ).

% upt_conv_Cons
tff(fact_2863_upt__append,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => ( aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),upt(zero_zero(nat),I)),upt(I,J)) = upt(zero_zero(nat),J) ) ) ).

% upt_append
tff(fact_2864_upt__add__eq__append,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( upt(I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K)) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),upt(I,J)),upt(J,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K))) ) ) ).

% upt_add_eq_append
tff(fact_2865_bijective__def,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D))] :
      ( bijective(C,D,R)
    <=> ( ! [X4: C,Y3: D,Z3: D] :
            ( ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X4),Y3),R)
              & member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X4),Z3),R) )
           => ( Y3 = Z3 ) )
        & ! [X4: C,Y3: C,Z3: D] :
            ( ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X4),Z3),R)
              & member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Y3),Z3),R) )
           => ( X4 = Y3 ) ) ) ) ).

% bijective_def
tff(fact_2866_nth__map__upt,axiom,
    ! [C: $tType,I: nat,N: nat,M2: nat,F: fun(nat,C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),minus_minus(nat,N,M2))
     => ( aa(nat,C,nth(C,aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),F),upt(M2,N))),I) = aa(nat,C,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),I)) ) ) ).

% nth_map_upt
tff(fact_2867_upt__eq__Cons__conv,axiom,
    ! [I: nat,J: nat,X: nat,Xs: list(nat)] :
      ( ( upt(I,J) = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),X),Xs) )
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
        & ( I = X )
        & ( upt(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),one_one(nat)),J) = Xs ) ) ) ).

% upt_eq_Cons_conv
tff(fact_2868_upt__rec,axiom,
    ! [I: nat,J: nat] :
      upt(I,J) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),I),upt(aa(nat,nat,suc,I),J)),nil(nat)) ).

% upt_rec
tff(fact_2869_enumerate__append__eq,axiom,
    ! [C: $tType,N: nat,Xs: list(C),Ys: list(C)] : enumerate(C,N,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(product_prod(nat,C)),list(product_prod(nat,C)),aa(list(product_prod(nat,C)),fun(list(product_prod(nat,C)),list(product_prod(nat,C))),append(product_prod(nat,C)),enumerate(C,N,Xs)),enumerate(C,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(C),nat,size_size(list(C)),Xs)),Ys)) ).

% enumerate_append_eq
tff(fact_2870_map__upt__eqI,axiom,
    ! [C: $tType,Xs: list(C),N: nat,M2: nat,F: fun(nat,C)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = minus_minus(nat,N,M2) )
     => ( ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Xs))
           => ( aa(nat,C,nth(C,Xs),I3) = aa(nat,C,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),I3)) ) )
       => ( aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),F),upt(M2,N)) = Xs ) ) ) ).

% map_upt_eqI
tff(fact_2871_map__nth__upt__drop__take__conv,axiom,
    ! [C: $tType,N4: nat,La: list(C),M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N4),aa(list(C),nat,size_size(list(C)),La))
     => ( aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),nth(C,La)),upt(M,N4)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),M),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N4),La)) ) ) ).

% map_nth_upt_drop_take_conv
tff(fact_2872_upt__eq__lel__conv,axiom,
    ! [La: nat,H: nat,Is1: list(nat),I: nat,Is2: list(nat)] :
      ( ( upt(La,H) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),Is1),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),I),Is2)) )
    <=> ( ( Is1 = upt(La,I) )
        & ( Is2 = upt(aa(nat,nat,suc,I),H) )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),La),I)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),H) ) ) ).

% upt_eq_lel_conv
tff(fact_2873_upt__Suc,axiom,
    ! [I: nat,J: nat] :
      upt(I,aa(nat,nat,suc,J)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J),aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),upt(I,J)),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),J),nil(nat))),nil(nat)) ).

% upt_Suc
tff(fact_2874_upt__Suc__append,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( upt(I,aa(nat,nat,suc,J)) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),upt(I,J)),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),J),nil(nat))) ) ) ).

% upt_Suc_append
tff(fact_2875_nth__image,axiom,
    ! [C: $tType,La: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),La),aa(list(C),nat,size_size(list(C)),Xs))
     => ( aa(set(nat),set(C),image2(nat,C,nth(C,Xs)),set_or7035219750837199246ssThan(nat,zero_zero(nat),La)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),La),Xs)) ) ) ).

% nth_image
tff(fact_2876_zipf__zip,axiom,
    ! [C: $tType,D: $tType,L12: list(C),L22: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),L12) = aa(list(D),nat,size_size(list(D)),L22) )
     => ( zipf(C,D,product_prod(C,D),product_Pair(C,D),L12,L22) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),L12),L22) ) ) ).

% zipf_zip
tff(fact_2877_Gcd__fin__0__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          ( ( aa(set(C),C,semiring_gcd_Gcd_fin(C),A4) = zero_zero(C) )
        <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),zero_zero(C)),bot_bot(set(C))))
            & aa(set(C),$o,finite_finite2(C),A4) ) ) ) ).

% Gcd_fin_0_iff
tff(fact_2878_neg__numeral__le__ceiling,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [V: num,X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),V))),archimedean_ceiling(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),V)),one_one(C))),X) ) ) ).

% neg_numeral_le_ceiling
tff(fact_2879_ceiling__less__neg__numeral,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(C,X)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),V)))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),minus_minus(C,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),V)),one_one(C))) ) ) ).

% ceiling_less_neg_numeral
tff(fact_2880_ceiling__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ( archimedean_ceiling(C,one_one(C)) = one_one(int) ) ) ).

% ceiling_one
tff(fact_2881_atLeastLessThan__empty,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3)
         => ( set_or7035219750837199246ssThan(C,A3,B2) = bot_bot(set(C)) ) ) ) ).

% atLeastLessThan_empty
tff(fact_2882_atLeastLessThan__empty__iff,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( ( set_or7035219750837199246ssThan(C,A3,B2) = bot_bot(set(C)) )
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% atLeastLessThan_empty_iff
tff(fact_2883_atLeastLessThan__empty__iff2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( ( bot_bot(set(C)) = set_or7035219750837199246ssThan(C,A3,B2) )
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ).

% atLeastLessThan_empty_iff2
tff(fact_2884_ceiling__add__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : archimedean_ceiling(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),one_one(C))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),archimedean_ceiling(C,X)),one_one(int)) ) ).

% ceiling_add_one
tff(fact_2885_ceiling__diff__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : archimedean_ceiling(C,minus_minus(C,X,one_one(C))) = minus_minus(int,archimedean_ceiling(C,X),one_one(int)) ) ).

% ceiling_diff_one
tff(fact_2886_Gcd__fin_Oempty,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ( aa(set(C),C,semiring_gcd_Gcd_fin(C),bot_bot(set(C))) = zero_zero(C) ) ) ).

% Gcd_fin.empty
tff(fact_2887_Gcd__fin_Oinfinite,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          ( ~ aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),C,semiring_gcd_Gcd_fin(C),A4) = one_one(C) ) ) ) ).

% Gcd_fin.infinite
tff(fact_2888_is__unit__Gcd__fin__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          ( dvd_dvd(C,aa(set(C),C,semiring_gcd_Gcd_fin(C),A4),one_one(C))
        <=> ( aa(set(C),C,semiring_gcd_Gcd_fin(C),A4) = one_one(C) ) ) ) ).

% is_unit_Gcd_fin_iff
tff(fact_2889_sorted__list__of__set__range,axiom,
    ! [M2: nat,N: nat] : aa(set(nat),list(nat),linord4507533701916653071of_set(nat),set_or7035219750837199246ssThan(nat,M2,N)) = upt(M2,N) ).

% sorted_list_of_set_range
tff(fact_2890_ceiling__le__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archimedean_ceiling(C,X)),one_one(int))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),one_one(C)) ) ) ).

% ceiling_le_one
tff(fact_2891_one__less__ceiling,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),one_one(int)),archimedean_ceiling(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),X) ) ) ).

% one_less_ceiling
tff(fact_2892_Int__atLeastLessThan,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or7035219750837199246ssThan(C,A3,B2)),set_or7035219750837199246ssThan(C,C3,D3)) = set_or7035219750837199246ssThan(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),D3)) ) ).

% Int_atLeastLessThan
tff(fact_2893_ceiling__less__zero,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(C,X)),zero_zero(int))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(C,C,uminus_uminus(C),one_one(C))) ) ) ).

% ceiling_less_zero
tff(fact_2894_zero__le__ceiling,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),archimedean_ceiling(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,uminus_uminus(C),one_one(C))),X) ) ) ).

% zero_le_ceiling
tff(fact_2895_nth__image__indices,axiom,
    ! [C: $tType,La: list(C)] : aa(set(nat),set(C),image2(nat,C,nth(C,La)),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(C),nat,size_size(list(C)),La))) = aa(list(C),set(C),set2(C),La) ).

% nth_image_indices
tff(fact_2896_ceiling__less__numeral,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(C,X)),aa(num,int,numeral_numeral(int),V))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),minus_minus(C,aa(num,C,numeral_numeral(C),V),one_one(C))) ) ) ).

% ceiling_less_numeral
tff(fact_2897_numeral__le__ceiling,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [V: num,X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(num,int,numeral_numeral(int),V)),archimedean_ceiling(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(num,C,numeral_numeral(C),V),one_one(C))),X) ) ) ).

% numeral_le_ceiling
tff(fact_2898_atLeastLessThan__upt,axiom,
    ! [I: nat,J: nat] : set_or7035219750837199246ssThan(nat,I,J) = aa(list(nat),set(nat),set2(nat),upt(I,J)) ).

% atLeastLessThan_upt
tff(fact_2899_ex__nat__less__eq,axiom,
    ! [N: nat,Pa: fun(nat,$o)] :
      ( ? [M3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M3),N)
          & aa(nat,$o,Pa,M3) )
    <=> ? [X4: nat] :
          ( member2(nat,X4,set_or7035219750837199246ssThan(nat,zero_zero(nat),N))
          & aa(nat,$o,Pa,X4) ) ) ).

% ex_nat_less_eq
tff(fact_2900_all__nat__less__eq,axiom,
    ! [N: nat,Pa: fun(nat,$o)] :
      ( ! [M3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M3),N)
         => aa(nat,$o,Pa,M3) )
    <=> ! [X4: nat] :
          ( member2(nat,X4,set_or7035219750837199246ssThan(nat,zero_zero(nat),N))
         => aa(nat,$o,Pa,X4) ) ) ).

% all_nat_less_eq
tff(fact_2901_ivl__disj__int__two_I3_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or7035219750837199246ssThan(C,La,M2)),set_or7035219750837199246ssThan(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(3)
tff(fact_2902_zipf_Osimps_I2_J,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(D,fun(E2,C)),A3: D,As2: list(D),B2: E2,Bs: list(E2)] : zipf(D,E2,C,F,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),As2),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),B2),Bs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(E2,C,aa(D,fun(E2,C),F,A3),B2)),zipf(D,E2,C,F,As2,Bs)) ).

% zipf.simps(2)
tff(fact_2903_zipf_Osimps_I1_J,axiom,
    ! [E2: $tType,D: $tType,C: $tType,F: fun(D,fun(E2,C))] : zipf(D,E2,C,F,nil(D),nil(E2)) = nil(C) ).

% zipf.simps(1)
tff(fact_2904_mult__ceiling__le,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archimedean_ceiling(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))),aa(int,int,aa(int,fun(int,int),times_times(int),archimedean_ceiling(C,A3)),archimedean_ceiling(C,B2))) ) ) ) ).

% mult_ceiling_le
tff(fact_2905_ivl__disj__int__one_I2_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_lessThan(C,La)),set_or7035219750837199246ssThan(C,La,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(2)
tff(fact_2906_ivl__disj__int__two_I1_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or5935395276787703475ssThan(C,La,M2)),set_or7035219750837199246ssThan(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(1)
tff(fact_2907_ivl__disj__un__singleton_I3_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: C,U: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),La),U)
         => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),La),bot_bot(set(C)))),set_or5935395276787703475ssThan(C,La,U)) = set_or7035219750837199246ssThan(C,La,U) ) ) ) ).

% ivl_disj_un_singleton(3)
tff(fact_2908_floor__le__neg__numeral,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(C,X)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),V)))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),V))),one_one(C))) ) ) ).

% floor_le_neg_numeral
tff(fact_2909_neg__numeral__less__floor,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [V: num,X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),V))),archim6421214686448440834_floor(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),V))),one_one(C))),X) ) ) ).

% neg_numeral_less_floor
tff(fact_2910_floor__le__numeral,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(C,X)),aa(num,int,numeral_numeral(int),V))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),V)),one_one(C))) ) ) ).

% floor_le_numeral
tff(fact_2911_numeral__less__floor,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [V: num,X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(num,int,numeral_numeral(int),V)),archim6421214686448440834_floor(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),V)),one_one(C))),X) ) ) ).

% numeral_less_floor
tff(fact_2912_ceiling__divide__lower,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Q2: C,P3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Q2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,aa(int,C,ring_1_of_int(C),archimedean_ceiling(C,divide_divide(C,P3,Q2))),one_one(C))),Q2)),P3) ) ) ).

% ceiling_divide_lower
tff(fact_2913_floor__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ( archim6421214686448440834_floor(C,one_one(C)) = one_one(int) ) ) ).

% floor_one
tff(fact_2914_zero__less__floor,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),archim6421214686448440834_floor(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),X) ) ) ).

% zero_less_floor
tff(fact_2915_floor__le__zero,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(C,X)),zero_zero(int))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),one_one(C)) ) ) ).

% floor_le_zero
tff(fact_2916_one__le__floor,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),one_one(int)),archim6421214686448440834_floor(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),X) ) ) ).

% one_le_floor
tff(fact_2917_floor__less__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archim6421214686448440834_floor(C,X)),one_one(int))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),one_one(C)) ) ) ).

% floor_less_one
tff(fact_2918_floor__diff__one,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : archim6421214686448440834_floor(C,minus_minus(C,X,one_one(C))) = minus_minus(int,archim6421214686448440834_floor(C,X),one_one(int)) ) ).

% floor_diff_one
tff(fact_2919_floor__split,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Pa: fun(int,$o),T4: C] :
          ( aa(int,$o,Pa,archim6421214686448440834_floor(C,T4))
        <=> ! [I2: int] :
              ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(int,C,ring_1_of_int(C),I2)),T4)
                & aa(C,$o,aa(C,fun(C,$o),ord_less(C),T4),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(int,C,ring_1_of_int(C),I2)),one_one(C))) )
             => aa(int,$o,Pa,I2) ) ) ) ).

% floor_split
tff(fact_2920_floor__eq__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,A3: int] :
          ( ( archim6421214686448440834_floor(C,X) = A3 )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(int,C,ring_1_of_int(C),A3)),X)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(int,C,ring_1_of_int(C),A3)),one_one(C))) ) ) ) ).

% floor_eq_iff
tff(fact_2921_floor__unique,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Z2: int,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(int,C,ring_1_of_int(C),Z2)),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(int,C,ring_1_of_int(C),Z2)),one_one(C)))
           => ( archim6421214686448440834_floor(C,X) = Z2 ) ) ) ) ).

% floor_unique
tff(fact_2922_less__floor__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Z2: int,X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z2),archim6421214686448440834_floor(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(int,C,ring_1_of_int(C),Z2)),one_one(C))),X) ) ) ).

% less_floor_iff
tff(fact_2923_floor__le__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,Z2: int] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(C,X)),Z2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(int,C,ring_1_of_int(C),Z2)),one_one(C))) ) ) ).

% floor_le_iff
tff(fact_2924_one__add__floor,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(C,X)),one_one(int)) = archim6421214686448440834_floor(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),one_one(C))) ) ).

% one_add_floor
tff(fact_2925_floor__divide__lower,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Q2: C,P3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Q2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(int,C,ring_1_of_int(C),archim6421214686448440834_floor(C,divide_divide(C,P3,Q2)))),Q2)),P3) ) ) ).

% floor_divide_lower
tff(fact_2926_floor__divide__upper,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Q2: C,P3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Q2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less(C),P3),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(int,C,ring_1_of_int(C),archim6421214686448440834_floor(C,divide_divide(C,P3,Q2)))),one_one(C))),Q2)) ) ) ).

% floor_divide_upper
tff(fact_2927_le__mult__floor,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
           => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),times_times(int),archim6421214686448440834_floor(C,A3)),archim6421214686448440834_floor(C,B2))),archim6421214686448440834_floor(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))) ) ) ) ).

% le_mult_floor
tff(fact_2928_ceiling__split,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Pa: fun(int,$o),T4: C] :
          ( aa(int,$o,Pa,archimedean_ceiling(C,T4))
        <=> ! [I2: int] :
              ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(int,C,ring_1_of_int(C),I2),one_one(C))),T4)
                & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),T4),aa(int,C,ring_1_of_int(C),I2)) )
             => aa(int,$o,Pa,I2) ) ) ) ).

% ceiling_split
tff(fact_2929_ceiling__eq__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,A3: int] :
          ( ( archimedean_ceiling(C,X) = A3 )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(int,C,ring_1_of_int(C),A3),one_one(C))),X)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(int,C,ring_1_of_int(C),A3)) ) ) ) ).

% ceiling_eq_iff
tff(fact_2930_ceiling__unique,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Z2: int,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(int,C,ring_1_of_int(C),Z2),one_one(C))),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(int,C,ring_1_of_int(C),Z2))
           => ( archimedean_ceiling(C,X) = Z2 ) ) ) ) ).

% ceiling_unique
tff(fact_2931_ceiling__correct,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(int,C,ring_1_of_int(C),archimedean_ceiling(C,X)),one_one(C))),X)
          & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),aa(int,C,ring_1_of_int(C),archimedean_ceiling(C,X))) ) ) ).

% ceiling_correct
tff(fact_2932_ceiling__less__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,Z2: int] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(C,X)),Z2)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),minus_minus(C,aa(int,C,ring_1_of_int(C),Z2),one_one(C))) ) ) ).

% ceiling_less_iff
tff(fact_2933_le__ceiling__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Z2: int,X: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Z2),archimedean_ceiling(C,X))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,aa(int,C,ring_1_of_int(C),Z2),one_one(C))),X) ) ) ).

% le_ceiling_iff
tff(fact_2934_ceiling__divide__upper,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [Q2: C,P3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),Q2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),P3),aa(C,C,aa(C,fun(C,C),times_times(C),aa(int,C,ring_1_of_int(C),archimedean_ceiling(C,divide_divide(C,P3,Q2)))),Q2)) ) ) ).

% ceiling_divide_upper
tff(fact_2935_of__int__1__less__iff,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(int,C,ring_1_of_int(C),Z2))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),one_one(int)),Z2) ) ) ).

% of_int_1_less_iff
tff(fact_2936_of__int__less__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(int,C,ring_1_of_int(C),Z2)),one_one(C))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z2),one_one(int)) ) ) ).

% of_int_less_1_iff
tff(fact_2937_of__int__1__le__iff,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(int,C,ring_1_of_int(C),Z2))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),one_one(int)),Z2) ) ) ).

% of_int_1_le_iff
tff(fact_2938_of__int__le__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [Z2: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(int,C,ring_1_of_int(C),Z2)),one_one(C))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Z2),one_one(int)) ) ) ).

% of_int_le_1_iff
tff(fact_2939_of__int__mult,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [W: int,Z2: int] : aa(int,C,ring_1_of_int(C),aa(int,int,aa(int,fun(int,int),times_times(int),W),Z2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(int,C,ring_1_of_int(C),W)),aa(int,C,ring_1_of_int(C),Z2)) ) ).

% of_int_mult
tff(fact_2940_of__int__1,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ( aa(int,C,ring_1_of_int(C),one_one(int)) = one_one(C) ) ) ).

% of_int_1
tff(fact_2941_of__int__eq__1__iff,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ! [Z2: int] :
          ( ( aa(int,C,ring_1_of_int(C),Z2) = one_one(C) )
        <=> ( Z2 = one_one(int) ) ) ) ).

% of_int_eq_1_iff
tff(fact_2942_mult__of__int__commute,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [X: int,Y: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(int,C,ring_1_of_int(C),X)),Y) = aa(C,C,aa(C,fun(C,C),times_times(C),Y),aa(int,C,ring_1_of_int(C),X)) ) ).

% mult_of_int_commute
tff(fact_2943_round__unique,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,Y: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,X,divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))))),aa(int,C,ring_1_of_int(C),Y))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(int,C,ring_1_of_int(C),Y)),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2)))))
           => ( archimedean_round(C,X) = Y ) ) ) ) ).

% round_unique
tff(fact_2944_of__int__round__gt,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),minus_minus(C,X,divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))))),aa(int,C,ring_1_of_int(C),archimedean_round(C,X))) ) ).

% of_int_round_gt
tff(fact_2945_of__int__round__ge,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,X,divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))))),aa(int,C,ring_1_of_int(C),archimedean_round(C,X))) ) ).

% of_int_round_ge
tff(fact_2946_of__int__round__le,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(int,C,ring_1_of_int(C),archimedean_round(C,X))),aa(C,C,aa(C,fun(C,C),plus_plus(C),X),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))))) ) ).

% of_int_round_le
tff(fact_2947_round__def,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : archimedean_round(C,X) = archim6421214686448440834_floor(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))))) ) ).

% round_def
tff(fact_2948_round__1,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ( archimedean_round(C,one_one(C)) = one_one(int) ) ) ).

% round_1
tff(fact_2949_round__altdef,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          archimedean_round(C,X) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2)))),archimedean_frac(C,X)),archimedean_ceiling(C,X),archim6421214686448440834_floor(C,X)) ) ).

% round_altdef
tff(fact_2950_upto__aux__rec,axiom,
    ! [I: int,J: int,Js: list(int)] :
      upto_aux(I,J,Js) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less(int),J),I),Js,upto_aux(I,minus_minus(int,J,one_one(int)),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),J),Js))) ).

% upto_aux_rec
tff(fact_2951_round__unique_H,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,N: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),minus_minus(C,X,aa(int,C,ring_1_of_int(C),N)))),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2))))
         => ( archimedean_round(C,X) = N ) ) ) ).

% round_unique'
tff(fact_2952_of__int__round__abs__le,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,aa(int,C,ring_1_of_int(C),archimedean_round(C,X)),X))),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2)))) ) ).

% of_int_round_abs_le
tff(fact_2953_floor__add,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,Y: C] :
          archim6421214686448440834_floor(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y)) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),archimedean_frac(C,X)),archimedean_frac(C,Y))),one_one(C)),aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(C,X)),archim6421214686448440834_floor(C,Y)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(C,X)),archim6421214686448440834_floor(C,Y))),one_one(int))) ) ).

% floor_add
tff(fact_2954_abs__idempotent,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : aa(C,C,abs_abs(C),aa(C,C,abs_abs(C),A3)) = aa(C,C,abs_abs(C),A3) ) ).

% abs_idempotent
tff(fact_2955_abs__0__eq,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( ( zero_zero(C) = aa(C,C,abs_abs(C),A3) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% abs_0_eq
tff(fact_2956_abs__eq__0,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( ( aa(C,C,abs_abs(C),A3) = zero_zero(C) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% abs_eq_0
tff(fact_2957_abs__zero,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ( aa(C,C,abs_abs(C),zero_zero(C)) = zero_zero(C) ) ) ).

% abs_zero
tff(fact_2958_abs__add__abs,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,C,abs_abs(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2)) ) ).

% abs_add_abs
tff(fact_2959_abs__mult__self__eq,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),A3)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),A3) ) ).

% abs_mult_self_eq
tff(fact_2960_abs__1,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ( aa(C,C,abs_abs(C),one_one(C)) = one_one(C) ) ) ).

% abs_1
tff(fact_2961_abs__minus__cancel,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : aa(C,C,abs_abs(C),aa(C,C,uminus_uminus(C),A3)) = aa(C,C,abs_abs(C),A3) ) ).

% abs_minus_cancel
tff(fact_2962_abs__le__zero__iff,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),A3)),zero_zero(C))
        <=> ( A3 = zero_zero(C) ) ) ) ).

% abs_le_zero_iff
tff(fact_2963_abs__le__self__iff,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),A3)),A3)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3) ) ) ).

% abs_le_self_iff
tff(fact_2964_abs__of__nonneg,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( aa(C,C,abs_abs(C),A3) = A3 ) ) ) ).

% abs_of_nonneg
tff(fact_2965_zero__less__abs__iff,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,abs_abs(C),A3))
        <=> ( A3 != zero_zero(C) ) ) ) ).

% zero_less_abs_iff
tff(fact_2966_abs__neg__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ( aa(C,C,abs_abs(C),aa(C,C,uminus_uminus(C),one_one(C))) = one_one(C) ) ) ).

% abs_neg_one
tff(fact_2967_abs__of__nonpos,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C))
         => ( aa(C,C,abs_abs(C),A3) = aa(C,C,uminus_uminus(C),A3) ) ) ) ).

% abs_of_nonpos
tff(fact_2968_abs__minus__commute,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,C,abs_abs(C),minus_minus(C,A3,B2)) = aa(C,C,abs_abs(C),minus_minus(C,B2,A3)) ) ).

% abs_minus_commute
tff(fact_2969_abs__one,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ( aa(C,C,abs_abs(C),one_one(C)) = one_one(C) ) ) ).

% abs_one
tff(fact_2970_abs__mult,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ! [A3: C,B2: C] : aa(C,C,abs_abs(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2)) ) ).

% abs_mult
tff(fact_2971_abs__le__D1,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),A3)),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% abs_le_D1
tff(fact_2972_abs__ge__self,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(C,C,abs_abs(C),A3)) ) ).

% abs_ge_self
tff(fact_2973_abs__ge__zero,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(C,C,abs_abs(C),A3)) ) ).

% abs_ge_zero
tff(fact_2974_abs__of__pos,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,C,abs_abs(C),A3) = A3 ) ) ) ).

% abs_of_pos
tff(fact_2975_abs__not__less__zero,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),A3)),zero_zero(C)) ) ).

% abs_not_less_zero
tff(fact_2976_abs__triangle__ineq,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2))),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2))) ) ).

% abs_triangle_ineq
tff(fact_2977_abs__triangle__ineq2__sym,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,aa(C,C,abs_abs(C),A3),aa(C,C,abs_abs(C),B2))),aa(C,C,abs_abs(C),minus_minus(C,B2,A3))) ) ).

% abs_triangle_ineq2_sym
tff(fact_2978_abs__triangle__ineq3,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,aa(C,C,abs_abs(C),A3),aa(C,C,abs_abs(C),B2)))),aa(C,C,abs_abs(C),minus_minus(C,A3,B2))) ) ).

% abs_triangle_ineq3
tff(fact_2979_abs__triangle__ineq2,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),minus_minus(C,aa(C,C,abs_abs(C),A3),aa(C,C,abs_abs(C),B2))),aa(C,C,abs_abs(C),minus_minus(C,A3,B2))) ) ).

% abs_triangle_ineq2
tff(fact_2980_abs__mult__less,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C,C3: C,B2: C,D3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),A3)),C3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),B2)),D3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2))),aa(C,C,aa(C,fun(C,C),times_times(C),C3),D3)) ) ) ) ).

% abs_mult_less
tff(fact_2981_abs__ge__minus__self,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),aa(C,C,abs_abs(C),A3)) ) ).

% abs_ge_minus_self
tff(fact_2982_abs__le__iff,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),A3)),B2)
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),B2) ) ) ) ).

% abs_le_iff
tff(fact_2983_abs__le__D2,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),A3)),B2)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),B2) ) ) ).

% abs_le_D2
tff(fact_2984_abs__leI,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),A3)),B2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),A3)),B2) ) ) ) ).

% abs_leI
tff(fact_2985_frac__lt__1,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),archimedean_frac(C,X)),one_one(C)) ) ).

% frac_lt_1
tff(fact_2986_frac__1__eq,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] : archimedean_frac(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),one_one(C))) = archimedean_frac(C,X) ) ).

% frac_1_eq
tff(fact_2987_dense__eq0__I,axiom,
    ! [C: $tType] :
      ( ( ordere166539214618696060dd_abs(C)
        & dense_linorder(C) )
     => ! [X: C] :
          ( ! [E: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),E)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),X)),E) )
         => ( X = zero_zero(C) ) ) ) ).

% dense_eq0_I
tff(fact_2988_abs__mult__pos,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C,Y: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,abs_abs(C),Y)),X) = aa(C,C,abs_abs(C),aa(C,C,aa(C,fun(C,C),times_times(C),Y),X)) ) ) ) ).

% abs_mult_pos
tff(fact_2989_abs__eq__mult,axiom,
    ! [C: $tType] :
      ( ordered_ring_abs(C)
     => ! [A3: C,B2: C] :
          ( ( ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
              | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),zero_zero(C)) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),B2)
              | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),zero_zero(C)) ) )
         => ( aa(C,C,abs_abs(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2)) ) ) ) ).

% abs_eq_mult
tff(fact_2990_abs__minus__le__zero,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),aa(C,C,abs_abs(C),A3))),zero_zero(C)) ) ).

% abs_minus_le_zero
tff(fact_2991_abs__diff__triangle__ineq,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C,C3: C,D3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),aa(C,C,aa(C,fun(C,C),plus_plus(C),C3),D3)))),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,abs_abs(C),minus_minus(C,A3,C3))),aa(C,C,abs_abs(C),minus_minus(C,B2,D3)))) ) ).

% abs_diff_triangle_ineq
tff(fact_2992_abs__triangle__ineq4,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C,B2: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,A3,B2))),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,abs_abs(C),A3)),aa(C,C,abs_abs(C),B2))) ) ).

% abs_triangle_ineq4
tff(fact_2993_abs__of__neg,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( aa(C,C,abs_abs(C),A3) = aa(C,C,uminus_uminus(C),A3) ) ) ) ).

% abs_of_neg
tff(fact_2994_cSup__abs__le,axiom,
    ! [C: $tType] :
      ( ( condit6923001295902523014norder(C)
        & linordered_idom(C) )
     => ! [S: set(C),A3: C] :
          ( ( S != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,S)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),X2)),A3) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),aa(set(C),C,complete_Sup_Sup(C),S))),A3) ) ) ) ).

% cSup_abs_le
tff(fact_2995_abs__add__one__gt__zero,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] : aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),aa(C,C,abs_abs(C),X))) ) ).

% abs_add_one_gt_zero
tff(fact_2996_cSup__asclose,axiom,
    ! [C: $tType] :
      ( ( condit6923001295902523014norder(C)
        & linordered_idom(C) )
     => ! [S: set(C),La: C,E4: C] :
          ( ( S != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,S)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,X2,La))),E4) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,aa(set(C),C,complete_Sup_Sup(C),S),La))),E4) ) ) ) ).

% cSup_asclose
tff(fact_2997_of__int__leD,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [N: int,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),aa(int,C,ring_1_of_int(C),N))),X)
         => ( ( N = zero_zero(int) )
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),X) ) ) ) ).

% of_int_leD
tff(fact_2998_of__int__lessD,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [N: int,X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),aa(int,C,ring_1_of_int(C),N))),X)
         => ( ( N = zero_zero(int) )
            | aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),X) ) ) ) ).

% of_int_lessD
tff(fact_2999_abs__square__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          ( ( aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(one2))) = one_one(C) )
        <=> ( aa(C,C,abs_abs(C),X) = one_one(C) ) ) ) ).

% abs_square_eq_1
tff(fact_3000_frac__eq,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          ( ( archimedean_frac(C,X) = X )
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),one_one(C)) ) ) ) ).

% frac_eq
tff(fact_3001_frac__add,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,Y: C] :
          archimedean_frac(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),X),Y)) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),archimedean_frac(C,X)),archimedean_frac(C,Y))),one_one(C)),aa(C,C,aa(C,fun(C,C),plus_plus(C),archimedean_frac(C,X)),archimedean_frac(C,Y)),minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),archimedean_frac(C,X)),archimedean_frac(C,Y)),one_one(C))) ) ).

% frac_add
tff(fact_3002_abs__square__le__1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(one2)))),one_one(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),X)),one_one(C)) ) ) ).

% abs_square_le_1
tff(fact_3003_abs__square__less__1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(num,nat,numeral_numeral(nat),bit0(one2)))),one_one(C))
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),X)),one_one(C)) ) ) ).

% abs_square_less_1
tff(fact_3004_upto__rec__numeral_I2_J,axiom,
    ! [M2: num,N: num] :
      upto(aa(num,int,numeral_numeral(int),M2),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N))) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(num,int,numeral_numeral(int),M2)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N))),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),aa(num,int,numeral_numeral(int),M2)),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(num,int,numeral_numeral(int),M2)),one_one(int)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N)))),nil(int)) ).

% upto_rec_numeral(2)
tff(fact_3005_upto__rec__numeral_I3_J,axiom,
    ! [M2: num,N: num] :
      upto(aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2)),aa(num,int,numeral_numeral(int),N)) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2))),aa(num,int,numeral_numeral(int),N)),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2))),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2))),one_one(int)),aa(num,int,numeral_numeral(int),N))),nil(int)) ).

% upto_rec_numeral(3)
tff(fact_3006_upto__rec__numeral_I4_J,axiom,
    ! [M2: num,N: num] :
      upto(aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N))) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2))),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N))),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2))),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M2))),one_one(int)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N)))),nil(int)) ).

% upto_rec_numeral(4)
tff(fact_3007_upto__rec__numeral_I1_J,axiom,
    ! [M2: num,N: num] :
      upto(aa(num,int,numeral_numeral(int),M2),aa(num,int,numeral_numeral(int),N)) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(num,int,numeral_numeral(int),M2)),aa(num,int,numeral_numeral(int),N)),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),aa(num,int,numeral_numeral(int),M2)),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(num,int,numeral_numeral(int),M2)),one_one(int)),aa(num,int,numeral_numeral(int),N))),nil(int)) ).

% upto_rec_numeral(1)
tff(fact_3008_mult__ceiling__le__Ints,axiom,
    ! [D: $tType,C: $tType] :
      ( ( archim2362893244070406136eiling(C)
        & linordered_idom(D) )
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( member2(C,A3,ring_1_Ints(C))
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(int,D,ring_1_of_int(D),archimedean_ceiling(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)))),aa(int,D,ring_1_of_int(D),aa(int,int,aa(int,fun(int,int),times_times(int),archimedean_ceiling(C,A3)),archimedean_ceiling(C,B2)))) ) ) ) ).

% mult_ceiling_le_Ints
tff(fact_3009_nth__upto,axiom,
    ! [I: int,K: nat,J: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),I),aa(nat,int,semiring_1_of_nat(int),K))),J)
     => ( aa(nat,int,nth(int,upto(I,J)),K) = aa(int,int,aa(int,fun(int,int),plus_plus(int),I),aa(nat,int,semiring_1_of_nat(int),K)) ) ) ).

% nth_upto
tff(fact_3010_upto__Nil,axiom,
    ! [I: int,J: int] :
      ( ( upto(I,J) = nil(int) )
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),J),I) ) ).

% upto_Nil
tff(fact_3011_upto__Nil2,axiom,
    ! [I: int,J: int] :
      ( ( nil(int) = upto(I,J) )
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),J),I) ) ).

% upto_Nil2
tff(fact_3012_upto__empty,axiom,
    ! [J: int,I: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),J),I)
     => ( upto(I,J) = nil(int) ) ) ).

% upto_empty
tff(fact_3013_upto__single,axiom,
    ! [I: int] : upto(I,I) = aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),I),nil(int)) ).

% upto_single
tff(fact_3014_distinct__upto,axiom,
    ! [I: int,J: int] : aa(list(int),$o,distinct(int),upto(I,J)) ).

% distinct_upto
tff(fact_3015_sorted__upto,axiom,
    ! [M2: int,N: int] : sorted_wrt(int,ord_less_eq(int),upto(M2,N)) ).

% sorted_upto
tff(fact_3016_sorted__wrt__upto,axiom,
    ! [I: int,J: int] : sorted_wrt(int,ord_less(int),upto(I,J)) ).

% sorted_wrt_upto
tff(fact_3017_Ints__mult,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => ! [A3: C,B2: C] :
          ( member2(C,A3,ring_1_Ints(C))
         => ( member2(C,B2,ring_1_Ints(C))
           => member2(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),ring_1_Ints(C)) ) ) ) ).

% Ints_mult
tff(fact_3018_Ints__1,axiom,
    ! [C: $tType] :
      ( ring_1(C)
     => member2(C,one_one(C),ring_1_Ints(C)) ) ).

% Ints_1
tff(fact_3019_upto__code,axiom,
    ! [I: int,J: int] : upto(I,J) = upto_aux(I,J,nil(int)) ).

% upto_code
tff(fact_3020_upto__aux__def,axiom,
    ! [I: int,J: int,Js: list(int)] : upto_aux(I,J,Js) = aa(list(int),list(int),aa(list(int),fun(list(int),list(int)),append(int),upto(I,J)),Js) ).

% upto_aux_def
tff(fact_3021_greaterThanAtMost__upto,axiom,
    ! [I: int,J: int] : set_or3652927894154168847AtMost(int,I,J) = aa(list(int),set(int),set2(int),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),I),one_one(int)),J)) ).

% greaterThanAtMost_upto
tff(fact_3022_atLeastLessThan__upto,axiom,
    ! [I: int,J: int] : set_or7035219750837199246ssThan(int,I,J) = aa(list(int),set(int),set2(int),upto(I,minus_minus(int,J,one_one(int)))) ).

% atLeastLessThan_upto
tff(fact_3023_Ints__odd__nonzero,axiom,
    ! [C: $tType] :
      ( ring_char_0(C)
     => ! [A3: C] :
          ( member2(C,A3,ring_1_Ints(C))
         => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),A3)),A3) != zero_zero(C) ) ) ) ).

% Ints_odd_nonzero
tff(fact_3024_upto__split2,axiom,
    ! [I: int,J: int,K: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),J),K)
       => ( upto(I,K) = aa(list(int),list(int),aa(list(int),fun(list(int),list(int)),append(int),upto(I,J)),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),J),one_one(int)),K)) ) ) ) ).

% upto_split2
tff(fact_3025_upto__split1,axiom,
    ! [I: int,J: int,K: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),J),K)
       => ( upto(I,K) = aa(list(int),list(int),aa(list(int),fun(list(int),list(int)),append(int),upto(I,minus_minus(int,J,one_one(int)))),upto(J,K)) ) ) ) ).

% upto_split1
tff(fact_3026_greaterThanLessThan__upto,axiom,
    ! [I: int,J: int] : set_or5935395276787703475ssThan(int,I,J) = aa(list(int),set(int),set2(int),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),I),one_one(int)),minus_minus(int,J,one_one(int)))) ).

% greaterThanLessThan_upto
tff(fact_3027_Ints__odd__less__0,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          ( member2(C,A3,ring_1_Ints(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),one_one(C)),A3)),A3)),zero_zero(C))
          <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ) ).

% Ints_odd_less_0
tff(fact_3028_Ints__nonzero__abs__ge1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          ( member2(C,X,ring_1_Ints(C))
         => ( ( X != zero_zero(C) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(C,C,abs_abs(C),X)) ) ) ) ).

% Ints_nonzero_abs_ge1
tff(fact_3029_Ints__nonzero__abs__less1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          ( member2(C,X,ring_1_Ints(C))
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),X)),one_one(C))
           => ( X = zero_zero(C) ) ) ) ) ).

% Ints_nonzero_abs_less1
tff(fact_3030_Ints__eq__abs__less1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C,Y: C] :
          ( member2(C,X,ring_1_Ints(C))
         => ( member2(C,Y,ring_1_Ints(C))
           => ( ( X = Y )
            <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(C,C,abs_abs(C),minus_minus(C,X,Y))),one_one(C)) ) ) ) ) ).

% Ints_eq_abs_less1
tff(fact_3031_upto_Osimps,axiom,
    ! [I: int,J: int] :
      upto(I,J) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),I),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),I),one_one(int)),J)),nil(int)) ).

% upto.simps
tff(fact_3032_upto_Oelims,axiom,
    ! [X: int,Xa: int,Y: list(int)] :
      ( ( upto(X,Xa) = Y )
     => ( Y = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X),Xa),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),X),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),X),one_one(int)),Xa)),nil(int)) ) ) ).

% upto.elims
tff(fact_3033_upto__rec1,axiom,
    ! [I: int,J: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J)
     => ( upto(I,J) = aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),I),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),I),one_one(int)),J)) ) ) ).

% upto_rec1
tff(fact_3034_upto__rec2,axiom,
    ! [I: int,J: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J)
     => ( upto(I,J) = aa(list(int),list(int),aa(list(int),fun(list(int),list(int)),append(int),upto(I,minus_minus(int,J,one_one(int)))),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),J),nil(int))) ) ) ).

% upto_rec2
tff(fact_3035_frac__neg,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C] :
          archimedean_frac(C,aa(C,C,uminus_uminus(C),X)) = $ite(member2(C,X,ring_1_Ints(C)),zero_zero(C),minus_minus(C,one_one(C),archimedean_frac(C,X))) ) ).

% frac_neg
tff(fact_3036_upto__split3,axiom,
    ! [I: int,J: int,K: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),J),K)
       => ( upto(I,K) = aa(list(int),list(int),aa(list(int),fun(list(int),list(int)),append(int),upto(I,minus_minus(int,J,one_one(int)))),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),J),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),J),one_one(int)),K))) ) ) ) ).

% upto_split3
tff(fact_3037_frac__unique__iff,axiom,
    ! [C: $tType] :
      ( archim2362893244070406136eiling(C)
     => ! [X: C,A3: C] :
          ( ( archimedean_frac(C,X) = A3 )
        <=> ( member2(C,minus_minus(C,X,A3),ring_1_Ints(C))
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C)) ) ) ) ).

% frac_unique_iff
tff(fact_3038_le__mult__floor__Ints,axiom,
    ! [D: $tType,C: $tType] :
      ( ( archim2362893244070406136eiling(C)
        & linordered_idom(D) )
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => ( member2(C,A3,ring_1_Ints(C))
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(int,D,ring_1_of_int(D),aa(int,int,aa(int,fun(int,int),times_times(int),archim6421214686448440834_floor(C,A3)),archim6421214686448440834_floor(C,B2)))),aa(int,D,ring_1_of_int(D),archim6421214686448440834_floor(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)))) ) ) ) ).

% le_mult_floor_Ints
tff(fact_3039_fact__split,axiom,
    ! [C: $tType] :
      ( semiring_char_0(C)
     => ! [K: nat,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N)
         => ( semiring_char_0_fact(C,N) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),suc),set_or7035219750837199246ssThan(nat,minus_minus(nat,N,K),N)))),semiring_char_0_fact(C,minus_minus(nat,N,K))) ) ) ) ).

% fact_split
tff(fact_3040_listrel__iff__nth,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs),Ys),listrel(C,D,R3))
    <=> ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
        & ! [N3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(C),nat,size_size(list(C)),Xs))
           => member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(nat,C,nth(C,Xs),N3)),aa(nat,D,nth(D,Ys),N3)),R3) ) ) ) ).

% listrel_iff_nth
tff(fact_3041_fact__binomial,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),semiring_char_0_fact(C,K)),aa(nat,C,semiring_1_of_nat(C),binomial(N,K))) = divide_divide(C,semiring_char_0_fact(C,N),semiring_char_0_fact(C,minus_minus(nat,N,K))) ) ) ) ).

% fact_binomial
tff(fact_3042_binomial__fact,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N)
         => ( aa(nat,C,semiring_1_of_nat(C),binomial(N,K)) = divide_divide(C,semiring_char_0_fact(C,N),aa(C,C,aa(C,fun(C,C),times_times(C),semiring_char_0_fact(C,K)),semiring_char_0_fact(C,minus_minus(nat,N,K)))) ) ) ) ).

% binomial_fact
tff(fact_3043_in__measures_I2_J,axiom,
    ! [C: $tType,X: C,Y: C,F: fun(C,nat),Fs: list(fun(C,nat))] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),measures(C,aa(list(fun(C,nat)),list(fun(C,nat)),aa(fun(C,nat),fun(list(fun(C,nat)),list(fun(C,nat))),cons(fun(C,nat)),F),Fs)))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(C,nat,F,X)),aa(C,nat,F,Y))
        | ( ( aa(C,nat,F,X) = aa(C,nat,F,Y) )
          & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),measures(C,Fs)) ) ) ) ).

% in_measures(2)
tff(fact_3044_in__measures_I1_J,axiom,
    ! [C: $tType,X: C,Y: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),measures(C,nil(fun(C,nat)))) ).

% in_measures(1)
tff(fact_3045_prod_OatMost__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_atMost(nat,aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_atMost(nat,N))),aa(nat,C,G,aa(nat,nat,suc,N))) ) ).

% prod.atMost_Suc
tff(fact_3046_prod_OlessThan__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_lessThan(nat,aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_lessThan(nat,N))),aa(nat,C,G,N)) ) ).

% prod.lessThan_Suc
tff(fact_3047_prod_Oop__ivl__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),M2: nat,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2),one_one(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,N))),aa(nat,C,G,N))) ) ).

% prod.op_ivl_Suc
tff(fact_3048_listrel__Nil2,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs),nil(D)),listrel(C,D,R3))
     => ( Xs = nil(C) ) ) ).

% listrel_Nil2
tff(fact_3049_listrel__Nil1,axiom,
    ! [C: $tType,D: $tType,Xs: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),Xs),listrel(C,D,R3))
     => ( Xs = nil(D) ) ) ).

% listrel_Nil1
tff(fact_3050_listrel_ONil,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,D))] : member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)),listrel(C,D,R3)) ).

% listrel.Nil
tff(fact_3051_listrel__eq__len,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs),Ys),listrel(C,D,R3))
     => ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) ) ) ).

% listrel_eq_len
tff(fact_3052_prod_OatLeastLessThan__concat,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,P3: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),P3)
           => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,N))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,N,P3))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,P3)) ) ) ) ) ).

% prod.atLeastLessThan_concat
tff(fact_3053_listrel__mono,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,D)),S4: set(product_prod(C,D))] :
      ( aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),ord_less_eq(set(product_prod(C,D))),R3),S4)
     => aa(set(product_prod(list(C),list(D))),$o,aa(set(product_prod(list(C),list(D))),fun(set(product_prod(list(C),list(D))),$o),ord_less_eq(set(product_prod(list(C),list(D)))),listrel(C,D,R3)),listrel(C,D,S4)) ) ).

% listrel_mono
tff(fact_3054_listrel_OCons,axiom,
    ! [D: $tType,C: $tType,X: C,Y: D,R3: set(product_prod(C,D)),Xs: list(C),Ys: list(D)] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),R3)
     => ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs),Ys),listrel(C,D,R3))
       => member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys)),listrel(C,D,R3)) ) ) ).

% listrel.Cons
tff(fact_3055_listrel__Cons1,axiom,
    ! [D: $tType,C: $tType,Y: C,Ys: list(C),Xs: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),Xs),listrel(C,D,R3))
     => ~ ! [Y2: D,Ys2: list(D)] :
            ( ( Xs = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2) )
           => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Y),Y2),R3)
             => ~ member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Ys),Ys2),listrel(C,D,R3)) ) ) ) ).

% listrel_Cons1
tff(fact_3056_listrel__Cons2,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Y: D,Ys: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys)),listrel(C,D,R3))
     => ~ ! [X2: C,Xs2: list(C)] :
            ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
           => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X2),Y),R3)
             => ~ member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs2),Ys),listrel(C,D,R3)) ) ) ) ).

% listrel_Cons2
tff(fact_3057_prod_OatLeast0__lessThan__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))),aa(nat,C,G,N)) ) ).

% prod.atLeast0_lessThan_Suc
tff(fact_3058_prod_OatLeast__Suc__lessThan,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M2),N)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,M2)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M2),N))) ) ) ) ).

% prod.atLeast_Suc_lessThan
tff(fact_3059_prod_OatLeastLessThan__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A3: nat,B2: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),B2)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,A3,aa(nat,nat,suc,B2))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,A3,B2))),aa(nat,C,G,B2)) ) ) ) ).

% prod.atLeastLessThan_Suc
tff(fact_3060_measures__less,axiom,
    ! [C: $tType,F: fun(C,nat),X: C,Y: C,Fs: list(fun(C,nat))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(C,nat,F,X)),aa(C,nat,F,Y))
     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),measures(C,aa(list(fun(C,nat)),list(fun(C,nat)),aa(fun(C,nat),fun(list(fun(C,nat)),list(fun(C,nat))),cons(fun(C,nat)),F),Fs))) ) ).

% measures_less
tff(fact_3061_measures__lesseq,axiom,
    ! [C: $tType,F: fun(C,nat),X: C,Y: C,Fs: list(fun(C,nat))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(C,nat,F,X)),aa(C,nat,F,Y))
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),measures(C,Fs))
       => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),measures(C,aa(list(fun(C,nat)),list(fun(C,nat)),aa(fun(C,nat),fun(list(fun(C,nat)),list(fun(C,nat))),cons(fun(C,nat)),F),Fs))) ) ) ).

% measures_lesseq
tff(fact_3062_listrel_Ocases,axiom,
    ! [D: $tType,C: $tType,A1: list(C),A22: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),A1),A22),listrel(C,D,R3))
     => ( ( ( A1 = nil(C) )
         => ( A22 != nil(D) ) )
       => ~ ! [X2: C,Y2: D,Xs2: list(C)] :
              ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
             => ! [Ys2: list(D)] :
                  ( ( A22 = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2) )
                 => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X2),Y2),R3)
                   => ~ member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs2),Ys2),listrel(C,D,R3)) ) ) ) ) ) ).

% listrel.cases
tff(fact_3063_listrel_Osimps,axiom,
    ! [D: $tType,C: $tType,A1: list(C),A22: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),A1),A22),listrel(C,D,R3))
    <=> ( ( ( A1 = nil(C) )
          & ( A22 = nil(D) ) )
        | ? [X4: C,Y3: D,Xs3: list(C),Ys3: list(D)] :
            ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( A22 = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y3),Ys3) )
            & member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X4),Y3),R3)
            & member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs3),Ys3),listrel(C,D,R3)) ) ) ) ).

% listrel.simps
tff(fact_3064_prod_Oinsert,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),X: C,G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ~ member2(C,X,A4)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,G,X)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4)) ) ) ) ) ).

% prod.insert
tff(fact_3065_prod_Oinfinite,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D)] :
          ( ~ aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = one_one(D) ) ) ) ).

% prod.infinite
tff(fact_3066_prod_Oempty,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),G),bot_bot(set(D))) = one_one(C) ) ).

% prod.empty
tff(fact_3067_prod__Un,axiom,
    ! [D: $tType,C: $tType] :
      ( field(D)
     => ! [A4: set(C),B3: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( ! [X2: C] :
                  ( member2(C,X2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
                 => ( aa(C,D,F,X2) != zero_zero(D) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = divide_divide(D,aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),B3)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ) ) ).

% prod_Un
tff(fact_3068_prod__diff1,axiom,
    ! [D: $tType,C: $tType] :
      ( semidom_divide(D)
     => ! [A4: set(C),F: fun(C,D),A3: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( aa(C,D,F,A3) != zero_zero(D) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = $ite(member2(C,A3,A4),divide_divide(D,aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4),aa(C,D,F,A3)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)) ) ) ) ) ).

% prod_diff1
tff(fact_3069_prod_Onot__neutral__contains__not__neutral,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),A4: set(D)] :
          ( ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),G),A4) != one_one(C) )
         => ~ ! [A5: D] :
                ( member2(D,A5,A4)
               => ( aa(D,C,G,A5) = one_one(C) ) ) ) ) ).

% prod.not_neutral_contains_not_neutral
tff(fact_3070_prod_Oneutral,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D)] :
          ( ! [X2: C] :
              ( member2(C,X2,A4)
             => ( aa(C,D,G,X2) = one_one(D) ) )
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = one_one(D) ) ) ) ).

% prod.neutral
tff(fact_3071_prod__ge__1,axiom,
    ! [D: $tType,C: $tType] :
      ( linord181362715937106298miring(D)
     => ! [A4: set(C),F: fun(C,D)] :
          ( ! [X2: C] :
              ( member2(C,X2,A4)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),one_one(D)),aa(C,D,F,X2)) )
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),one_one(D)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)) ) ) ).

% prod_ge_1
tff(fact_3072_prod__le__1,axiom,
    ! [C: $tType,D: $tType] :
      ( linord181362715937106298miring(D)
     => ! [A4: set(C),F: fun(C,D)] :
          ( ! [X2: C] :
              ( member2(C,X2,A4)
             => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),zero_zero(D)),aa(C,D,F,X2))
                & aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),one_one(D)) ) )
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)),one_one(D)) ) ) ).

% prod_le_1
tff(fact_3073_prod_Orelated,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [R: fun(C,fun(C,$o)),S: set(D),H: fun(D,C),G: fun(D,C)] :
          ( aa(C,$o,aa(C,fun(C,$o),R,one_one(C)),one_one(C))
         => ( ! [X1: C,Y1: C,X23: C,Y23: C] :
                ( ( aa(C,$o,aa(C,fun(C,$o),R,X1),X23)
                  & aa(C,$o,aa(C,fun(C,$o),R,Y1),Y23) )
               => aa(C,$o,aa(C,fun(C,$o),R,aa(C,C,aa(C,fun(C,C),times_times(C),X1),Y1)),aa(C,C,aa(C,fun(C,C),times_times(C),X23),Y23)) )
           => ( aa(set(D),$o,finite_finite2(D),S)
             => ( ! [X2: D] :
                    ( member2(D,X2,S)
                   => aa(C,$o,aa(C,fun(C,$o),R,aa(D,C,H,X2)),aa(D,C,G,X2)) )
               => aa(C,$o,aa(C,fun(C,$o),R,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),H),S)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),G),S)) ) ) ) ) ) ).

% prod.related
tff(fact_3074_prod_Oinsert__if,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = $ite(member2(C,X,A4),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4),aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,G,X)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4))) ) ) ) ).

% prod.insert_if
tff(fact_3075_prod_Oreindex__bij__witness__not__neutral,axiom,
    ! [C: $tType,E2: $tType,D: $tType] :
      ( comm_monoid_mult(E2)
     => ! [S3: set(C),T5: set(D),S: set(C),I: fun(D,C),J: fun(C,D),T: set(D),G: fun(C,E2),H: fun(D,E2)] :
          ( aa(set(C),$o,finite_finite2(C),S3)
         => ( aa(set(D),$o,finite_finite2(D),T5)
           => ( ! [A5: C] :
                  ( member2(C,A5,minus_minus(set(C),S,S3))
                 => ( aa(D,C,I,aa(C,D,J,A5)) = A5 ) )
             => ( ! [A5: C] :
                    ( member2(C,A5,minus_minus(set(C),S,S3))
                   => member2(D,aa(C,D,J,A5),minus_minus(set(D),T,T5)) )
               => ( ! [B4: D] :
                      ( member2(D,B4,minus_minus(set(D),T,T5))
                     => ( aa(C,D,J,aa(D,C,I,B4)) = B4 ) )
                 => ( ! [B4: D] :
                        ( member2(D,B4,minus_minus(set(D),T,T5))
                       => member2(C,aa(D,C,I,B4),minus_minus(set(C),S,S3)) )
                   => ( ! [A5: C] :
                          ( member2(C,A5,S3)
                         => ( aa(C,E2,G,A5) = one_one(E2) ) )
                     => ( ! [B4: D] :
                            ( member2(D,B4,T5)
                           => ( aa(D,E2,H,B4) = one_one(E2) ) )
                       => ( ! [A5: C] :
                              ( member2(C,A5,S)
                             => ( aa(D,E2,H,aa(C,D,J,A5)) = aa(C,E2,G,A5) ) )
                         => ( aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7121269368397514597t_prod(C,E2),G),S) = aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7121269368397514597t_prod(D,E2),H),T) ) ) ) ) ) ) ) ) ) ) ) ).

% prod.reindex_bij_witness_not_neutral
tff(fact_3076_less__1__prod2,axiom,
    ! [D: $tType,C: $tType] :
      ( linordered_idom(D)
     => ! [I5: set(C),I: C,F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),I5)
         => ( member2(C,I,I5)
           => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),one_one(D)),aa(C,D,F,I))
             => ( ! [I3: C] :
                    ( member2(C,I3,I5)
                   => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),one_one(D)),aa(C,D,F,I3)) )
               => aa(D,$o,aa(D,fun(D,$o),ord_less(D),one_one(D)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),I5)) ) ) ) ) ) ).

% less_1_prod2
tff(fact_3077_less__1__prod,axiom,
    ! [D: $tType,C: $tType] :
      ( linordered_idom(D)
     => ! [I5: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),I5)
         => ( ( I5 != bot_bot(set(C)) )
           => ( ! [I3: C] :
                  ( member2(C,I3,I5)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less(D),one_one(D)),aa(C,D,F,I3)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),one_one(D)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),I5)) ) ) ) ) ).

% less_1_prod
tff(fact_3078_prod_Osubset__diff,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [B3: set(C),A4: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),A4,B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),B3)) ) ) ) ) ).

% prod.subset_diff
tff(fact_3079_prod_Omono__neutral__cong__right,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [T: set(C),S: set(C),G: fun(C,D),H: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),T)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
           => ( ! [X2: C] :
                  ( member2(C,X2,minus_minus(set(C),T,S))
                 => ( aa(C,D,G,X2) = one_one(D) ) )
             => ( ! [X2: C] :
                    ( member2(C,X2,S)
                   => ( aa(C,D,G,X2) = aa(C,D,H,X2) ) )
               => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),T) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),S) ) ) ) ) ) ) ).

% prod.mono_neutral_cong_right
tff(fact_3080_prod_Omono__neutral__cong__left,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [T: set(C),S: set(C),H: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),T)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
           => ( ! [X2: C] :
                  ( member2(C,X2,minus_minus(set(C),T,S))
                 => ( aa(C,D,H,X2) = one_one(D) ) )
             => ( ! [X2: C] :
                    ( member2(C,X2,S)
                   => ( aa(C,D,G,X2) = aa(C,D,H,X2) ) )
               => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),S) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),T) ) ) ) ) ) ) ).

% prod.mono_neutral_cong_left
tff(fact_3081_prod_Omono__neutral__right,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [T: set(C),S: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),T)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
           => ( ! [X2: C] :
                  ( member2(C,X2,minus_minus(set(C),T,S))
                 => ( aa(C,D,G,X2) = one_one(D) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),T) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),S) ) ) ) ) ) ).

% prod.mono_neutral_right
tff(fact_3082_prod_Omono__neutral__left,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [T: set(C),S: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),T)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
           => ( ! [X2: C] :
                  ( member2(C,X2,minus_minus(set(C),T,S))
                 => ( aa(C,D,G,X2) = one_one(D) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),S) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),T) ) ) ) ) ) ).

% prod.mono_neutral_left
tff(fact_3083_prod_Osame__carrierI,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [C4: set(C),A4: set(C),B3: set(C),G: fun(C,D),H: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),C4)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
             => ( ! [A5: C] :
                    ( member2(C,A5,minus_minus(set(C),C4,A4))
                   => ( aa(C,D,G,A5) = one_one(D) ) )
               => ( ! [B4: C] :
                      ( member2(C,B4,minus_minus(set(C),C4,B3))
                     => ( aa(C,D,H,B4) = one_one(D) ) )
                 => ( ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),C4) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),C4) )
                   => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),B3) ) ) ) ) ) ) ) ) ).

% prod.same_carrierI
tff(fact_3084_prod_Osame__carrier,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [C4: set(C),A4: set(C),B3: set(C),G: fun(C,D),H: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),C4)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),C4)
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),C4)
             => ( ! [A5: C] :
                    ( member2(C,A5,minus_minus(set(C),C4,A4))
                   => ( aa(C,D,G,A5) = one_one(D) ) )
               => ( ! [B4: C] :
                      ( member2(C,B4,minus_minus(set(C),C4,B3))
                     => ( aa(C,D,H,B4) = one_one(D) ) )
                 => ( ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),B3) )
                  <=> ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),C4) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),C4) ) ) ) ) ) ) ) ) ).

% prod.same_carrier
tff(fact_3085_prod_Ounion__inter,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),B3)) ) ) ) ) ).

% prod.union_inter
tff(fact_3086_prod_OInt__Diff,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),A4,B3))) ) ) ) ).

% prod.Int_Diff
tff(fact_3087_prod_Omono__neutral__cong,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [T: set(C),S: set(C),H: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),T)
         => ( aa(set(C),$o,finite_finite2(C),S)
           => ( ! [I3: C] :
                  ( member2(C,I3,minus_minus(set(C),T,S))
                 => ( aa(C,D,H,I3) = one_one(D) ) )
             => ( ! [I3: C] :
                    ( member2(C,I3,minus_minus(set(C),S,T))
                   => ( aa(C,D,G,I3) = one_one(D) ) )
               => ( ! [X2: C] :
                      ( member2(C,X2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),T))
                     => ( aa(C,D,G,X2) = aa(C,D,H,X2) ) )
                 => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),S) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),T) ) ) ) ) ) ) ) ).

% prod.mono_neutral_cong
tff(fact_3088_prod__mono__strict,axiom,
    ! [D: $tType,C: $tType] :
      ( linordered_semidom(D)
     => ! [A4: set(C),F: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ! [I3: C] :
                ( member2(C,I3,A4)
               => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),zero_zero(D)),aa(C,D,F,I3))
                  & aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,I3)),aa(C,D,G,I3)) ) )
           => ( ( A4 != bot_bot(set(C)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4)) ) ) ) ) ).

% prod_mono_strict
tff(fact_3089_prod_Oinsert__remove,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,G,X)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ).

% prod.insert_remove
tff(fact_3090_prod_Oremove,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),X: C,G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,G,X)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ).

% prod.remove
tff(fact_3091_prod_Ounion__inter__neutral,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( ! [X2: C] :
                  ( member2(C,X2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
                 => ( aa(C,D,G,X2) = one_one(D) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),B3)) ) ) ) ) ) ).

% prod.union_inter_neutral
tff(fact_3092_prod_Ounion__disjoint,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),B3)) ) ) ) ) ) ).

% prod.union_disjoint
tff(fact_3093_prod_Ounion__diff2,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),A4,B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),B3,A4)))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ) ).

% prod.union_diff2
tff(fact_3094_prod__mono2,axiom,
    ! [D: $tType,C: $tType] :
      ( linordered_idom(D)
     => ! [B3: set(C),A4: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),B3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
           => ( ! [B4: C] :
                  ( member2(C,B4,minus_minus(set(C),B3,A4))
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),one_one(D)),aa(C,D,F,B4)) )
             => ( ! [A5: C] :
                    ( member2(C,A5,A4)
                   => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),zero_zero(D)),aa(C,D,F,A5)) )
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),B3)) ) ) ) ) ) ).

% prod_mono2
tff(fact_3095_prod__le__power,axiom,
    ! [C: $tType,D: $tType] :
      ( linordered_semidom(D)
     => ! [A4: set(C),F: fun(C,D),N: D,K: nat] :
          ( ! [I3: C] :
              ( member2(C,I3,A4)
             => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),zero_zero(D)),aa(C,D,F,I3))
                & aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,I3)),N) ) )
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(C,A4)),K)
           => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),one_one(D)),N)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),F),A4)),aa(nat,D,aa(D,fun(nat,D),power_power(D),N),K)) ) ) ) ) ).

% prod_le_power
tff(fact_3096_card__disjoint__shuffles,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) )
     => ( finite_card(list(C),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys)) = binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),nat,size_size(list(C)),Ys)),aa(list(C),nat,size_size(list(C)),Xs)) ) ) ).

% card_disjoint_shuffles
tff(fact_3097_prod_Odistinct__set__conv__list,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [Xs: list(C),G: fun(C,D)] :
          ( aa(list(C),$o,distinct(C),Xs)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(list(C),set(C),set2(C),Xs)) = aa(list(D),D,groups5270119922927024881d_list(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Xs)) ) ) ) ).

% prod.distinct_set_conv_list
tff(fact_3098_prod_Ocl__ivl__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),M2: nat,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,N)),M2),one_one(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N))),aa(nat,C,G,aa(nat,nat,suc,N)))) ) ).

% prod.cl_ivl_Suc
tff(fact_3099_refl__on__singleton,axiom,
    ! [C: $tType,X: C] : refl_on(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),X)),bot_bot(set(product_prod(C,C))))) ).

% refl_on_singleton
tff(fact_3100_euclidean__size__times__nonunit,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( ~ dvd_dvd(C,A3,one_one(C))
             => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),euclid6346220572633701492n_size(C,B2)),euclid6346220572633701492n_size(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))) ) ) ) ) ).

% euclidean_size_times_nonunit
tff(fact_3101_Nil__in__shuffles,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( member2(list(C),nil(C),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
    <=> ( ( Xs = nil(C) )
        & ( Ys = nil(C) ) ) ) ).

% Nil_in_shuffles
tff(fact_3102_finite__shuffles,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(set(list(C)),$o,finite_finite2(list(C)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys)) ).

% finite_shuffles
tff(fact_3103_atLeastatMost__empty__iff2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( ( bot_bot(set(C)) = set_or1337092689740270186AtMost(C,A3,B2) )
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% atLeastatMost_empty_iff2
tff(fact_3104_atLeastatMost__empty__iff,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A3: C,B2: C] :
          ( ( set_or1337092689740270186AtMost(C,A3,B2) = bot_bot(set(C)) )
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ).

% atLeastatMost_empty_iff
tff(fact_3105_atLeastatMost__empty,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [B2: C,A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3)
         => ( set_or1337092689740270186AtMost(C,A3,B2) = bot_bot(set(C)) ) ) ) ).

% atLeastatMost_empty
tff(fact_3106_atLeastAtMost__singleton__iff,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( set_or1337092689740270186AtMost(C,A3,B2) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),C3),bot_bot(set(C))) )
        <=> ( ( A3 = B2 )
            & ( B2 = C3 ) ) ) ) ).

% atLeastAtMost_singleton_iff
tff(fact_3107_atLeastAtMost__singleton,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C] : set_or1337092689740270186AtMost(C,A3,A3) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) ) ).

% atLeastAtMost_singleton
tff(fact_3108_euclidean__size__1,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ( euclid6346220572633701492n_size(C,one_one(C)) = one_one(nat) ) ) ).

% euclidean_size_1
tff(fact_3109_prod__list_OCons,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [X: C,Xs: list(C)] : aa(list(C),C,groups5270119922927024881d_list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(C,C,aa(C,fun(C,C),times_times(C),X),aa(list(C),C,groups5270119922927024881d_list(C),Xs)) ) ).

% prod_list.Cons
tff(fact_3110_prod__list_ONil,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ( aa(list(C),C,groups5270119922927024881d_list(C),nil(C)) = one_one(C) ) ) ).

% prod_list.Nil
tff(fact_3111_prod__list_Oappend,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [Xs: list(C),Ys: list(C)] : aa(list(C),C,groups5270119922927024881d_list(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(list(C),C,groups5270119922927024881d_list(C),Xs)),aa(list(C),C,groups5270119922927024881d_list(C),Ys)) ) ).

% prod_list.append
tff(fact_3112_Int__atLeastAtMost,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or1337092689740270186AtMost(C,A3,B2)),set_or1337092689740270186AtMost(C,C3,D3)) = set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3),aa(C,C,aa(C,fun(C,C),ord_min(C),B2),D3)) ) ).

% Int_atLeastAtMost
tff(fact_3113_Int__atLeastAtMostR1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [B2: C,C3: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atMost(C,B2)),set_or1337092689740270186AtMost(C,C3,D3)) = set_or1337092689740270186AtMost(C,C3,aa(C,C,aa(C,fun(C,C),ord_min(C),B2),D3)) ) ).

% Int_atLeastAtMostR1
tff(fact_3114_Int__atLeastAtMostL1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or1337092689740270186AtMost(C,A3,B2)),set_ord_atMost(C,D3)) = set_or1337092689740270186AtMost(C,A3,aa(C,C,aa(C,fun(C,C),ord_min(C),B2),D3)) ) ).

% Int_atLeastAtMostL1
tff(fact_3115_image__mult__atLeastAtMost,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [D3: C,A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),D3)
         => ( aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),times_times(C),D3)),set_or1337092689740270186AtMost(C,A3,B2)) = set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),times_times(C),D3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),D3),B2)) ) ) ) ).

% image_mult_atLeastAtMost
tff(fact_3116_shuffles__commutes,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys) = aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Ys),Xs) ).

% shuffles_commutes
tff(fact_3117_Cons__in__shuffles__rightI,axiom,
    ! [C: $tType,Zs: list(C),Xs: list(C),Ys: list(C),Z2: C] :
      ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
     => member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z2),Zs),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z2),Ys))) ) ).

% Cons_in_shuffles_rightI
tff(fact_3118_Cons__in__shuffles__leftI,axiom,
    ! [C: $tType,Zs: list(C),Xs: list(C),Ys: list(C),Z2: C] :
      ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
     => member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z2),Zs),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z2),Xs)),Ys)) ) ).

% Cons_in_shuffles_leftI
tff(fact_3119_shuffles_Osimps_I2_J,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),nil(C)) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),Xs),bot_bot(set(list(C)))) ).

% shuffles.simps(2)
tff(fact_3120_shuffles_Osimps_I1_J,axiom,
    ! [C: $tType,Ys: list(C)] : aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),nil(C)),Ys) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),Ys),bot_bot(set(list(C)))) ).

% shuffles.simps(1)
tff(fact_3121_Nil__in__shufflesI,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs = nil(C) )
     => ( ( Ys = nil(C) )
       => member2(list(C),nil(C),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys)) ) ) ).

% Nil_in_shufflesI
tff(fact_3122_refl__on__Int,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),B3: set(C),S4: set(product_prod(C,C))] :
      ( refl_on(C,A4,R3)
     => ( refl_on(C,B3,S4)
       => refl_on(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),S4)) ) ) ).

% refl_on_Int
tff(fact_3123_atLeastAtMost__singleton_H,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] :
          ( ( A3 = B2 )
         => ( set_or1337092689740270186AtMost(C,A3,B2) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) ) ) ) ).

% atLeastAtMost_singleton'
tff(fact_3124_all__nat__less,axiom,
    ! [N: nat,Pa: fun(nat,$o)] :
      ( ! [M3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M3),N)
         => aa(nat,$o,Pa,M3) )
    <=> ! [X4: nat] :
          ( member2(nat,X4,set_or1337092689740270186AtMost(nat,zero_zero(nat),N))
         => aa(nat,$o,Pa,X4) ) ) ).

% all_nat_less
tff(fact_3125_ex__nat__less,axiom,
    ! [N: nat,Pa: fun(nat,$o)] :
      ( ? [M3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M3),N)
          & aa(nat,$o,Pa,M3) )
    <=> ? [X4: nat] :
          ( member2(nat,X4,set_or1337092689740270186AtMost(nat,zero_zero(nat),N))
          & aa(nat,$o,Pa,X4) ) ) ).

% ex_nat_less
tff(fact_3126_shufflesE,axiom,
    ! [C: $tType,Zs: list(C),Xs: list(C),Ys: list(C)] :
      ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
     => ( ( ( Zs = Xs )
         => ( Ys != nil(C) ) )
       => ( ( ( Zs = Ys )
           => ( Xs != nil(C) ) )
         => ( ! [X2: C,Xs4: list(C)] :
                ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs4) )
               => ! [Z4: C,Zs4: list(C)] :
                    ( ( Zs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z4),Zs4) )
                   => ( ( X2 = Z4 )
                     => ~ member2(list(C),Zs4,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs4),Ys)) ) ) )
           => ~ ! [Y2: C,Ys4: list(C)] :
                  ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys4) )
                 => ! [Z4: C,Zs4: list(C)] :
                      ( ( Zs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z4),Zs4) )
                     => ( ( Y2 = Z4 )
                       => ~ member2(list(C),Zs4,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys4)) ) ) ) ) ) ) ) ).

% shufflesE
tff(fact_3127_length__shuffles,axiom,
    ! [C: $tType,Zs: list(C),Xs: list(C),Ys: list(C)] :
      ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
     => ( aa(list(C),nat,size_size(list(C)),Zs) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),nat,size_size(list(C)),Ys)) ) ) ).

% length_shuffles
tff(fact_3128_set__shuffles,axiom,
    ! [C: $tType,Zs: list(C),Xs: list(C),Ys: list(C)] :
      ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
     => ( aa(list(C),set(C),set2(C),Zs) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) ) ) ).

% set_shuffles
tff(fact_3129_euclidean__size__unit,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [A3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( euclid6346220572633701492n_size(C,A3) = euclid6346220572633701492n_size(C,one_one(C)) ) ) ) ).

% euclidean_size_unit
tff(fact_3130_euclidean__size__mult,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [A3: C,B2: C] : euclid6346220572633701492n_size(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),euclid6346220572633701492n_size(C,A3)),euclid6346220572633701492n_size(C,B2)) ) ).

% euclidean_size_mult
tff(fact_3131_refl__on__empty,axiom,
    ! [C: $tType] : refl_on(C,bot_bot(set(C)),bot_bot(set(product_prod(C,C)))) ).

% refl_on_empty
tff(fact_3132_shuffles_Osimps_I3_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C,Ys: list(C)] : aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) = aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),sup_sup(set(list(C))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys))) ).

% shuffles.simps(3)
tff(fact_3133_Cons__shuffles__subset1,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] : aa(set(list(C)),$o,aa(set(list(C)),fun(set(list(C)),$o),ord_less_eq(set(list(C))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys)) ).

% Cons_shuffles_subset1
tff(fact_3134_Cons__shuffles__subset2,axiom,
    ! [C: $tType,Y: C,Xs: list(C),Ys: list(C)] : aa(set(list(C)),$o,aa(set(list(C)),fun(set(list(C)),$o),ord_less_eq(set(list(C))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))) ).

% Cons_shuffles_subset2
tff(fact_3135_ivl__disj__int__two_I7_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or7035219750837199246ssThan(C,La,M2)),set_or1337092689740270186AtMost(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(7)
tff(fact_3136_ivl__disj__int__one_I4_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_lessThan(C,La)),set_or1337092689740270186AtMost(C,La,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(4)
tff(fact_3137_ivl__disj__int__two_I8_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or1337092689740270186AtMost(C,La,M2)),set_or3652927894154168847AtMost(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(8)
tff(fact_3138_ivl__disj__int__two_I5_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or5935395276787703475ssThan(C,La,M2)),set_or1337092689740270186AtMost(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(5)
tff(fact_3139_ivl__disj__int__two_I4_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,M2: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or1337092689740270186AtMost(C,La,M2)),set_or5935395276787703475ssThan(C,M2,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_two(4)
tff(fact_3140_unit__iff__euclidean__size,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [A3: C] :
          ( dvd_dvd(C,A3,one_one(C))
        <=> ( ( euclid6346220572633701492n_size(C,A3) = euclid6346220572633701492n_size(C,one_one(C)) )
            & ( A3 != zero_zero(C) ) ) ) ) ).

% unit_iff_euclidean_size
tff(fact_3141_size__mult__mono_H,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),euclid6346220572633701492n_size(C,A3)),euclid6346220572633701492n_size(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3))) ) ) ).

% size_mult_mono'
tff(fact_3142_size__mult__mono,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [B2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),euclid6346220572633701492n_size(C,A3)),euclid6346220572633701492n_size(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))) ) ) ).

% size_mult_mono
tff(fact_3143_euclidean__size__times__unit,axiom,
    ! [C: $tType] :
      ( euclid3725896446679973847miring(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( euclid6346220572633701492n_size(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = euclid6346220572633701492n_size(C,B2) ) ) ) ).

% euclidean_size_times_unit
tff(fact_3144_atLeastAtMost__upt,axiom,
    ! [N: nat,M2: nat] : set_or1337092689740270186AtMost(nat,N,M2) = aa(list(nat),set(nat),set2(nat),upt(N,aa(nat,nat,suc,M2))) ).

% atLeastAtMost_upt
tff(fact_3145_shuffles_Oelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: set(list(C))] :
      ( ( aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),X),Xa) = Y )
     => ( ( ( X = nil(C) )
         => ( Y != aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),Xa),bot_bot(set(list(C)))) ) )
       => ( ( ( Xa = nil(C) )
           => ( Y != aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),X),bot_bot(set(list(C)))) ) )
         => ~ ! [X2: C,Xs2: list(C)] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ! [Y2: C,Ys2: list(C)] :
                    ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                   => ( Y != aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),sup_sup(set(list(C))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2))) ) ) ) ) ) ) ).

% shuffles.elims
tff(fact_3146_atLeastLessThan__eq__atLeastAtMost__diff,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] : set_or7035219750837199246ssThan(C,A3,B2) = minus_minus(set(C),set_or1337092689740270186AtMost(C,A3,B2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) ) ).

% atLeastLessThan_eq_atLeastAtMost_diff
tff(fact_3147_greaterThanAtMost__eq__atLeastAtMost__diff,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [A3: C,B2: C] : set_or3652927894154168847AtMost(C,A3,B2) = minus_minus(set(C),set_or1337092689740270186AtMost(C,A3,B2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ) ).

% greaterThanAtMost_eq_atLeastAtMost_diff
tff(fact_3148_atLeastAtMost__diff__ends,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : minus_minus(set(C),set_or1337092689740270186AtMost(C,A3,B2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) = set_or5935395276787703475ssThan(C,A3,B2) ) ).

% atLeastAtMost_diff_ends
tff(fact_3149_prod_OatLeast0__atMost__Suc,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))),aa(nat,C,G,aa(nat,nat,suc,N))) ) ).

% prod.atLeast0_atMost_Suc
tff(fact_3150_prod_OatLeast__Suc__atMost,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,M2)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M2),N))) ) ) ) ).

% prod.atLeast_Suc_atMost
tff(fact_3151_prod_Onat__ivl__Suc_H,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),aa(nat,nat,suc,N))
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,aa(nat,nat,suc,N))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N))) ) ) ) ).

% prod.nat_ivl_Suc'
tff(fact_3152_prod_Olast__plus,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,N)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,N))) ) ) ) ).

% prod.last_plus
tff(fact_3153_prod_Ohead,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,M2)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or3652927894154168847AtMost(nat,M2,N))) ) ) ) ).

% prod.head
tff(fact_3154_distinct__disjoint__shuffles,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),$o,distinct(C),Ys)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) )
         => ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
           => aa(list(C),$o,distinct(C),Zs) ) ) ) ) ).

% distinct_disjoint_shuffles
tff(fact_3155_Cons__in__shuffles__iff,axiom,
    ! [C: $tType,Z2: C,Zs: list(C),Xs: list(C),Ys: list(C)] :
      ( member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z2),Zs),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
    <=> ( ( ( Xs != nil(C) )
          & ( aa(list(C),C,hd(C),Xs) = Z2 )
          & member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),tl(C),Xs)),Ys)) )
        | ( ( Ys != nil(C) )
          & ( aa(list(C),C,hd(C),Ys) = Z2 )
          & member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),aa(list(C),list(C),tl(C),Ys))) ) ) ) ).

% Cons_in_shuffles_iff
tff(fact_3156_ivl__disj__un__singleton_I6_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: C,U: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),La),U)
         => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),set_or7035219750837199246ssThan(C,La,U)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),U),bot_bot(set(C)))) = set_or1337092689740270186AtMost(C,La,U) ) ) ) ).

% ivl_disj_un_singleton(6)
tff(fact_3157_prod__list_Oeq__foldr,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [Xs: list(C)] : aa(list(C),C,groups5270119922927024881d_list(C),Xs) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),foldr(C,C),times_times(C)),Xs),one_one(C)) ) ).

% prod_list.eq_foldr
tff(fact_3158_ivl__disj__un__singleton_I5_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: C,U: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),La),U)
         => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),La),bot_bot(set(C)))),set_or3652927894154168847AtMost(C,La,U)) = set_or1337092689740270186AtMost(C,La,U) ) ) ) ).

% ivl_disj_un_singleton(5)
tff(fact_3159_prod_Ohead__if,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),M2: nat,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2),one_one(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,M2,N))),aa(nat,C,G,N))) ) ).

% prod.head_if
tff(fact_3160_prod_Oub__add__nat,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C),P3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)))
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),P3))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),P3)))) ) ) ) ).

% prod.ub_add_nat
tff(fact_3161_image__mult__atLeastAtMost__if,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,X: C,Y: C] :
          aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),times_times(C),C3)),set_or1337092689740270186AtMost(C,X,Y)) = $ite(
            aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),
            set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),X),aa(C,C,aa(C,fun(C,C),times_times(C),C3),Y)),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),Y),aa(C,C,aa(C,fun(C,C),times_times(C),C3),X)),bot_bot(set(C))) ) ) ).

% image_mult_atLeastAtMost_if
tff(fact_3162_divmod__cases,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [B2: C,A3: C] :
          ( ( ( B2 != zero_zero(C) )
           => ( ( modulo_modulo(C,A3,B2) = zero_zero(C) )
             => ( A3 != aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,A3,B2)),B2) ) ) )
         => ( ( ( B2 != zero_zero(C) )
             => ! [Q3: C,R5: C] :
                  ( ( euclid7384307370059645450egment(C,R5) = euclid7384307370059645450egment(C,B2) )
                 => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),euclid6346220572633701492n_size(C,R5)),euclid6346220572633701492n_size(C,B2))
                   => ( ( R5 != zero_zero(C) )
                     => ( ( divide_divide(C,A3,B2) = Q3 )
                       => ( ( modulo_modulo(C,A3,B2) = R5 )
                         => ( A3 != aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),Q3),B2)),R5) ) ) ) ) ) ) )
           => ( B2 = zero_zero(C) ) ) ) ) ).

% divmod_cases
tff(fact_3163_mod__eqI,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [B2: C,R3: C,Q2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( euclid7384307370059645450egment(C,R3) = euclid7384307370059645450egment(C,B2) )
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),euclid6346220572633701492n_size(C,R3)),euclid6346220572633701492n_size(C,B2))
             => ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),Q2),B2)),R3) = A3 )
               => ( modulo_modulo(C,A3,B2) = R3 ) ) ) ) ) ) ).

% mod_eqI
tff(fact_3164_div__eqI,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [B2: C,R3: C,Q2: C,A3: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( euclid7384307370059645450egment(C,R3) = euclid7384307370059645450egment(C,B2) )
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),euclid6346220572633701492n_size(C,R3)),euclid6346220572633701492n_size(C,B2))
             => ( ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),Q2),B2)),R3) = A3 )
               => ( divide_divide(C,A3,B2) = Q2 ) ) ) ) ) ) ).

% div_eqI
tff(fact_3165_div__bounded,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [B2: C,R3: C,Q2: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( euclid7384307370059645450egment(C,R3) = euclid7384307370059645450egment(C,B2) )
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),euclid6346220572633701492n_size(C,R3)),euclid6346220572633701492n_size(C,B2))
             => ( divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),Q2),B2)),R3),B2) = Q2 ) ) ) ) ) ).

% div_bounded
tff(fact_3166_pochhammer__times__pochhammer__half,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Z2: C,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),comm_s3205402744901411588hammer(C,Z2,aa(nat,nat,suc,N))),comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),Z2),divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),bit0(one2)))),aa(nat,nat,suc,N))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_aa(C,fun(nat,C),Z2)),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)),one_one(nat)))) ) ).

% pochhammer_times_pochhammer_half
tff(fact_3167_image__ident,axiom,
    ! [C: $tType,Y5: set(C)] : aa(set(C),set(C),image2(C,C,aTP_Lamp_ab(C,C)),Y5) = Y5 ).

% image_ident
tff(fact_3168_subset__mset_OcSUP__const,axiom,
    ! [C: $tType,D: $tType,A4: set(C),C3: multiset(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),aTP_Lamp_ac(multiset(D),fun(C,multiset(D)),C3)),A4)) = C3 ) ) ).

% subset_mset.cSUP_const
tff(fact_3169_map__ident,axiom,
    ! [C: $tType,X3: list(C)] : aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),map(C,C),aTP_Lamp_ab(C,C)),X3) = X3 ).

% map_ident
tff(fact_3170_division__segment__1,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ( euclid7384307370059645450egment(C,one_one(C)) = one_one(C) ) ) ).

% division_segment_1
tff(fact_3171_singleton__conv2,axiom,
    ! [C: $tType,A3: C] : collect(C,aa(C,fun(C,$o),fequal(C),A3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) ).

% singleton_conv2
tff(fact_3172_singleton__conv,axiom,
    ! [C: $tType,A3: C] : collect(C,aTP_Lamp_ad(C,fun(C,$o),A3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) ).

% singleton_conv
tff(fact_3173_prod_Oneutral__const,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),aTP_Lamp_ae(D,C)),A4) = one_one(C) ) ).

% prod.neutral_const
tff(fact_3174_division__segment__numeral,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [K: num] : euclid7384307370059645450egment(C,aa(num,C,numeral_numeral(C),K)) = one_one(C) ) ).

% division_segment_numeral
tff(fact_3175_division__segment__of__nat,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [N: nat] : euclid7384307370059645450egment(C,aa(nat,C,semiring_1_of_nat(C),N)) = one_one(C) ) ).

% division_segment_of_nat
tff(fact_3176_SUP__bot,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(D)] : aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,aTP_Lamp_af(D,C)),A4)) = bot_bot(C) ) ).

% SUP_bot
tff(fact_3177_SUP__bot__conv_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [B3: fun(D,C),A4: set(D)] :
          ( ( aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,B3),A4)) = bot_bot(C) )
        <=> ! [X4: D] :
              ( member2(D,X4,A4)
             => ( aa(D,C,B3,X4) = bot_bot(C) ) ) ) ) ).

% SUP_bot_conv(1)
tff(fact_3178_SUP__bot__conv_I2_J,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [B3: fun(D,C),A4: set(D)] :
          ( ( bot_bot(C) = aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,B3),A4)) )
        <=> ! [X4: D] :
              ( member2(D,X4,A4)
             => ( aa(D,C,B3,X4) = bot_bot(C) ) ) ) ) ).

% SUP_bot_conv(2)
tff(fact_3179_cSUP__const,axiom,
    ! [C: $tType,D: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),C3: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,aTP_Lamp_ag(D,fun(C,D),C3)),A4)) = C3 ) ) ) ).

% cSUP_const
tff(fact_3180_SUP__const,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),F: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,aTP_Lamp_ah(D,fun(C,D),F)),A4)) = F ) ) ) ).

% SUP_const
tff(fact_3181_foldl__length,axiom,
    ! [C: $tType,La: list(C)] : aa(list(C),nat,aa(nat,fun(list(C),nat),aa(fun(nat,fun(C,nat)),fun(nat,fun(list(C),nat)),foldl(nat,C),aTP_Lamp_ai(nat,fun(C,nat))),zero_zero(nat)),La) = aa(list(C),nat,size_size(list(C)),La) ).

% foldl_length
tff(fact_3182_prod_Odelta_H,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),A3: C,B2: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(fun(C,D),fun(C,D),aTP_Lamp_aj(C,fun(fun(C,D),fun(C,D)),A3),B2)),S) = $ite(member2(C,A3,S),aa(C,D,B2,A3),one_one(D)) ) ) ) ).

% prod.delta'
tff(fact_3183_prod_Odelta,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),A3: C,B2: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(fun(C,D),fun(C,D),aTP_Lamp_ak(C,fun(fun(C,D),fun(C,D)),A3),B2)),S) = $ite(member2(C,A3,S),aa(C,D,B2,A3),one_one(D)) ) ) ) ).

% prod.delta
tff(fact_3184_if__image__distrib,axiom,
    ! [C: $tType,D: $tType,Pa: fun(D,$o),F: fun(D,C),G: fun(D,C),S: set(D)] : aa(set(D),set(C),image2(D,C,aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),aTP_Lamp_al(fun(D,$o),fun(fun(D,C),fun(fun(D,C),fun(D,C))),Pa),F),G)),S) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(D),set(C),image2(D,C,F),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),S),collect(D,Pa)))),aa(set(D),set(C),image2(D,C,G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),S),collect(D,aTP_Lamp_am(fun(D,$o),fun(D,$o),Pa))))) ).

% if_image_distrib
tff(fact_3185_UN__constant,axiom,
    ! [D: $tType,C: $tType,C3: set(C),A4: set(D)] :
      aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_an(set(C),fun(D,set(C)),C3)),A4)) = $ite(A4 = bot_bot(set(D)),bot_bot(set(C)),C3) ).

% UN_constant
tff(fact_3186_sorted__wrt__rev__linord,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C)] :
          ( sorted_wrt(C,aTP_Lamp_ao(C,fun(C,$o)),La)
        <=> sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),La)) ) ) ).

% sorted_wrt_rev_linord
tff(fact_3187_division__segment__euclidean__size,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),euclid7384307370059645450egment(C,A3)),aa(nat,C,semiring_1_of_nat(C),euclid6346220572633701492n_size(C,A3))) = A3 ) ).

% division_segment_euclidean_size
tff(fact_3188_UN__singleton,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(C),set(set(C)),image2(C,set(C),aTP_Lamp_ap(C,set(C))),A4)) = A4 ).

% UN_singleton
tff(fact_3189_UN__simps_I1_J,axiom,
    ! [C: $tType,D: $tType,A3: C,B3: fun(D,set(C)),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_aq(C,fun(fun(D,set(C)),fun(D,set(C))),A3),B3)),C4)) = $ite(C4 = bot_bot(set(D)),bot_bot(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4)))) ).

% UN_simps(1)
tff(fact_3190_UN__simps_I3_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_ar(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4)) = $ite(C4 = bot_bot(set(D)),bot_bot(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4)))) ).

% UN_simps(3)
tff(fact_3191_UN__simps_I2_J,axiom,
    ! [D: $tType,C: $tType,A4: fun(D,set(C)),B3: set(C),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_as(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4)) = $ite(C4 = bot_bot(set(D)),bot_bot(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4))),B3)) ).

% UN_simps(2)
tff(fact_3192_Max__const,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(D)
     => ! [A4: set(C),C3: D] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic643756798349783984er_Max(D,aa(set(C),set(D),image2(C,D,aTP_Lamp_at(D,fun(C,D),C3)),A4)) = C3 ) ) ) ) ).

% Max_const
tff(fact_3193_Min__const,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(D)
     => ! [A4: set(C),C3: D] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic643756798350308766er_Min(D,aa(set(C),set(D),image2(C,D,aTP_Lamp_at(D,fun(C,D),C3)),A4)) = C3 ) ) ) ) ).

% Min_const
tff(fact_3194_foldr__length,axiom,
    ! [C: $tType,La: list(C)] : aa(nat,nat,aa(list(C),fun(nat,nat),aa(fun(C,fun(nat,nat)),fun(list(C),fun(nat,nat)),foldr(C,nat),aTP_Lamp_au(C,fun(nat,nat))),La),zero_zero(nat)) = aa(list(C),nat,size_size(list(C)),La) ).

% foldr_length
tff(fact_3195_concat__map__singleton,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(list(C)),list(C),concat(C),aa(list(D),list(list(C)),aa(fun(D,list(C)),fun(list(D),list(list(C))),map(D,list(C)),aTP_Lamp_av(fun(D,C),fun(D,list(C)),F)),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) ).

% concat_map_singleton
tff(fact_3196_set__concat,axiom,
    ! [C: $tType,Xs: list(list(C))] : aa(list(C),set(C),set2(C),aa(list(list(C)),list(C),concat(C),Xs)) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(list(C)),set(set(C)),image2(list(C),set(C),set2(C)),aa(list(list(C)),set(list(C)),set2(list(C)),Xs))) ).

% set_concat
tff(fact_3197_finite__lists__distinct__length__eq,axiom,
    ! [C: $tType,A4: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => aa(set(list(C)),$o,finite_finite2(list(C)),collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_aw(set(C),fun(nat,fun(list(C),$o)),A4),N))) ) ).

% finite_lists_distinct_length_eq
tff(fact_3198_sorted__wrt__true,axiom,
    ! [C: $tType,Xs: list(C)] : sorted_wrt(C,aTP_Lamp_ax(C,fun(C,$o)),Xs) ).

% sorted_wrt_true
tff(fact_3199_sorted__wrt__rev,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( sorted_wrt(C,Pa,aa(list(C),list(C),rev(C),Xs))
    <=> sorted_wrt(C,aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Pa),Xs) ) ).

% sorted_wrt_rev
tff(fact_3200_insort__insert__triv,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] :
          ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
         => ( linord329482645794927042rt_key(C,C,aTP_Lamp_az(C,C),X,Xs) = Xs ) ) ) ).

% insort_insert_triv
tff(fact_3201_tl__append,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),aa(list(C),list(C),tl(C),Ys)),aTP_Lamp_ba(list(C),fun(C,fun(list(C),list(C))),Ys)),Xs) ).

% tl_append
tff(fact_3202_sorted__wrt__map,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(C,$o)),F: fun(D,C),Xs: list(D)] :
      ( sorted_wrt(C,R,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
    <=> sorted_wrt(D,aa(fun(D,C),fun(D,fun(D,$o)),aTP_Lamp_bb(fun(C,fun(C,$o)),fun(fun(D,C),fun(D,fun(D,$o))),R),F),Xs) ) ).

% sorted_wrt_map
tff(fact_3203_imageE,axiom,
    ! [C: $tType,D: $tType,B2: C,F: fun(D,C),A4: set(D)] :
      ( member2(C,B2,aa(set(D),set(C),image2(D,C,F),A4))
     => ~ ! [X2: D] :
            ( ( B2 = aa(D,C,F,X2) )
           => ~ member2(D,X2,A4) ) ) ).

% imageE
tff(fact_3204_image__image,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(D,C),G: fun(E2,D),A4: set(E2)] : aa(set(D),set(C),image2(D,C,F),aa(set(E2),set(D),image2(E2,D,G),A4)) = aa(set(E2),set(C),image2(E2,C,aa(fun(E2,D),fun(E2,C),aTP_Lamp_bc(fun(D,C),fun(fun(E2,D),fun(E2,C)),F),G)),A4) ).

% image_image
tff(fact_3205_Compr__image__eq,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D),Pa: fun(C,$o)] : collect(C,aa(fun(C,$o),fun(C,$o),aa(set(D),fun(fun(C,$o),fun(C,$o)),aTP_Lamp_bd(fun(D,C),fun(set(D),fun(fun(C,$o),fun(C,$o))),F),A4),Pa)) = aa(set(D),set(C),image2(D,C,F),collect(D,aa(fun(C,$o),fun(D,$o),aa(set(D),fun(fun(C,$o),fun(D,$o)),aTP_Lamp_be(fun(D,C),fun(set(D),fun(fun(C,$o),fun(D,$o))),F),A4),Pa))) ).

% Compr_image_eq
tff(fact_3206_finite__imp__inj__to__nat__seg_H,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ~ ! [F5: fun(C,nat)] :
            ( ? [N7: nat] : aa(set(C),set(nat),image2(C,nat,F5),A4) = collect(nat,aTP_Lamp_bf(nat,fun(nat,$o),N7))
           => ~ inj_on(C,nat,F5,A4) ) ) ).

% finite_imp_inj_to_nat_seg'
tff(fact_3207_less__set__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
    <=> aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less(fun(C,$o)),aTP_Lamp_a(set(C),fun(C,$o),A4)),aTP_Lamp_a(set(C),fun(C,$o),B3)) ) ).

% less_set_def
tff(fact_3208_Collect__imp__eq,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] : collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bg(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Pa),Q)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),collect(C,Pa))),collect(C,Q)) ).

% Collect_imp_eq
tff(fact_3209_Compl__eq,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),A4) = collect(C,aTP_Lamp_bh(set(C),fun(C,$o),A4)) ).

% Compl_eq
tff(fact_3210_Collect__neg__eq,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : collect(C,aTP_Lamp_bi(fun(C,$o),fun(C,$o),Pa)) = aa(set(C),set(C),uminus_uminus(set(C)),collect(C,Pa)) ).

% Collect_neg_eq
tff(fact_3211_uminus__set__def,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),A4) = collect(C,aa(fun(C,$o),fun(C,$o),uminus_uminus(fun(C,$o)),aTP_Lamp_a(set(C),fun(C,$o),A4))) ).

% uminus_set_def
tff(fact_3212_list_Omap__ident,axiom,
    ! [C: $tType,T4: list(C)] : aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),map(C,C),aTP_Lamp_ab(C,C)),T4) = T4 ).

% list.map_ident
tff(fact_3213_foldl__map,axiom,
    ! [C: $tType,D: $tType,E2: $tType,G: fun(C,fun(D,C)),A3: C,F: fun(E2,D),Xs: list(E2)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),G),A3),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),Xs)) = aa(list(E2),C,aa(C,fun(list(E2),C),aa(fun(C,fun(E2,C)),fun(C,fun(list(E2),C)),foldl(C,E2),aa(fun(E2,D),fun(C,fun(E2,C)),aTP_Lamp_bj(fun(C,fun(D,C)),fun(fun(E2,D),fun(C,fun(E2,C))),G),F)),A3),Xs) ).

% foldl_map
tff(fact_3214_Pow__def,axiom,
    ! [C: $tType,A4: set(C)] : pow(C,A4) = collect(set(C),aTP_Lamp_bk(set(C),fun(set(C),$o),A4)) ).

% Pow_def
tff(fact_3215_Collect__subset,axiom,
    ! [C: $tType,A4: set(C),Pa: fun(C,$o)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bl(set(C),fun(fun(C,$o),fun(C,$o)),A4),Pa))),A4) ).

% Collect_subset
tff(fact_3216_less__eq__set__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
    <=> aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less_eq(fun(C,$o)),aTP_Lamp_a(set(C),fun(C,$o),A4)),aTP_Lamp_a(set(C),fun(C,$o),B3)) ) ).

% less_eq_set_def
tff(fact_3217_insert__compr,axiom,
    ! [C: $tType,A3: C,B3: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3) = collect(C,aa(set(C),fun(C,$o),aTP_Lamp_bm(C,fun(set(C),fun(C,$o)),A3),B3)) ).

% insert_compr
tff(fact_3218_insert__Collect,axiom,
    ! [C: $tType,A3: C,Pa: fun(C,$o)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),collect(C,Pa)) = collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bn(C,fun(fun(C,$o),fun(C,$o)),A3),Pa)) ).

% insert_Collect
tff(fact_3219_Set_Oempty__def,axiom,
    ! [C: $tType] : bot_bot(set(C)) = collect(C,aTP_Lamp_bo(C,$o)) ).

% Set.empty_def
tff(fact_3220_insert__def,axiom,
    ! [C: $tType,A3: C,B3: set(C)] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),B3) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),collect(C,aTP_Lamp_ad(C,fun(C,$o),A3))),B3) ).

% insert_def
tff(fact_3221_inj__singleton,axiom,
    ! [C: $tType,A4: set(C)] : inj_on(C,set(C),aTP_Lamp_ap(C,set(C)),A4) ).

% inj_singleton
tff(fact_3222_Collect__conv__if2,axiom,
    ! [C: $tType,A3: C,Pa: fun(C,$o)] :
      collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bp(C,fun(fun(C,$o),fun(C,$o)),A3),Pa)) = $ite(aa(C,$o,Pa,A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))),bot_bot(set(C))) ).

% Collect_conv_if2
tff(fact_3223_Collect__conv__if,axiom,
    ! [C: $tType,A3: C,Pa: fun(C,$o)] :
      collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bq(C,fun(fun(C,$o),fun(C,$o)),A3),Pa)) = $ite(aa(C,$o,Pa,A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))),bot_bot(set(C))) ).

% Collect_conv_if
tff(fact_3224_list_Ocase__distrib,axiom,
    ! [D: $tType,C: $tType,E2: $tType,H: fun(D,C),F1: D,F22: fun(E2,fun(list(E2),D)),List: list(E2)] : aa(D,C,H,aa(list(E2),D,aa(fun(E2,fun(list(E2),D)),fun(list(E2),D),aa(D,fun(fun(E2,fun(list(E2),D)),fun(list(E2),D)),case_list(D,E2),F1),F22),List)) = aa(list(E2),C,aa(fun(E2,fun(list(E2),C)),fun(list(E2),C),aa(C,fun(fun(E2,fun(list(E2),C)),fun(list(E2),C)),case_list(C,E2),aa(D,C,H,F1)),aa(fun(E2,fun(list(E2),D)),fun(E2,fun(list(E2),C)),aTP_Lamp_br(fun(D,C),fun(fun(E2,fun(list(E2),D)),fun(E2,fun(list(E2),C))),H),F22)),List) ).

% list.case_distrib
tff(fact_3225_Un__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = collect(C,aa(set(C),fun(C,$o),aTP_Lamp_bs(set(C),fun(set(C),fun(C,$o)),A4),B3)) ).

% Un_def
tff(fact_3226_Collect__disj__eq,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] : collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bt(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Pa),Q)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),collect(C,Pa)),collect(C,Q)) ).

% Collect_disj_eq
tff(fact_3227_sup__set__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3) = collect(C,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),sup_sup(fun(C,$o)),aTP_Lamp_a(set(C),fun(C,$o),A4)),aTP_Lamp_a(set(C),fun(C,$o),B3))) ).

% sup_set_def
tff(fact_3228_Collect__conj__eq,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] : collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bu(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Pa),Q)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),collect(C,Pa)),collect(C,Q)) ).

% Collect_conj_eq
tff(fact_3229_inf__Int__eq,axiom,
    ! [C: $tType,R: set(C),S: set(C),X3: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),aTP_Lamp_a(set(C),fun(C,$o),R)),aTP_Lamp_a(set(C),fun(C,$o),S)),X3)
    <=> member2(C,X3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),R),S)) ) ).

% inf_Int_eq
tff(fact_3230_inf__set__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = collect(C,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),aTP_Lamp_a(set(C),fun(C,$o),A4)),aTP_Lamp_a(set(C),fun(C,$o),B3))) ).

% inf_set_def
tff(fact_3231_Int__Collect,axiom,
    ! [C: $tType,X: C,A4: set(C),Pa: fun(C,$o)] :
      ( member2(C,X,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa)))
    <=> ( member2(C,X,A4)
        & aa(C,$o,Pa,X) ) ) ).

% Int_Collect
tff(fact_3232_Int__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = collect(C,aa(set(C),fun(C,$o),aTP_Lamp_bv(set(C),fun(set(C),fun(C,$o)),A4),B3)) ).

% Int_def
tff(fact_3233_inf__Int__eq2,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D)),S: set(product_prod(C,D)),X3: C,Xa3: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),inf_inf(fun(C,fun(D,$o))),aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),R)),aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),S)),X3),Xa3)
    <=> member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X3),Xa3),aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),R),S)) ) ).

% inf_Int_eq2
tff(fact_3234_inj__Pair_I2_J,axiom,
    ! [D: $tType,C: $tType,C3: fun(C,D),S: set(C)] : inj_on(C,product_prod(D,C),aTP_Lamp_bx(fun(C,D),fun(C,product_prod(D,C)),C3),S) ).

% inj_Pair(2)
tff(fact_3235_inj__Pair_I1_J,axiom,
    ! [D: $tType,C: $tType,C3: fun(C,D),S: set(C)] : inj_on(C,product_prod(C,D),aTP_Lamp_by(fun(C,D),fun(C,product_prod(C,D)),C3),S) ).

% inj_Pair(1)
tff(fact_3236_lambda__one,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ( aTP_Lamp_bz(C,C) = aa(C,fun(C,C),times_times(C),one_one(C)) ) ) ).

% lambda_one
tff(fact_3237_lambda__zero,axiom,
    ! [C: $tType] :
      ( mult_zero(C)
     => ( aTP_Lamp_ca(C,C) = aa(C,fun(C,C),times_times(C),zero_zero(C)) ) ) ).

% lambda_zero
tff(fact_3238_set__diff__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : minus_minus(set(C),A4,B3) = collect(C,aa(set(C),fun(C,$o),aTP_Lamp_cb(set(C),fun(set(C),fun(C,$o)),A4),B3)) ).

% set_diff_eq
tff(fact_3239_minus__set__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : minus_minus(set(C),A4,B3) = collect(C,minus_minus(fun(C,$o),aTP_Lamp_a(set(C),fun(C,$o),A4),aTP_Lamp_a(set(C),fun(C,$o),B3))) ).

% minus_set_def
tff(fact_3240_list_Odisc__eq__case_I1_J,axiom,
    ! [C: $tType,List: list(C)] :
      ( ( List = nil(C) )
    <=> aa(list(C),$o,aa(fun(C,fun(list(C),$o)),fun(list(C),$o),aa($o,fun(fun(C,fun(list(C),$o)),fun(list(C),$o)),case_list($o,C),$true),aTP_Lamp_cc(C,fun(list(C),$o))),List) ) ).

% list.disc_eq_case(1)
tff(fact_3241_list_Odisc__eq__case_I2_J,axiom,
    ! [C: $tType,List: list(C)] :
      ( ( List != nil(C) )
    <=> aa(list(C),$o,aa(fun(C,fun(list(C),$o)),fun(list(C),$o),aa($o,fun(fun(C,fun(list(C),$o)),fun(list(C),$o)),case_list($o,C),$false),aTP_Lamp_cd(C,fun(list(C),$o))),List) ) ).

% list.disc_eq_case(2)
tff(fact_3242_tl__def,axiom,
    ! [C: $tType,List: list(C)] : aa(list(C),list(C),tl(C),List) = aa(list(C),list(C),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aTP_Lamp_ce(C,fun(list(C),list(C)))),List) ).

% tl_def
tff(fact_3243_prod_Odistrib,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),H: fun(D,C),A4: set(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),aa(fun(D,C),fun(D,C),aTP_Lamp_cf(fun(D,C),fun(fun(D,C),fun(D,C)),G),H)),A4) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),G),A4)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),H),A4)) ) ).

% prod.distrib
tff(fact_3244_Shift__def,axiom,
    ! [C: $tType,Kl2: set(list(C)),K: C] : bNF_Greatest_Shift(C,Kl2,K) = collect(list(C),aa(C,fun(list(C),$o),aTP_Lamp_cg(set(list(C)),fun(C,fun(list(C),$o)),Kl2),K)) ).

% Shift_def
tff(fact_3245_prod_Ofinite__Collect__op,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [I5: set(C),X: fun(C,D),Y: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_ch(set(C),fun(fun(C,D),fun(C,$o)),I5),X)))
         => ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_ch(set(C),fun(fun(C,D),fun(C,$o)),I5),Y)))
           => aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aa(fun(C,D),fun(fun(C,D),fun(C,$o)),aTP_Lamp_ci(set(C),fun(fun(C,D),fun(fun(C,D),fun(C,$o))),I5),X),Y))) ) ) ) ).

% prod.finite_Collect_op
tff(fact_3246_image__constant__conv,axiom,
    ! [D: $tType,C: $tType,C3: C,A4: set(D)] :
      aa(set(D),set(C),image2(D,C,aTP_Lamp_cj(C,fun(D,C),C3)),A4) = $ite(A4 = bot_bot(set(D)),bot_bot(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),C3),bot_bot(set(C)))) ).

% image_constant_conv
tff(fact_3247_image__constant,axiom,
    ! [C: $tType,D: $tType,X: C,A4: set(C),C3: D] :
      ( member2(C,X,A4)
     => ( aa(set(C),set(D),image2(C,D,aTP_Lamp_ck(D,fun(C,D),C3)),A4) = aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),C3),bot_bot(set(D))) ) ) ).

% image_constant
tff(fact_3248_translation__subtract__Int,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [A3: C,S4: set(C),T4: set(C)] : aa(set(C),set(C),image2(C,C,aTP_Lamp_cl(C,fun(C,C),A3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S4),T4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),image2(C,C,aTP_Lamp_cl(C,fun(C,C),A3)),S4)),aa(set(C),set(C),image2(C,C,aTP_Lamp_cl(C,fun(C,C),A3)),T4)) ) ).

% translation_subtract_Int
tff(fact_3249_SUP__inf__distrib2,axiom,
    ! [E2: $tType,C: $tType,D: $tType] :
      ( comple592849572758109894attice(C)
     => ! [F: fun(D,C),A4: set(D),G: fun(E2,C),B3: set(E2)] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,F),A4))),aa(set(C),C,complete_Sup_Sup(C),aa(set(E2),set(C),image2(E2,C,G),B3))) = aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,aa(set(E2),fun(D,C),aa(fun(E2,C),fun(set(E2),fun(D,C)),aTP_Lamp_cn(fun(D,C),fun(fun(E2,C),fun(set(E2),fun(D,C))),F),G),B3)),A4)) ) ).

% SUP_inf_distrib2
tff(fact_3250_inf__SUP,axiom,
    ! [C: $tType,D: $tType] :
      ( comple592849572758109894attice(C)
     => ! [A3: C,F: fun(D,C),B3: set(D)] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,F),B3))) = aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_co(C,fun(fun(D,C),fun(D,C)),A3),F)),B3)) ) ).

% inf_SUP
tff(fact_3251_Sup__inf,axiom,
    ! [C: $tType] :
      ( comple592849572758109894attice(C)
     => ! [B3: set(C),A3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Sup_Sup(C),B3)),A3) = aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),image2(C,C,aTP_Lamp_cp(C,fun(C,C),A3)),B3)) ) ).

% Sup_inf
tff(fact_3252_SUP__inf,axiom,
    ! [C: $tType,D: $tType] :
      ( comple592849572758109894attice(C)
     => ! [F: fun(D,C),B3: set(D),A3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,F),B3))),A3) = aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,aa(C,fun(D,C),aTP_Lamp_cq(fun(D,C),fun(C,fun(D,C)),F),A3)),B3)) ) ).

% SUP_inf
tff(fact_3253_prod_Ointer__filter,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D),Pa: fun(C,$o)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bl(set(C),fun(fun(C,$o),fun(C,$o)),A4),Pa))) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(fun(C,$o),fun(C,D),aTP_Lamp_cr(fun(C,D),fun(fun(C,$o),fun(C,D)),G),Pa)),A4) ) ) ) ).

% prod.inter_filter
tff(fact_3254_foldl__length__aux,axiom,
    ! [C: $tType,A3: nat,La: list(C)] : aa(list(C),nat,aa(nat,fun(list(C),nat),aa(fun(nat,fun(C,nat)),fun(nat,fun(list(C),nat)),foldl(nat,C),aTP_Lamp_ai(nat,fun(C,nat))),A3),La) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),aa(list(C),nat,size_size(list(C)),La)) ).

% foldl_length_aux
tff(fact_3255_UNION__empty__conv_I2_J,axiom,
    ! [D: $tType,C: $tType,B3: fun(D,set(C)),A4: set(D)] :
      ( ( aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),A4)) = bot_bot(set(C)) )
    <=> ! [X4: D] :
          ( member2(D,X4,A4)
         => ( aa(D,set(C),B3,X4) = bot_bot(set(C)) ) ) ) ).

% UNION_empty_conv(2)
tff(fact_3256_UNION__empty__conv_I1_J,axiom,
    ! [D: $tType,C: $tType,B3: fun(D,set(C)),A4: set(D)] :
      ( ( bot_bot(set(C)) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),A4)) )
    <=> ! [X4: D] :
          ( member2(D,X4,A4)
         => ( aa(D,set(C),B3,X4) = bot_bot(set(C)) ) ) ) ).

% UNION_empty_conv(1)
tff(fact_3257_UN__empty,axiom,
    ! [D: $tType,C: $tType,B3: fun(D,set(C))] : aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),bot_bot(set(D)))) = bot_bot(set(C)) ).

% UN_empty
tff(fact_3258_UN__empty2,axiom,
    ! [D: $tType,C: $tType,A4: set(D)] : aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_cs(D,set(C))),A4)) = bot_bot(set(C)) ).

% UN_empty2
tff(fact_3259_sorted__map,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
        <=> sorted_wrt(D,aTP_Lamp_ct(fun(D,C),fun(D,fun(D,$o)),F),Xs) ) ) ).

% sorted_map
tff(fact_3260_UN__extend__simps_I5_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4))) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_cu(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4)) ).

% UN_extend_simps(5)
tff(fact_3261_UN__extend__simps_I4_J,axiom,
    ! [C: $tType,D: $tType,A4: fun(D,set(C)),C4: set(D),B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4))),B3) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_cv(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4)) ).

% UN_extend_simps(4)
tff(fact_3262_Int__UN__distrib,axiom,
    ! [C: $tType,D: $tType,B3: set(C),A4: fun(D,set(C)),I5: set(D)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),B3),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),I5))) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_cu(set(C),fun(fun(D,set(C)),fun(D,set(C))),B3),A4)),I5)) ).

% Int_UN_distrib
tff(fact_3263_Int__UN__distrib2,axiom,
    ! [E2: $tType,C: $tType,D: $tType,A4: fun(D,set(C)),I5: set(D),B3: fun(E2,set(C)),J4: set(E2)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),I5))),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(E2),set(set(C)),image2(E2,set(C),B3),J4))) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(E2),fun(D,set(C)),aa(fun(E2,set(C)),fun(set(E2),fun(D,set(C))),aTP_Lamp_cx(fun(D,set(C)),fun(fun(E2,set(C)),fun(set(E2),fun(D,set(C)))),A4),B3),J4)),I5)) ).

% Int_UN_distrib2
tff(fact_3264_Int__Union,axiom,
    ! [C: $tType,A4: set(C),B3: set(set(C))] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),B3)) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4)),B3)) ).

% Int_Union
tff(fact_3265_Int__Union2,axiom,
    ! [C: $tType,B3: set(set(C)),A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),B3)),A4) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aTP_Lamp_cy(set(C),fun(set(C),set(C)),A4)),B3)) ).

% Int_Union2
tff(fact_3266_zip__same__conv__map,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(product_prod(C,C)),aa(list(C),fun(list(C),list(product_prod(C,C))),zip(C,C),Xs),Xs) = aa(list(C),list(product_prod(C,C)),aa(fun(C,product_prod(C,C)),fun(list(C),list(product_prod(C,C))),map(C,product_prod(C,C)),aTP_Lamp_cz(C,product_prod(C,C))),Xs) ).

% zip_same_conv_map
tff(fact_3267_finite__if__eq__beyond__finite,axiom,
    ! [C: $tType,S: set(C),S5: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),S)
     => aa(set(set(C)),$o,finite_finite2(set(C)),collect(set(C),aa(set(C),fun(set(C),$o),aTP_Lamp_da(set(C),fun(set(C),fun(set(C),$o)),S),S5))) ) ).

% finite_if_eq_beyond_finite
tff(fact_3268_arg__min__list_Osimps_I2_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Y: C,Zs: list(C)] :
          arg_min_list(C,D,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs))) = $let(
            m: C,
            m:= arg_min_list(C,D,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)),
            $ite(aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X)),aa(C,D,F,m)),X,m) ) ) ).

% arg_min_list.simps(2)
tff(fact_3269_foldr__conv__foldl,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),Xs: list(D),A3: C] : aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),Xs),A3) = aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),aTP_Lamp_db(fun(D,fun(C,C)),fun(C,fun(D,C)),F)),A3),aa(list(D),list(D),rev(D),Xs)) ).

% foldr_conv_foldl
tff(fact_3270_foldl__conv__foldr,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(D,C)),A3: C,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),A3),Xs) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),aTP_Lamp_dc(fun(C,fun(D,C)),fun(D,fun(C,C)),F)),aa(list(D),list(D),rev(D),Xs)),A3) ).

% foldl_conv_foldr
tff(fact_3271_distinct__finite__set,axiom,
    ! [C: $tType,X: set(C)] : aa(set(list(C)),$o,finite_finite2(list(C)),collect(list(C),aTP_Lamp_dd(set(C),fun(list(C),$o),X))) ).

% distinct_finite_set
tff(fact_3272_set__insort__insert,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] : aa(list(C),set(C),set2(C),linord329482645794927042rt_key(C,C,aTP_Lamp_az(C,C),X,Xs)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(list(C),set(C),set2(C),Xs)) ) ).

% set_insort_insert
tff(fact_3273_sorted__insort__insert,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),X: C] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),linord329482645794927042rt_key(C,C,aTP_Lamp_az(C,C),X,Xs)) ) ) ).

% sorted_insort_insert
tff(fact_3274_product__concat__map,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),Xs),Ys) = aa(list(list(product_prod(C,D))),list(product_prod(C,D)),concat(product_prod(C,D)),aa(list(C),list(list(product_prod(C,D))),aa(fun(C,list(product_prod(C,D))),fun(list(C),list(list(product_prod(C,D)))),map(C,list(product_prod(C,D))),aTP_Lamp_de(list(D),fun(C,list(product_prod(C,D))),Ys)),Xs)) ).

% product_concat_map
tff(fact_3275_map__add__upt_H,axiom,
    ! [Ofs: nat,A3: nat,B2: nat] : aa(list(nat),list(nat),aa(fun(nat,nat),fun(list(nat),list(nat)),map(nat,nat),aTP_Lamp_df(nat,fun(nat,nat),Ofs)),upt(A3,B2)) = upt(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),Ofs),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),B2),Ofs)) ).

% map_add_upt'
tff(fact_3276_numeral__code_I3_J,axiom,
    ! [C: $tType] :
      ( numeral(C)
     => ! [N: num] :
          aa(num,C,numeral_numeral(C),bit1(N)) = $let(
            m: C,
            m:= aa(num,C,numeral_numeral(C),N),
            aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),m),m)),one_one(C)) ) ) ).

% numeral_code(3)
tff(fact_3277_SUP__empty,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(D,C)] : aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,F),bot_bot(set(D)))) = bot_bot(C) ) ).

% SUP_empty
tff(fact_3278_SUP__constant,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [C3: C,A4: set(D)] :
          aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,aTP_Lamp_dg(C,fun(D,C),C3)),A4)) = $ite(A4 = bot_bot(set(D)),bot_bot(C),C3) ) ).

% SUP_constant
tff(fact_3279_power__numeral__even,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [Z2: C,W: num] :
          aa(nat,C,aa(C,fun(nat,C),power_power(C),Z2),aa(num,nat,numeral_numeral(nat),bit0(W))) = $let(
            w: C,
            w:= aa(nat,C,aa(C,fun(nat,C),power_power(C),Z2),aa(num,nat,numeral_numeral(nat),W)),
            aa(C,C,aa(C,fun(C,C),times_times(C),w),w) ) ) ).

% power_numeral_even
tff(fact_3280_power__numeral__odd,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [Z2: C,W: num] :
          aa(nat,C,aa(C,fun(nat,C),power_power(C),Z2),aa(num,nat,numeral_numeral(nat),bit1(W))) = $let(
            w: C,
            w:= aa(nat,C,aa(C,fun(nat,C),power_power(C),Z2),aa(num,nat,numeral_numeral(nat),W)),
            aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),Z2),w)),w) ) ) ).

% power_numeral_odd
tff(fact_3281_prod_Ointer__restrict,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(set(C),fun(C,D),aTP_Lamp_dh(fun(C,D),fun(set(C),fun(C,D)),G),B3)),A4) ) ) ) ).

% prod.inter_restrict
tff(fact_3282_prod_Osetdiff__irrelevant,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),minus_minus(set(C),A4,collect(C,aTP_Lamp_di(fun(C,D),fun(C,$o),G)))) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),A4) ) ) ) ).

% prod.setdiff_irrelevant
tff(fact_3283_UN__extend__simps_I1_J,axiom,
    ! [C: $tType,D: $tType,A3: C,B3: fun(D,set(C)),C4: set(D)] :
      aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4))) = $ite(C4 = bot_bot(set(D)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_aq(C,fun(fun(D,set(C)),fun(D,set(C))),A3),B3)),C4))) ).

% UN_extend_simps(1)
tff(fact_3284_UN__extend__simps_I3_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4))) = $ite(C4 = bot_bot(set(D)),A4,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_ar(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4))) ).

% UN_extend_simps(3)
tff(fact_3285_UN__extend__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,A4: fun(D,set(C)),C4: set(D),B3: set(C)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4))),B3) = $ite(C4 = bot_bot(set(D)),B3,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_as(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4))) ).

% UN_extend_simps(2)
tff(fact_3286_length__transpose,axiom,
    ! [C: $tType,Xs: list(list(C))] : aa(list(list(C)),nat,size_size(list(list(C))),transpose(C,Xs)) = aa(nat,nat,aa(list(list(C)),fun(nat,nat),aa(fun(list(C),fun(nat,nat)),fun(list(list(C)),fun(nat,nat)),foldr(list(C),nat),aTP_Lamp_dj(list(C),fun(nat,nat))),Xs),zero_zero(nat)) ).

% length_transpose
tff(fact_3287_foldr__length__aux,axiom,
    ! [C: $tType,La: list(C),A3: nat] : aa(nat,nat,aa(list(C),fun(nat,nat),aa(fun(C,fun(nat,nat)),fun(list(C),fun(nat,nat)),foldr(C,nat),aTP_Lamp_au(C,fun(nat,nat))),La),A3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),aa(list(C),nat,size_size(list(C)),La)) ).

% foldr_length_aux
tff(fact_3288_Succ__def,axiom,
    ! [C: $tType,Kl2: set(list(C)),Kl: list(C)] : bNF_Greatest_Succ(C,Kl2,Kl) = collect(C,aa(list(C),fun(C,$o),aTP_Lamp_dk(set(list(C)),fun(list(C),fun(C,$o)),Kl2),Kl)) ).

% Succ_def
tff(fact_3289_set__list__bind,axiom,
    ! [C: $tType,D: $tType,Xs: list(D),F: fun(D,list(C))] : aa(list(C),set(C),set2(C),bind(D,C,Xs,F)) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_dl(fun(D,list(C)),fun(D,set(C)),F)),aa(list(D),set(D),set2(D),Xs))) ).

% set_list_bind
tff(fact_3290_listrelp__listrel__eq,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,D)),X3: list(C),Xa3: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),listrelp(C,D,aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),R3)),X3),Xa3)
    <=> member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),X3),Xa3),listrel(C,D,R3)) ) ).

% listrelp_listrel_eq
tff(fact_3291_n__lists_Osimps_I2_J,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : n_lists(C,aa(nat,nat,suc,N),Xs) = aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aTP_Lamp_dn(list(C),fun(list(C),list(list(C))),Xs)),n_lists(C,N,Xs))) ).

% n_lists.simps(2)
tff(fact_3292_enumerate__map__upt,axiom,
    ! [C: $tType,N: nat,F: fun(nat,C),M2: nat] : enumerate(C,N,aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),F),upt(N,M2))) = aa(list(nat),list(product_prod(nat,C)),aa(fun(nat,product_prod(nat,C)),fun(list(nat),list(product_prod(nat,C))),map(nat,product_prod(nat,C)),aTP_Lamp_do(fun(nat,C),fun(nat,product_prod(nat,C)),F)),upt(N,M2)) ).

% enumerate_map_upt
tff(fact_3293_map__add__upt,axiom,
    ! [N: nat,M2: nat] : aa(list(nat),list(nat),aa(fun(nat,nat),fun(list(nat),list(nat)),map(nat,nat),aTP_Lamp_df(nat,fun(nat,nat),N)),upt(zero_zero(nat),M2)) = upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N)) ).

% map_add_upt
tff(fact_3294_min__list_Osimps,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: C,Xs: list(C)] : min_list(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),C,aa(fun(C,fun(list(C),C)),fun(list(C),C),aa(C,fun(fun(C,fun(list(C),C)),fun(list(C),C)),case_list(C,C),X),aa(list(C),fun(C,fun(list(C),C)),aTP_Lamp_dp(C,fun(list(C),fun(C,fun(list(C),C))),X),Xs)),Xs) ) ).

% min_list.simps
tff(fact_3295_product__lists_Osimps_I2_J,axiom,
    ! [C: $tType,Xs: list(C),Xss2: list(list(C))] : aa(list(list(C)),list(list(C)),product_lists(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Xs),Xss2)) = aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(C),list(list(list(C))),aa(fun(C,list(list(C))),fun(list(C),list(list(list(C)))),map(C,list(list(C))),aTP_Lamp_dq(list(list(C)),fun(C,list(list(C))),Xss2)),Xs)) ).

% product_lists.simps(2)
tff(fact_3296_UNION__singleton__eq__range,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] : aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_dr(fun(D,C),fun(D,set(C)),F)),A4)) = aa(set(D),set(C),image2(D,C,F),A4) ).

% UNION_singleton_eq_range
tff(fact_3297_inj__on__disjoint__Un,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C),G: fun(C,D),B3: set(C)] :
      ( inj_on(C,D,F,A4)
     => ( inj_on(C,D,G,B3)
       => ( ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),image2(C,D,F),A4)),aa(set(C),set(D),image2(C,D,G),B3)) = bot_bot(set(D)) )
         => inj_on(C,D,aa(fun(C,D),fun(C,D),aa(set(C),fun(fun(C,D),fun(C,D)),aTP_Lamp_ds(fun(C,D),fun(set(C),fun(fun(C,D),fun(C,D))),F),A4),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) ) ) ) ).

% inj_on_disjoint_Un
tff(fact_3298_Max__add__commute,axiom,
    ! [C: $tType,D: $tType] :
      ( linord4140545234300271783up_add(D)
     => ! [S: set(C),F: fun(C,D),K: D] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ( lattic643756798349783984er_Max(D,aa(set(C),set(D),image2(C,D,aa(D,fun(C,D),aTP_Lamp_dt(fun(C,D),fun(D,fun(C,D)),F),K)),S)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),lattic643756798349783984er_Max(D,aa(set(C),set(D),image2(C,D,F),S))),K) ) ) ) ) ).

% Max_add_commute
tff(fact_3299_Min__add__commute,axiom,
    ! [C: $tType,D: $tType] :
      ( linord4140545234300271783up_add(D)
     => ! [S: set(C),F: fun(C,D),K: D] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ( lattic643756798350308766er_Min(D,aa(set(C),set(D),image2(C,D,aa(D,fun(C,D),aTP_Lamp_dt(fun(C,D),fun(D,fun(C,D)),F),K)),S)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),lattic643756798350308766er_Min(D,aa(set(C),set(D),image2(C,D,F),S))),K) ) ) ) ) ).

% Min_add_commute
tff(fact_3300_prod_OSuc__reindex__ivl,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M2: nat,N: nat,G: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,M2,N))),aa(nat,C,G,aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,M2)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_du(fun(nat,C),fun(nat,C),G)),set_or1337092689740270186AtMost(nat,M2,N))) ) ) ) ).

% prod.Suc_reindex_ivl
tff(fact_3301_prod_OIf__cases,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(C),Pa: fun(C,$o),H: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_dv(fun(C,$o),fun(fun(C,D),fun(fun(C,D),fun(C,D))),Pa),H),G)),A4) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),H),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa)))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),collect(C,Pa))))) ) ) ) ).

% prod.If_cases
tff(fact_3302_prod_OatMost__Suc__shift,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_atMost(nat,aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,zero_zero(nat))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_du(fun(nat,C),fun(nat,C),G)),set_ord_atMost(nat,N))) ) ).

% prod.atMost_Suc_shift
tff(fact_3303_prod_OlessThan__Suc__shift,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_lessThan(nat,aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,zero_zero(nat))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_du(fun(nat,C),fun(nat,C),G)),set_ord_lessThan(nat,N))) ) ).

% prod.lessThan_Suc_shift
tff(fact_3304_subseqs_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      aa(list(C),list(list(C)),subseqs(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $let(
        xss: list(list(C)),
        xss:= aa(list(C),list(list(C)),subseqs(C),Xs),
        aa(list(list(C)),list(list(C)),aa(list(list(C)),fun(list(list(C)),list(list(C))),append(list(C)),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(C,fun(list(C),list(C)),cons(C),X)),xss)),xss) ) ).

% subseqs.simps(2)
tff(fact_3305_list_Osize__gen_I2_J,axiom,
    ! [C: $tType,X: fun(C,nat),X21: C,X22: list(C)] : aa(list(C),nat,size_list(C,X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(C,nat,X,X21)),aa(list(C),nat,size_list(C,X),X22))),aa(nat,nat,suc,zero_zero(nat))) ).

% list.size_gen(2)
tff(fact_3306_map__upt__Suc,axiom,
    ! [C: $tType,F: fun(nat,C),N: nat] : aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),F),upt(zero_zero(nat),aa(nat,nat,suc,N))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(nat,C,F,zero_zero(nat))),aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),aTP_Lamp_dw(fun(nat,C),fun(nat,C),F)),upt(zero_zero(nat),N))) ).

% map_upt_Suc
tff(fact_3307_finite__lists__length__eq,axiom,
    ! [C: $tType,A4: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => aa(set(list(C)),$o,finite_finite2(list(C)),collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_dx(set(C),fun(nat,fun(list(C),$o)),A4),N))) ) ).

% finite_lists_length_eq
tff(fact_3308_horner__sum__foldr,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_semiring_0(C)
     => ! [F: fun(D,C),A3: C,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),Xs) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),aa(C,fun(D,fun(C,C)),aTP_Lamp_dy(fun(D,C),fun(C,fun(D,fun(C,C))),F),A3)),Xs),zero_zero(C)) ) ).

% horner_sum_foldr
tff(fact_3309_map__nth,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),nth(C,Xs)),upt(zero_zero(nat),aa(list(C),nat,size_size(list(C)),Xs))) = Xs ).

% map_nth
tff(fact_3310_slice__prepend,axiom,
    ! [C: $tType,I: nat,K: nat,Xs: list(C),Ys: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),K)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),aa(list(C),nat,size_size(list(C)),Xs))
       => $let(
            p2: nat,
            p2:= aa(list(C),nat,size_size(list(C)),Ys),
            slice(C,I,K,Xs) = slice(C,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),p2),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),p2),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Xs)) ) ) ) ).

% slice_prepend
tff(fact_3311_distinct__finite__subset,axiom,
    ! [C: $tType,X: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),X)
     => aa(set(list(C)),$o,finite_finite2(list(C)),collect(list(C),aTP_Lamp_dz(set(C),fun(list(C),$o),X))) ) ).

% distinct_finite_subset
tff(fact_3312_zip__Cons1,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(C),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys) = aa(list(D),list(product_prod(C,D)),aa(fun(D,fun(list(D),list(product_prod(C,D)))),fun(list(D),list(product_prod(C,D))),aa(list(product_prod(C,D)),fun(fun(D,fun(list(D),list(product_prod(C,D)))),fun(list(D),list(product_prod(C,D)))),case_list(list(product_prod(C,D)),D),nil(product_prod(C,D))),aa(list(C),fun(D,fun(list(D),list(product_prod(C,D)))),aTP_Lamp_ea(C,fun(list(C),fun(D,fun(list(D),list(product_prod(C,D))))),X),Xs)),Ys) ).

% zip_Cons1
tff(fact_3313_zip__Cons,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Y: D,Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys)) = aa(list(C),list(product_prod(C,D)),aa(fun(C,fun(list(C),list(product_prod(C,D)))),fun(list(C),list(product_prod(C,D))),aa(list(product_prod(C,D)),fun(fun(C,fun(list(C),list(product_prod(C,D)))),fun(list(C),list(product_prod(C,D)))),case_list(list(product_prod(C,D)),C),nil(product_prod(C,D))),aa(list(D),fun(C,fun(list(C),list(product_prod(C,D)))),aTP_Lamp_eb(D,fun(list(D),fun(C,fun(list(C),list(product_prod(C,D))))),Y),Ys)),Xs) ).

% zip_Cons
tff(fact_3314_set__n__lists,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(list(C)),set(list(C)),set2(list(C)),n_lists(C,N,Xs)) = collect(list(C),aa(list(C),fun(list(C),$o),aTP_Lamp_ec(nat,fun(list(C),fun(list(C),$o)),N),Xs)) ).

% set_n_lists
tff(fact_3315_map__decr__upt,axiom,
    ! [M2: nat,N: nat] : aa(list(nat),list(nat),aa(fun(nat,nat),fun(list(nat),list(nat)),map(nat,nat),aTP_Lamp_ed(nat,nat)),upt(aa(nat,nat,suc,M2),aa(nat,nat,suc,N))) = upt(M2,N) ).

% map_decr_upt
tff(fact_3316_atLeastAtMost__upto,axiom,
    ! [I: int,J: int] : set_or1337092689740270186AtMost(int,I,J) = aa(list(int),set(int),set2(int),upto(I,J)) ).

% atLeastAtMost_upto
tff(fact_3317_map__by__foldl,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),La: list(D)] : aa(list(D),list(C),aa(list(C),fun(list(D),list(C)),aa(fun(list(C),fun(D,list(C))),fun(list(C),fun(list(D),list(C))),foldl(list(C),D),aTP_Lamp_ee(fun(D,C),fun(list(C),fun(D,list(C))),F)),nil(C)),La) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),La) ).

% map_by_foldl
tff(fact_3318_prod_Odelta__remove,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),A3: C,B2: fun(C,D),C3: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_ef(C,fun(fun(C,D),fun(fun(C,D),fun(C,D))),A3),B2),C3)),S) = $ite(member2(C,A3,S),aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,B2,A3)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),C3),minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),C3),minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ) ).

% prod.delta_remove
tff(fact_3319_prod_OUNION__disjoint,axiom,
    ! [D: $tType,E2: $tType,C: $tType] :
      ( comm_monoid_mult(E2)
     => ! [I5: set(C),A4: fun(C,set(D)),G: fun(D,E2)] :
          ( aa(set(C),$o,finite_finite2(C),I5)
         => ( ! [X2: C] :
                ( member2(C,X2,I5)
               => aa(set(D),$o,finite_finite2(D),aa(C,set(D),A4,X2)) )
           => ( ! [X2: C] :
                  ( member2(C,X2,I5)
                 => ! [Xa4: C] :
                      ( member2(C,Xa4,I5)
                     => ( ( X2 != Xa4 )
                       => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(C,set(D),A4,X2)),aa(C,set(D),A4,Xa4)) = bot_bot(set(D)) ) ) ) )
             => ( aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7121269368397514597t_prod(D,E2),G),aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I5))) = aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7121269368397514597t_prod(C,E2),aa(fun(D,E2),fun(C,E2),aTP_Lamp_eg(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),A4),G)),I5) ) ) ) ) ) ).

% prod.UNION_disjoint
tff(fact_3320_division__segment__mult,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( euclid7384307370059645450egment(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),euclid7384307370059645450egment(C,A3)),euclid7384307370059645450egment(C,B2)) ) ) ) ) ).

% division_segment_mult
tff(fact_3321_prod_OatMost__shift,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_atMost(nat,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,zero_zero(nat))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_du(fun(nat,C),fun(nat,C),G)),set_ord_lessThan(nat,N))) ) ).

% prod.atMost_shift
tff(fact_3322_is__unit__division__segment,axiom,
    ! [C: $tType] :
      ( euclid3128863361964157862miring(C)
     => ! [A3: C] : dvd_dvd(C,euclid7384307370059645450egment(C,A3),one_one(C)) ) ).

% is_unit_division_segment
tff(fact_3323_finite__lists__length__le,axiom,
    ! [C: $tType,A4: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => aa(set(list(C)),$o,finite_finite2(list(C)),collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_eh(set(C),fun(nat,fun(list(C),$o)),A4),N))) ) ).

% finite_lists_length_le
tff(fact_3324_foldl__set,axiom,
    ! [C: $tType,La: list(set(C))] : aa(list(set(C)),set(C),aa(set(C),fun(list(set(C)),set(C)),aa(fun(set(C),fun(set(C),set(C))),fun(set(C),fun(list(set(C)),set(C))),foldl(set(C),set(C)),sup_sup(set(C))),bot_bot(set(C))),La) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),collect(set(C),aTP_Lamp_ei(list(set(C)),fun(set(C),$o),La))) ).

% foldl_set
tff(fact_3325_Pow__set_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      pow(C,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) = $let(
        a2: set(set(C)),
        a2:= pow(C,aa(list(C),set(C),set2(C),Xs)),
        aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),sup_sup(set(set(C))),a2),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X)),a2)) ) ).

% Pow_set(2)
tff(fact_3326_image__mult__atLeastAtMost__if_H,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [C3: C,X: C,Y: C] :
          aa(set(C),set(C),image2(C,C,aTP_Lamp_ej(C,fun(C,C),C3)),set_or1337092689740270186AtMost(C,X,Y)) = $ite(
            aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),C3),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),C3),aa(C,C,aa(C,fun(C,C),times_times(C),Y),C3)),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),times_times(C),Y),C3),aa(C,C,aa(C,fun(C,C),times_times(C),X),C3))),
            bot_bot(set(C)) ) ) ).

% image_mult_atLeastAtMost_if'
tff(fact_3327_image__affinity__atLeastAtMost,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [M2: C,C3: C,A3: C,B2: C] :
          aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),aTP_Lamp_ek(C,fun(C,fun(C,C)),M2),C3)),set_or1337092689740270186AtMost(C,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(C,A3,B2) = bot_bot(set(C)),
            bot_bot(set(C)),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),M2),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),M2),A3)),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),M2),B2)),C3)),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),M2),B2)),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),M2),A3)),C3))) ) ) ).

% image_affinity_atLeastAtMost
tff(fact_3328_image__affinity__atLeastAtMost__diff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [M2: C,C3: C,A3: C,B2: C] :
          aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),aTP_Lamp_el(C,fun(C,fun(C,C)),M2),C3)),set_or1337092689740270186AtMost(C,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(C,A3,B2) = bot_bot(set(C)),
            bot_bot(set(C)),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),M2),set_or1337092689740270186AtMost(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),M2),A3),C3),minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),M2),B2),C3)),set_or1337092689740270186AtMost(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),M2),B2),C3),minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),M2),A3),C3))) ) ) ).

% image_affinity_atLeastAtMost_diff
tff(fact_3329_image__affinity__atLeastAtMost__div,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [M2: C,C3: C,A3: C,B2: C] :
          aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),aTP_Lamp_em(C,fun(C,fun(C,C)),M2),C3)),set_or1337092689740270186AtMost(C,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(C,A3,B2) = bot_bot(set(C)),
            bot_bot(set(C)),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),M2),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,A3,M2)),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,B2,M2)),C3)),set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,B2,M2)),C3),aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,A3,M2)),C3))) ) ) ).

% image_affinity_atLeastAtMost_div
tff(fact_3330_image__affinity__atLeastAtMost__div__diff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [M2: C,C3: C,A3: C,B2: C] :
          aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),aTP_Lamp_en(C,fun(C,fun(C,C)),M2),C3)),set_or1337092689740270186AtMost(C,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(C,A3,B2) = bot_bot(set(C)),
            bot_bot(set(C)),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),M2),set_or1337092689740270186AtMost(C,minus_minus(C,divide_divide(C,A3,M2),C3),minus_minus(C,divide_divide(C,B2,M2),C3)),set_or1337092689740270186AtMost(C,minus_minus(C,divide_divide(C,B2,M2),C3),minus_minus(C,divide_divide(C,A3,M2),C3))) ) ) ).

% image_affinity_atLeastAtMost_div_diff
tff(fact_3331_prod__gen__delta,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),A3: C,B2: fun(C,D),C3: D] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),aa(D,fun(C,D),aa(fun(C,D),fun(D,fun(C,D)),aTP_Lamp_eo(C,fun(fun(C,D),fun(D,fun(C,D))),A3),B2),C3)),S) = $ite(member2(C,A3,S),aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,B2,A3)),aa(nat,D,aa(D,fun(nat,D),power_power(D),C3),minus_minus(nat,finite_card(C,S),one_one(nat)))),aa(nat,D,aa(D,fun(nat,D),power_power(D),C3),finite_card(C,S))) ) ) ) ).

% prod_gen_delta
tff(fact_3332_mergesort__remdups__def,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : aa(list(C),list(C),mergesort_remdups(C),Xs) = merge_list(C,nil(list(C)),aa(list(C),list(list(C)),aa(fun(C,list(C)),fun(list(C),list(list(C))),map(C,list(C)),aTP_Lamp_ep(C,list(C))),Xs)) ) ).

% mergesort_remdups_def
tff(fact_3333_card__lists__length__eq,axiom,
    ! [C: $tType,A4: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( finite_card(list(C),collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_dx(set(C),fun(nat,fun(list(C),$o)),A4),N))) = aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),finite_card(C,A4)),N) ) ) ).

% card_lists_length_eq
tff(fact_3334_transpose_Osimps_I3_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Xss2: list(list(C))] : transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Xss2)) = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aTP_Lamp_eq(C,fun(list(C),list(C))))),Xss2)))),transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Xs),aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aa(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C))),aa(list(list(C)),fun(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C)))),case_list(list(list(C)),C),nil(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))))),Xss2))))) ).

% transpose.simps(3)
tff(fact_3335_transpose_Oelims,axiom,
    ! [C: $tType,X: list(list(C)),Y: list(list(C))] :
      ( ( transpose(C,X) = Y )
     => ( ( ( X = nil(list(C)) )
         => ( Y != nil(list(C)) ) )
       => ( ! [Xss: list(list(C))] :
              ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss) )
             => ( Y != transpose(C,Xss) ) )
         => ~ ! [X2: C,Xs2: list(C),Xss: list(list(C))] :
                ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xss) )
               => ( Y != aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aTP_Lamp_eq(C,fun(list(C),list(C))))),Xss)))),transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Xs2),aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aa(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C))),aa(list(list(C)),fun(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C)))),case_list(list(list(C)),C),nil(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))))),Xss))))) ) ) ) ) ) ).

% transpose.elims
tff(fact_3336_prod_Oin__pairs,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),M2: nat,N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),M2),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_es(fun(nat,C),fun(nat,C),G)),set_or1337092689740270186AtMost(nat,M2,N)) ) ).

% prod.in_pairs
tff(fact_3337_prod_Oin__pairs__0,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_ord_atMost(nat,aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),N)))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_es(fun(nat,C),fun(nat,C),G)),set_ord_atMost(nat,N)) ) ).

% prod.in_pairs_0
tff(fact_3338_signed__take__bit__code,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat,A3: C] :
          bit_ri4674362597316999326ke_bit(C,N,A3) = $let(
            l2: C,
            l2:= bit_se2584673776208193580ke_bit(C,aa(nat,nat,suc,N),A3),
            $ite(bit_se5641148757651400278ts_bit(C,l2,N),aa(C,C,aa(C,fun(C,C),plus_plus(C),l2),bit_se4730199178511100633sh_bit(C,aa(nat,nat,suc,N),aa(C,C,uminus_uminus(C),one_one(C)))),l2) ) ) ).

% signed_take_bit_code
tff(fact_3339_gbinomial__mult__fact_H,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,A3),K)),semiring_char_0_fact(C,K)) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_et(C,fun(nat,C),A3)),set_or7035219750837199246ssThan(nat,zero_zero(nat),K)) ) ).

% gbinomial_mult_fact'
tff(fact_3340_gbinomial__mult__fact,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),semiring_char_0_fact(C,K)),aa(nat,C,gbinomial(C,A3),K)) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aTP_Lamp_et(C,fun(nat,C),A3)),set_or7035219750837199246ssThan(nat,zero_zero(nat),K)) ) ).

% gbinomial_mult_fact
tff(fact_3341_prod_Ozero__middle,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [P3: nat,K: nat,G: fun(nat,C),H: fun(nat,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),P3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),P3)
           => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aa(fun(nat,C),fun(nat,C),aa(fun(nat,C),fun(fun(nat,C),fun(nat,C)),aTP_Lamp_eu(nat,fun(fun(nat,C),fun(fun(nat,C),fun(nat,C))),K),G),H)),set_ord_atMost(nat,P3)) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aa(fun(nat,C),fun(nat,C),aa(fun(nat,C),fun(fun(nat,C),fun(nat,C)),aTP_Lamp_ev(nat,fun(fun(nat,C),fun(fun(nat,C),fun(nat,C))),K),G),H)),set_ord_atMost(nat,minus_minus(nat,P3,aa(nat,nat,suc,zero_zero(nat))))) ) ) ) ) ).

% prod.zero_middle
tff(fact_3342_transpose__rectangle,axiom,
    ! [C: $tType,Xs: list(list(C)),N: nat] :
      ( ( ( Xs = nil(list(C)) )
       => ( N = zero_zero(nat) ) )
     => ( ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(list(C)),nat,size_size(list(list(C))),Xs))
           => ( aa(list(C),nat,size_size(list(C)),aa(nat,list(C),nth(list(C),Xs),I3)) = N ) )
       => ( transpose(C,Xs) = aa(list(nat),list(list(C)),aa(fun(nat,list(C)),fun(list(nat),list(list(C))),map(nat,list(C)),aTP_Lamp_ex(list(list(C)),fun(nat,list(C)),Xs)),upt(zero_zero(nat),N)) ) ) ) ).

% transpose_rectangle
tff(fact_3343_card__lists__distinct__length__eq_H,axiom,
    ! [C: $tType,K: nat,A4: set(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),finite_card(C,A4))
     => ( finite_card(list(C),collect(list(C),aa(set(C),fun(list(C),$o),aTP_Lamp_ey(nat,fun(set(C),fun(list(C),$o)),K),A4))) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),aTP_Lamp_ez(nat,nat)),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),minus_minus(nat,finite_card(C,A4),K)),one_one(nat)),finite_card(C,A4))) ) ) ).

% card_lists_distinct_length_eq'
tff(fact_3344_card__lists__distinct__length__eq,axiom,
    ! [C: $tType,A4: set(C),K: nat] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),finite_card(C,A4))
       => ( finite_card(list(C),collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_aw(set(C),fun(nat,fun(list(C),$o)),A4),K))) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),aTP_Lamp_ez(nat,nat)),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),minus_minus(nat,finite_card(C,A4),K)),one_one(nat)),finite_card(C,A4))) ) ) ) ).

% card_lists_distinct_length_eq
tff(fact_3345_set__Cons__sing__Nil,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(list(C)),set(list(C)),aa(set(C),fun(set(list(C)),set(list(C))),set_Cons(C),A4),aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),nil(C)),bot_bot(set(list(C))))) = aa(set(C),set(list(C)),image2(C,list(C),aTP_Lamp_fa(C,list(C))),A4) ).

% set_Cons_sing_Nil
tff(fact_3346_gbinomial__code,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,K: nat] :
          aa(nat,C,gbinomial(C,A3),K) = $ite(K = zero_zero(nat),one_one(C),divide_divide(C,set_fo6178422350223883121st_nat(C,aTP_Lamp_fb(C,fun(nat,fun(C,C)),A3),zero_zero(nat),minus_minus(nat,K,one_one(nat)),one_one(C)),semiring_char_0_fact(C,K))) ) ).

% gbinomial_code
tff(fact_3347_product__code,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D)] : product_product(C,D,aa(list(C),set(C),set2(C),Xs),aa(list(D),set(D),set2(D),Ys)) = aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(list(product_prod(C,D))),list(product_prod(C,D)),concat(product_prod(C,D)),aa(list(C),list(list(product_prod(C,D))),aa(fun(C,list(product_prod(C,D))),fun(list(C),list(list(product_prod(C,D)))),map(C,list(product_prod(C,D))),aTP_Lamp_de(list(D),fun(C,list(product_prod(C,D))),Ys)),Xs))) ).

% product_code
tff(fact_3348_nth__nth__transpose__sorted,axiom,
    ! [C: $tType,Xs: list(list(C)),I: nat,J: nat] :
      ( sorted_wrt(nat,ord_less_eq(nat),aa(list(nat),list(nat),rev(nat),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),Xs)))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(list(C)),nat,size_size(list(list(C))),transpose(C,Xs)))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(list(C)),nat,size_size(list(list(C))),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fc(nat,fun(list(C),$o),I)),Xs)))
         => ( aa(nat,C,nth(C,aa(nat,list(C),nth(list(C),transpose(C,Xs)),I)),J) = aa(nat,C,nth(C,aa(nat,list(C),nth(list(C),Xs),J)),I) ) ) ) ) ).

% nth_nth_transpose_sorted
tff(fact_3349_pochhammer__code,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [A3: C,N: nat] :
          comm_s3205402744901411588hammer(C,A3,N) = $ite(N = zero_zero(nat),one_one(C),set_fo6178422350223883121st_nat(C,aTP_Lamp_fd(C,fun(nat,fun(C,C)),A3),zero_zero(nat),minus_minus(nat,N,one_one(nat)),one_one(C))) ) ).

% pochhammer_code
tff(fact_3350_predicate1I,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ! [X2: C] :
          ( aa(C,$o,Pa,X2)
         => aa(C,$o,Q,X2) )
     => aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less_eq(fun(C,$o)),Pa),Q) ) ).

% predicate1I
tff(fact_3351_inf1I,axiom,
    ! [C: $tType,A4: fun(C,$o),X: C,B3: fun(C,$o)] :
      ( aa(C,$o,A4,X)
     => ( aa(C,$o,B3,X)
       => aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),A4),B3),X) ) ) ).

% inf1I
tff(fact_3352_inf2I,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o)),X: C,Y: D,B3: fun(C,fun(D,$o))] :
      ( aa(D,$o,aa(C,fun(D,$o),A4,X),Y)
     => ( aa(D,$o,aa(C,fun(D,$o),B3,X),Y)
       => aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),inf_inf(fun(C,fun(D,$o))),A4),B3),X),Y) ) ) ).

% inf2I
tff(fact_3353_filter__filter,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Q),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(fun(C,$o),fun(C,$o),aTP_Lamp_fe(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Pa),Q)),Xs) ).

% filter_filter
tff(fact_3354_sup1CI,axiom,
    ! [C: $tType,B3: fun(C,$o),X: C,A4: fun(C,$o)] :
      ( ( ~ aa(C,$o,B3,X)
       => aa(C,$o,A4,X) )
     => aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),sup_sup(fun(C,$o)),A4),B3),X) ) ).

% sup1CI
tff(fact_3355_filter__True,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X2) )
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = Xs ) ) ).

% filter_True
tff(fact_3356_filter__append,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Ys)) ).

% filter_append
tff(fact_3357_remove1__filter__not,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      ( ~ aa(C,$o,Pa,X)
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) ) ) ).

% remove1_filter_not
tff(fact_3358_removeAll__filter__not,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      ( ~ aa(C,$o,Pa,X)
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) ) ) ).

% removeAll_filter_not
tff(fact_3359_set__filter,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = collect(C,aa(list(C),fun(C,$o),aTP_Lamp_ff(fun(C,$o),fun(list(C),fun(C,$o)),Pa),Xs)) ).

% set_filter
tff(fact_3360_filter__False,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ~ aa(C,$o,Pa,X2) )
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = nil(C) ) ) ).

% filter_False
tff(fact_3361_predicate1D,axiom,
    ! [C: $tType,Pa: fun(C,$o),Q: fun(C,$o),X: C] :
      ( aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less_eq(fun(C,$o)),Pa),Q)
     => ( aa(C,$o,Pa,X)
       => aa(C,$o,Q,X) ) ) ).

% predicate1D
tff(fact_3362_rev__predicate1D,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Q: fun(C,$o)] :
      ( aa(C,$o,Pa,X)
     => ( aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less_eq(fun(C,$o)),Pa),Q)
       => aa(C,$o,Q,X) ) ) ).

% rev_predicate1D
tff(fact_3363_sup1I2,axiom,
    ! [C: $tType,B3: fun(C,$o),X: C,A4: fun(C,$o)] :
      ( aa(C,$o,B3,X)
     => aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),sup_sup(fun(C,$o)),A4),B3),X) ) ).

% sup1I2
tff(fact_3364_sup1I1,axiom,
    ! [C: $tType,A4: fun(C,$o),X: C,B3: fun(C,$o)] :
      ( aa(C,$o,A4,X)
     => aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),sup_sup(fun(C,$o)),A4),B3),X) ) ).

% sup1I1
tff(fact_3365_sup1E,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o),X: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),sup_sup(fun(C,$o)),A4),B3),X)
     => ( ~ aa(C,$o,A4,X)
       => aa(C,$o,B3,X) ) ) ).

% sup1E
tff(fact_3366_inf2D2,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(C,fun(D,$o)),X: C,Y: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),inf_inf(fun(C,fun(D,$o))),A4),B3),X),Y)
     => aa(D,$o,aa(C,fun(D,$o),B3,X),Y) ) ).

% inf2D2
tff(fact_3367_inf2D1,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(C,fun(D,$o)),X: C,Y: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),inf_inf(fun(C,fun(D,$o))),A4),B3),X),Y)
     => aa(D,$o,aa(C,fun(D,$o),A4,X),Y) ) ).

% inf2D1
tff(fact_3368_inf1D2,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o),X: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),A4),B3),X)
     => aa(C,$o,B3,X) ) ).

% inf1D2
tff(fact_3369_inf1D1,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o),X: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),A4),B3),X)
     => aa(C,$o,A4,X) ) ).

% inf1D1
tff(fact_3370_inf2E,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(C,fun(D,$o)),X: C,Y: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),inf_inf(fun(C,fun(D,$o))),A4),B3),X),Y)
     => ~ ( aa(D,$o,aa(C,fun(D,$o),A4,X),Y)
         => ~ aa(D,$o,aa(C,fun(D,$o),B3,X),Y) ) ) ).

% inf2E
tff(fact_3371_inf1E,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o),X: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),A4),B3),X)
     => ~ ( aa(C,$o,A4,X)
         => ~ aa(C,$o,B3,X) ) ) ).

% inf1E
tff(fact_3372_filter_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),nil(C)) = nil(C) ).

% filter.simps(1)
tff(fact_3373_rev__filter,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),rev(C),Xs)) ).

% rev_filter
tff(fact_3374_filter_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(aa(C,$o,Pa,X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) ).

% filter.simps(2)
tff(fact_3375_distinct__filter,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) ) ).

% distinct_filter
tff(fact_3376_filter__cong,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ( Xs = Ys )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Ys))
           => ( aa(C,$o,Pa,X2)
            <=> aa(C,$o,Q,X2) ) )
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Q),Ys) ) ) ) ).

% filter_cong
tff(fact_3377_filter__id__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = Xs )
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) ) ) ).

% filter_id_conv
tff(fact_3378_sorted__wrt__filter,axiom,
    ! [C: $tType,F: fun(C,fun(C,$o)),Xs: list(C),Pa: fun(C,$o)] :
      ( sorted_wrt(C,F,Xs)
     => sorted_wrt(C,F,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) ) ).

% sorted_wrt_filter
tff(fact_3379_filter__remove1,axiom,
    ! [C: $tType,Q: fun(C,$o),X: C,Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Q),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Q),Xs)) ).

% filter_remove1
tff(fact_3380_partition__in__shuffles,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] : member2(list(C),Xs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_bi(fun(C,$o),fun(C,$o),Pa)),Xs))) ).

% partition_in_shuffles
tff(fact_3381_removeAll__filter__not__eq,axiom,
    ! [C: $tType,X: C] : aa(C,fun(list(C),list(C)),removeAll(C),X) = aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),aTP_Lamp_fg(C,fun(C,$o)),X)) ).

% removeAll_filter_not_eq
tff(fact_3382_empty__filter__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) )
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => ~ aa(C,$o,Pa,X4) ) ) ).

% empty_filter_conv
tff(fact_3383_filter__empty__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = nil(C) )
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => ~ aa(C,$o,Pa,X4) ) ) ).

% filter_empty_conv
tff(fact_3384_filter__is__subset,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs))),aa(list(C),set(C),set2(C),Xs)) ).

% filter_is_subset
tff(fact_3385_length__filter__le,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_filter_le
tff(fact_3386_sorted__filter_H,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),Pa: fun(C,$o)] :
          ( sorted_wrt(C,ord_less_eq(C),La)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),La)) ) ) ).

% sorted_filter'
tff(fact_3387_distinct__map__filter,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),Pa: fun(D,$o)] :
      ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
     => aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs))) ) ).

% distinct_map_filter
tff(fact_3388_last__filter,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ( Xs != nil(C) )
     => ( aa(C,$o,Pa,last(C,Xs))
       => ( last(C,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = last(C,Xs) ) ) ) ).

% last_filter
tff(fact_3389_sum__length__filter__compl,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs))),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_bi(fun(C,$o),fun(C,$o),Pa)),Xs))) = aa(list(C),nat,size_size(list(C)),Xs) ).

% sum_length_filter_compl
tff(fact_3390_filter__concat,axiom,
    ! [C: $tType,P3: fun(C,$o),Xs: list(list(C))] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),P3),aa(list(list(C)),list(C),concat(C),Xs)) = aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),P3)),Xs)) ).

% filter_concat
tff(fact_3391_inter__set__filter,axiom,
    ! [C: $tType,A4: set(C),Xs: list(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(list(C),set(C),set2(C),Xs)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_a(set(C),fun(C,$o),A4)),Xs)) ).

% inter_set_filter
tff(fact_3392_sorted__same,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [G: fun(list(C),C),Xs: list(C)] : sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(list(C),fun(C,$o),aTP_Lamp_fh(fun(list(C),C),fun(list(C),fun(C,$o)),G),Xs)),Xs)) ) ).

% sorted_same
tff(fact_3393_filter__shuffles,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C)] : aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys)) = aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Ys)) ).

% filter_shuffles
tff(fact_3394_concat__filter__neq__Nil,axiom,
    ! [C: $tType,Xs: list(list(C))] : aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fi(list(C),$o)),Xs)) = aa(list(list(C)),list(C),concat(C),Xs) ).

% concat_filter_neq_Nil
tff(fact_3395_union__coset__filter,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),coset(C,Xs)),A4) = coset(C,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_bh(set(C),fun(C,$o),A4)),Xs)) ).

% union_coset_filter
tff(fact_3396_length__filter__less,axiom,
    ! [C: $tType,X: C,Xs: list(C),Pa: fun(C,$o)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( ~ aa(C,$o,Pa,X)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ) ) ).

% length_filter_less
tff(fact_3397_filter__eq__Cons__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Ys: list(C),X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Ys) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) )
    <=> ? [Us: list(C),Vs2: list(C)] :
          ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Vs2)) )
          & ! [X4: C] :
              ( member2(C,X4,aa(list(C),set(C),set2(C),Us))
             => ~ aa(C,$o,Pa,X4) )
          & aa(C,$o,Pa,X)
          & ( Xs = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Vs2) ) ) ) ).

% filter_eq_Cons_iff
tff(fact_3398_Cons__eq__filter__iff,axiom,
    ! [C: $tType,X: C,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Ys) )
    <=> ? [Us: list(C),Vs2: list(C)] :
          ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Vs2)) )
          & ! [X4: C] :
              ( member2(C,X4,aa(list(C),set(C),set2(C),Us))
             => ~ aa(C,$o,Pa,X4) )
          & aa(C,$o,Pa,X)
          & ( Xs = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Vs2) ) ) ) ).

% Cons_eq_filter_iff
tff(fact_3399_filter__eq__ConsD,axiom,
    ! [C: $tType,Pa: fun(C,$o),Ys: list(C),X: C,Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Ys) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) )
     => ? [Us3: list(C),Vs3: list(C)] :
          ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Vs3)) )
          & ! [X3: C] :
              ( member2(C,X3,aa(list(C),set(C),set2(C),Us3))
             => ~ aa(C,$o,Pa,X3) )
          & aa(C,$o,Pa,X)
          & ( Xs = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Vs3) ) ) ) ).

% filter_eq_ConsD
tff(fact_3400_Cons__eq__filterD,axiom,
    ! [C: $tType,X: C,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Ys) )
     => ? [Us3: list(C),Vs3: list(C)] :
          ( ( Ys = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Vs3)) )
          & ! [X3: C] :
              ( member2(C,X3,aa(list(C),set(C),set2(C),Us3))
             => ~ aa(C,$o,Pa,X3) )
          & aa(C,$o,Pa,X)
          & ( Xs = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Vs3) ) ) ) ).

% Cons_eq_filterD
tff(fact_3401_sorted__filter,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D),Pa: fun(D,$o)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
         => sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs))) ) ) ).

% sorted_filter
tff(fact_3402_inj__on__filter__key__eq,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),Y: C,Xs: list(C)] :
      ( inj_on(C,D,F,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),aa(list(C),set(C),set2(C),Xs)))
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),aTP_Lamp_fj(fun(C,D),fun(C,fun(C,$o)),F),Y)),Xs) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),fequal(C),Y)),Xs) ) ) ).

% inj_on_filter_key_eq
tff(fact_3403_sorted__map__same,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),G: fun(list(D),C),Xs: list(D)] : sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),aa(list(D),fun(D,$o),aa(fun(list(D),C),fun(list(D),fun(D,$o)),aTP_Lamp_fk(fun(D,C),fun(fun(list(D),C),fun(list(D),fun(D,$o))),F),G),Xs)),Xs))) ) ).

% sorted_map_same
tff(fact_3404_length__filter__conv__card,axiom,
    ! [C: $tType,P3: fun(C,$o),Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),P3),Xs)) = finite_card(nat,collect(nat,aa(list(C),fun(nat,$o),aTP_Lamp_fl(fun(C,$o),fun(list(C),fun(nat,$o)),P3),Xs))) ).

% length_filter_conv_card
tff(fact_3405_minus__coset__filter,axiom,
    ! [C: $tType,A4: set(C),Xs: list(C)] : minus_minus(set(C),A4,coset(C,Xs)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_a(set(C),fun(C,$o),A4)),Xs)) ).

% minus_coset_filter
tff(fact_3406_filter__eq__snocD,axiom,
    ! [C: $tType,Pa: fun(C,$o),La: list(C),L_a: list(C),X: C] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),La) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L_a),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) )
     => ( member2(C,X,aa(list(C),set(C),set2(C),La))
        & aa(C,$o,Pa,X) ) ) ).

% filter_eq_snocD
tff(fact_3407_filter__conv__foldr,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),foldr(C,list(C)),aTP_Lamp_fm(fun(C,$o),fun(C,fun(list(C),list(C))),Pa)),Xs),nil(C)) ).

% filter_conv_foldr
tff(fact_3408_set__minus__filter__out,axiom,
    ! [C: $tType,Xs: list(C),Y: C] : minus_minus(set(C),aa(list(C),set(C),set2(C),Xs),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C)))) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),Y)),Xs)) ).

% set_minus_filter_out
tff(fact_3409_filter__shuffles__disjoint2_I1_J,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) )
     => ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_fo(list(C),fun(C,$o),Ys)),Zs) = Ys ) ) ) ).

% filter_shuffles_disjoint2(1)
tff(fact_3410_filter__shuffles__disjoint2_I2_J,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) )
     => ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_fp(list(C),fun(C,$o),Ys)),Zs) = Xs ) ) ) ).

% filter_shuffles_disjoint2(2)
tff(fact_3411_filter__shuffles__disjoint1_I1_J,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) )
     => ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_fo(list(C),fun(C,$o),Xs)),Zs) = Xs ) ) ) ).

% filter_shuffles_disjoint1(1)
tff(fact_3412_filter__shuffles__disjoint1_I2_J,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Zs: list(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) = bot_bot(set(C)) )
     => ( member2(list(C),Zs,aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys))
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_fp(list(C),fun(C,$o),Xs)),Zs) = Ys ) ) ) ).

% filter_shuffles_disjoint1(2)
tff(fact_3413_filter__nth__ex__nth,axiom,
    ! [C: $tType,N: nat,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)))
     => ? [M4: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M4)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M4),aa(list(C),nat,size_size(list(C)),Xs))
          & ( aa(nat,C,nth(C,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)),N) = aa(nat,C,nth(C,Xs),M4) )
          & ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),M4),Xs)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) ) ) ) ).

% filter_nth_ex_nth
tff(fact_3414_transpose__aux__max,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Xss2: list(list(D))] : aa(nat,nat,aa(nat,fun(nat,nat),ord_max(nat),aa(nat,nat,suc,aa(list(C),nat,size_size(list(C)),Xs))),aa(nat,nat,aa(list(list(D)),fun(nat,nat),aa(fun(list(D),fun(nat,nat)),fun(list(list(D)),fun(nat,nat)),foldr(list(D),nat),aTP_Lamp_fq(list(D),fun(nat,nat))),Xss2),zero_zero(nat))) = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),ord_max(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(nat,nat,aa(list(list(D)),fun(nat,nat),aa(fun(list(D),fun(nat,nat)),fun(list(list(D)),fun(nat,nat)),foldr(list(D),nat),aTP_Lamp_fr(list(D),fun(nat,nat))),aa(list(list(D)),list(list(D)),aa(fun(list(D),$o),fun(list(list(D)),list(list(D))),filter2(list(D)),aTP_Lamp_fs(list(D),$o)),Xss2)),zero_zero(nat)))) ).

% transpose_aux_max
tff(fact_3415_distinct__length__filter,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),collect(C,Pa)),aa(list(C),set(C),set2(C),Xs))) ) ) ).

% distinct_length_filter
tff(fact_3416_transpose__max__length,axiom,
    ! [C: $tType,Xs: list(list(C))] : aa(nat,nat,aa(list(list(C)),fun(nat,nat),aa(fun(list(C),fun(nat,nat)),fun(list(list(C)),fun(nat,nat)),foldr(list(C),nat),aTP_Lamp_dj(list(C),fun(nat,nat))),transpose(C,Xs)),zero_zero(nat)) = aa(list(list(C)),nat,size_size(list(list(C))),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fi(list(C),$o)),Xs)) ).

% transpose_max_length
tff(fact_3417_transpose__aux__filter__tail,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aa(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C))),aa(list(list(C)),fun(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C)))),case_list(list(list(C)),C),nil(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))))),Xss2)) = aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),tl(C)),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fi(list(C),$o)),Xss2)) ).

% transpose_aux_filter_tail
tff(fact_3418_transpose__aux__filter__head,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aTP_Lamp_eq(C,fun(list(C),list(C))))),Xss2)) = aa(list(list(C)),list(C),aa(fun(list(C),C),fun(list(list(C)),list(C)),map(list(C),C),hd(C)),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fi(list(C),$o)),Xss2)) ).

% transpose_aux_filter_head
tff(fact_3419_prod__atLeastAtMost__code,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [F: fun(nat,C),A3: nat,B2: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),F),set_or1337092689740270186AtMost(nat,A3,B2)) = set_fo6178422350223883121st_nat(C,aTP_Lamp_ft(fun(nat,C),fun(nat,fun(C,C)),F),A3,B2,one_one(C)) ) ).

% prod_atLeastAtMost_code
tff(fact_3420_nth__transpose,axiom,
    ! [C: $tType,I: nat,Xs: list(list(C))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(list(C)),nat,size_size(list(list(C))),transpose(C,Xs)))
     => ( aa(nat,list(C),nth(list(C),transpose(C,Xs)),I) = aa(list(list(C)),list(C),aa(fun(list(C),C),fun(list(list(C)),list(C)),map(list(C),C),aTP_Lamp_fu(nat,fun(list(C),C),I)),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fc(nat,fun(list(C),$o),I)),Xs)) ) ) ).

% nth_transpose
tff(fact_3421_distinct__concat_H,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( aa(list(list(C)),$o,distinct(list(C)),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fi(list(C),$o)),Xs))
     => ( ! [Ys2: list(C)] :
            ( member2(list(C),Ys2,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
           => aa(list(C),$o,distinct(C),Ys2) )
       => ( ! [Ys2: list(C),Zs3: list(C)] :
              ( member2(list(C),Ys2,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
             => ( member2(list(C),Zs3,aa(list(list(C)),set(list(C)),set2(list(C)),Xs))
               => ( ( Ys2 != Zs3 )
                 => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(list(C),set(C),set2(C),Ys2)),aa(list(C),set(C),set2(C),Zs3)) = bot_bot(set(C)) ) ) ) )
         => aa(list(C),$o,distinct(C),aa(list(list(C)),list(C),concat(C),Xs)) ) ) ) ).

% distinct_concat'
tff(fact_3422_transpose__column__length,axiom,
    ! [C: $tType,Xs: list(list(C)),I: nat] :
      ( sorted_wrt(nat,ord_less_eq(nat),aa(list(nat),list(nat),rev(nat),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),Xs)))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(list(C)),nat,size_size(list(list(C))),Xs))
       => ( aa(list(list(C)),nat,size_size(list(list(C))),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fc(nat,fun(list(C),$o),I)),transpose(C,Xs))) = aa(list(C),nat,size_size(list(C)),aa(nat,list(C),nth(list(C),Xs),I)) ) ) ) ).

% transpose_column_length
tff(fact_3423_transpose__column,axiom,
    ! [C: $tType,Xs: list(list(C)),I: nat] :
      ( sorted_wrt(nat,ord_less_eq(nat),aa(list(nat),list(nat),rev(nat),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),Xs)))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(list(C)),nat,size_size(list(list(C))),Xs))
       => ( aa(list(list(C)),list(C),aa(fun(list(C),C),fun(list(list(C)),list(C)),map(list(C),C),aTP_Lamp_fu(nat,fun(list(C),C),I)),aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),filter2(list(C)),aTP_Lamp_fc(nat,fun(list(C),$o),I)),transpose(C,Xs))) = aa(nat,list(C),nth(list(C),Xs),I) ) ) ) ).

% transpose_column
tff(fact_3424_choose__odd__sum,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_fv(nat,fun(nat,C),N)),set_ord_atMost(nat,N))) = aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N) ) ) ) ).

% choose_odd_sum
tff(fact_3425_choose__even__sum,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_fw(nat,fun(nat,C),N)),set_ord_atMost(nat,N))) = aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N) ) ) ) ).

% choose_even_sum
tff(fact_3426_gbinomial__partial__row__sum,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,M2: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_fx(C,fun(nat,C),A3)),set_ord_atMost(nat,M2)) = aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),M2)),one_one(C)),aa(num,C,numeral_numeral(C),bit0(one2)))),aa(nat,C,gbinomial(C,A3),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),one_one(nat)))) ) ).

% gbinomial_partial_row_sum
tff(fact_3427_gbinomial__r__part__sum,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [M2: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(nat,C,semiring_1_of_nat(C),M2))),one_one(C)))),set_ord_atMost(nat,M2)) = aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),M2)) ) ).

% gbinomial_r_part_sum
tff(fact_3428_sum__gp,axiom,
    ! [C: $tType] :
      ( ( division_ring(C)
        & comm_ring(C) )
     => ! [X: C,M2: nat,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_or1337092689740270186AtMost(nat,M2,N)) = $ite(
            aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2),
            zero_zero(C),
            $ite(X = one_one(C),aa(nat,C,semiring_1_of_nat(C),minus_minus(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)),M2)),divide_divide(C,minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(nat,nat,suc,N))),minus_minus(C,one_one(C),X))) ) ) ).

% sum_gp
tff(fact_3429_sum_Oempty,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(C)
     => ! [G: fun(D,C)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),G),bot_bot(set(D))) = zero_zero(C) ) ).

% sum.empty
tff(fact_3430_sum__constant,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(C)
     => ! [Y: C,A4: set(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),aTP_Lamp_fy(C,fun(D,C),Y)),A4) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),finite_card(D,A4))),Y) ) ).

% sum_constant
tff(fact_3431_sum__zero__power,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [C3: fun(nat,C),A4: set(nat)] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_fz(fun(nat,C),fun(nat,C),C3)),A4) = $ite(
            ( aa(set(nat),$o,finite_finite2(nat),A4)
            & member2(nat,zero_zero(nat),A4) ),
            aa(nat,C,C3,zero_zero(nat)),
            zero_zero(C) ) ) ).

% sum_zero_power
tff(fact_3432_sum__mult__of__bool__eq,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(D)
     => ! [A4: set(C),F: fun(C,D),Pa: fun(C,$o)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(fun(C,$o),fun(C,D),aTP_Lamp_ga(fun(C,D),fun(fun(C,$o),fun(C,D)),F),Pa)),A4) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa))) ) ) ) ).

% sum_mult_of_bool_eq
tff(fact_3433_sum__of__bool__mult__eq,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(D)
     => ! [A4: set(C),Pa: fun(C,$o),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(fun(C,D),fun(C,D),aTP_Lamp_gb(fun(C,$o),fun(fun(C,D),fun(C,D)),Pa),F)),A4) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa))) ) ) ) ).

% sum_of_bool_mult_eq
tff(fact_3434_sum__zero__power_H,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [C3: fun(nat,C),D3: fun(nat,C),A4: set(nat)] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(fun(nat,C),fun(nat,C),aTP_Lamp_gc(fun(nat,C),fun(fun(nat,C),fun(nat,C)),C3),D3)),A4) = $ite(
            ( aa(set(nat),$o,finite_finite2(nat),A4)
            & member2(nat,zero_zero(nat),A4) ),
            divide_divide(C,aa(nat,C,C3,zero_zero(nat)),aa(nat,C,D3,zero_zero(nat))),
            zero_zero(C) ) ) ).

% sum_zero_power'
tff(fact_3435_sum__of__bool__eq,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(D)
     => ! [A4: set(C),Pa: fun(C,$o)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aTP_Lamp_gd(fun(C,$o),fun(C,D),Pa)),A4) = aa(nat,D,semiring_1_of_nat(D),finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa)))) ) ) ) ) ).

% sum_of_bool_eq
tff(fact_3436_sum__distrib__left,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [R3: C,F: fun(D,C),A4: set(D)] : aa(C,C,aa(C,fun(C,C),times_times(C),R3),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),F),A4)) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),aa(fun(D,C),fun(D,C),aTP_Lamp_ge(C,fun(fun(D,C),fun(D,C)),R3),F)),A4) ) ).

% sum_distrib_left
tff(fact_3437_sum__distrib__right,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [F: fun(D,C),A4: set(D),R3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),F),A4)),R3) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),aa(C,fun(D,C),aTP_Lamp_gf(fun(D,C),fun(C,fun(D,C)),F),R3)),A4) ) ).

% sum_distrib_right
tff(fact_3438_sum__product,axiom,
    ! [E2: $tType,C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [F: fun(D,C),A4: set(D),G: fun(E2,C),B3: set(E2)] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),F),A4)),aa(set(E2),C,aa(fun(E2,C),fun(set(E2),C),groups7311177749621191930dd_sum(E2,C),G),B3)) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),aa(set(E2),fun(D,C),aa(fun(E2,C),fun(set(E2),fun(D,C)),aTP_Lamp_gh(fun(D,C),fun(fun(E2,C),fun(set(E2),fun(D,C))),F),G),B3)),A4) ) ).

% sum_product
tff(fact_3439_sum__strict__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( strict7427464778891057005id_add(D)
     => ! [A4: set(C),F: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C] :
                  ( member2(C,X2,A4)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X2)),aa(C,D,G,X2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),A4)) ) ) ) ) ).

% sum_strict_mono
tff(fact_3440_sum_Ointer__restrict,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),G: fun(C,D),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(set(C),fun(C,D),aTP_Lamp_gi(fun(C,D),fun(set(C),fun(C,D)),G),B3)),A4) ) ) ) ).

% sum.inter_restrict
tff(fact_3441_sum__power__add,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,M2: nat,I5: set(nat)] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(nat,fun(nat,C),aTP_Lamp_gj(C,fun(nat,fun(nat,C)),X),M2)),I5) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),I5)) ) ).

% sum_power_add
tff(fact_3442_filter__upt__take__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),M2: nat,La: list(C),N: nat] : aa(list(nat),list(nat),aa(fun(nat,$o),fun(list(nat),list(nat)),filter2(nat),aa(list(C),fun(nat,$o),aa(nat,fun(list(C),fun(nat,$o)),aTP_Lamp_gk(fun(C,$o),fun(nat,fun(list(C),fun(nat,$o))),Pa),M2),La)),upt(N,M2)) = aa(list(nat),list(nat),aa(fun(nat,$o),fun(list(nat),list(nat)),filter2(nat),aa(list(C),fun(nat,$o),aTP_Lamp_gl(fun(C,$o),fun(list(C),fun(nat,$o)),Pa),La)),upt(N,M2)) ).

% filter_upt_take_conv
tff(fact_3443_sum__pos,axiom,
    ! [D: $tType,C: $tType] :
      ( ordere6911136660526730532id_add(D)
     => ! [I5: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),I5)
         => ( ( I5 != bot_bot(set(C)) )
           => ( ! [I3: C] :
                  ( member2(C,I3,I5)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less(D),zero_zero(D)),aa(C,D,F,I3)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),zero_zero(D)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),I5)) ) ) ) ) ).

% sum_pos
tff(fact_3444_sum__bounded__above,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ordere6911136660526730532id_add(D)
        & semiring_1(D) )
     => ! [A4: set(C),F: fun(C,D),K5: D] :
          ( ! [I3: C] :
              ( member2(C,I3,A4)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,I3)),K5) )
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)),aa(D,D,aa(D,fun(D,D),times_times(D),aa(nat,D,semiring_1_of_nat(D),finite_card(C,A4))),K5)) ) ) ).

% sum_bounded_above
tff(fact_3445_sum__bounded__below,axiom,
    ! [D: $tType,C: $tType] :
      ( ( ordere6911136660526730532id_add(D)
        & semiring_1(D) )
     => ! [A4: set(C),K5: D,F: fun(C,D)] :
          ( ! [I3: C] :
              ( member2(C,I3,A4)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),K5),aa(C,D,F,I3)) )
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(D,D,aa(D,fun(D,D),times_times(D),aa(nat,D,semiring_1_of_nat(D),finite_card(C,A4))),K5)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)) ) ) ).

% sum_bounded_below
tff(fact_3446_sum_Omono__neutral__cong,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [T: set(C),S: set(C),H: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),T)
         => ( aa(set(C),$o,finite_finite2(C),S)
           => ( ! [I3: C] :
                  ( member2(C,I3,minus_minus(set(C),T,S))
                 => ( aa(C,D,H,I3) = zero_zero(D) ) )
             => ( ! [I3: C] :
                    ( member2(C,I3,minus_minus(set(C),S,T))
                   => ( aa(C,D,G,I3) = zero_zero(D) ) )
               => ( ! [X2: C] :
                      ( member2(C,X2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),S),T))
                     => ( aa(C,D,G,X2) = aa(C,D,H,X2) ) )
                 => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),S) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),H),T) ) ) ) ) ) ) ) ).

% sum.mono_neutral_cong
tff(fact_3447_sum_Ounion__inter,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),B3)) ) ) ) ) ).

% sum.union_inter
tff(fact_3448_sum_OInt__Diff,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),G: fun(C,D),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),A4) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),minus_minus(set(C),A4,B3))) ) ) ) ).

% sum.Int_Diff
tff(fact_3449_upt__filter__extend,axiom,
    ! [U: nat,U3: nat,Pa: fun(nat,$o)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),U),U3)
     => ( ! [I3: nat] :
            ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),U),I3)
              & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),U3) )
           => ~ aa(nat,$o,Pa,I3) )
       => ( aa(list(nat),list(nat),aa(fun(nat,$o),fun(list(nat),list(nat)),filter2(nat),Pa),upt(zero_zero(nat),U)) = aa(list(nat),list(nat),aa(fun(nat,$o),fun(list(nat),list(nat)),filter2(nat),Pa),upt(zero_zero(nat),U3)) ) ) ) ).

% upt_filter_extend
tff(fact_3450_sum_OIf__cases,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),Pa: fun(C,$o),H: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_gm(fun(C,$o),fun(fun(C,D),fun(fun(C,D),fun(C,D))),Pa),H),G)),A4) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),H),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa)))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),collect(C,Pa))))) ) ) ) ).

% sum.If_cases
tff(fact_3451_sum_Ounion__inter__neutral,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( ! [X2: C] :
                  ( member2(C,X2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
                 => ( aa(C,D,G,X2) = zero_zero(D) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),B3)) ) ) ) ) ) ).

% sum.union_inter_neutral
tff(fact_3452_sum_Oinsert__remove,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),G: fun(C,D),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(C,D,G,X)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ).

% sum.insert_remove
tff(fact_3453_sum_Oremove,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),X: C,G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),A4) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(C,D,G,X)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ).

% sum.remove
tff(fact_3454_sum__diff1,axiom,
    ! [D: $tType,C: $tType] :
      ( ab_group_add(D)
     => ! [A4: set(C),F: fun(C,D),A3: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = $ite(member2(C,A3,A4),minus_minus(D,aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4),aa(C,D,F,A3)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)) ) ) ) ).

% sum_diff1
tff(fact_3455_sum__Un,axiom,
    ! [D: $tType,C: $tType] :
      ( ab_group_add(D)
     => ! [A4: set(C),B3: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = minus_minus(D,aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),B3)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ) ).

% sum_Un
tff(fact_3456_sum_Ounion__disjoint,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),B3)) ) ) ) ) ) ).

% sum.union_disjoint
tff(fact_3457_sum__Un2,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),B3: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),minus_minus(set(C),A4,B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),minus_minus(set(C),B3,A4)))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ).

% sum_Un2
tff(fact_3458_sum_Ounion__diff2,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(C),B3: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),B3)
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),minus_minus(set(C),A4,B3))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),minus_minus(set(C),B3,A4)))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ) ).

% sum.union_diff2
tff(fact_3459_sum_Odelta__remove,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [S: set(C),A3: C,B2: fun(C,D),C3: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_gn(C,fun(fun(C,D),fun(fun(C,D),fun(C,D))),A3),B2),C3)),S) = $ite(member2(C,A3,S),aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(C,D,B2,A3)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),C3),minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),C3),minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ) ).

% sum.delta_remove
tff(fact_3460_sum__div__partition,axiom,
    ! [C: $tType,D: $tType] :
      ( euclid4440199948858584721cancel(D)
     => ! [A4: set(C),F: fun(C,D),B2: D] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( divide_divide(D,aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4),B2) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(D,fun(C,D),aTP_Lamp_go(fun(C,D),fun(D,fun(C,D)),F),B2)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,aa(D,fun(C,$o),aTP_Lamp_gp(fun(C,D),fun(D,fun(C,$o)),F),B2))))),divide_divide(D,aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,aa(D,fun(C,$o),aTP_Lamp_gq(fun(C,D),fun(D,fun(C,$o)),F),B2)))),B2)) ) ) ) ).

% sum_div_partition
tff(fact_3461_sum_OUNION__disjoint,axiom,
    ! [D: $tType,E2: $tType,C: $tType] :
      ( comm_monoid_add(E2)
     => ! [I5: set(C),A4: fun(C,set(D)),G: fun(D,E2)] :
          ( aa(set(C),$o,finite_finite2(C),I5)
         => ( ! [X2: C] :
                ( member2(C,X2,I5)
               => aa(set(D),$o,finite_finite2(D),aa(C,set(D),A4,X2)) )
           => ( ! [X2: C] :
                  ( member2(C,X2,I5)
                 => ! [Xa4: C] :
                      ( member2(C,Xa4,I5)
                     => ( ( X2 != Xa4 )
                       => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(C,set(D),A4,X2)),aa(C,set(D),A4,Xa4)) = bot_bot(set(D)) ) ) ) )
             => ( aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7311177749621191930dd_sum(D,E2),G),aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I5))) = aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7311177749621191930dd_sum(C,E2),aa(fun(D,E2),fun(C,E2),aTP_Lamp_gr(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),A4),G)),I5) ) ) ) ) ) ).

% sum.UNION_disjoint
tff(fact_3462_power__diff__1__eq,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,N: nat] : minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N),one_one(C)) = aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,X,one_one(C))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_lessThan(nat,N))) ) ).

% power_diff_1_eq
tff(fact_3463_one__diff__power__eq,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,N: nat] : minus_minus(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,one_one(C),X)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_lessThan(nat,N))) ) ).

% one_diff_power_eq
tff(fact_3464_geometric__sum,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C,N: nat] :
          ( ( X != one_one(C) )
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_lessThan(nat,N)) = divide_divide(C,minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N),one_one(C)),minus_minus(C,X,one_one(C))) ) ) ) ).

% geometric_sum
tff(fact_3465_gbinomial__parallel__sum,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_gs(C,fun(nat,C),A3)),set_ord_atMost(nat,N)) = aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),aa(nat,C,semiring_1_of_nat(C),N))),one_one(C))),N) ) ).

% gbinomial_parallel_sum
tff(fact_3466_member__le__sum,axiom,
    ! [D: $tType,C: $tType] :
      ( ( ordere6911136660526730532id_add(D)
        & semiring_1(D) )
     => ! [I: C,A4: set(C),F: fun(C,D)] :
          ( member2(C,I,A4)
         => ( ! [X2: C] :
                ( member2(C,X2,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),I),bot_bot(set(C)))))
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),zero_zero(D)),aa(C,D,F,X2)) )
           => ( aa(set(C),$o,finite_finite2(C),A4)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,I)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)) ) ) ) ) ).

% member_le_sum
tff(fact_3467_sum__bounded__above__divide,axiom,
    ! [C: $tType,D: $tType] :
      ( linordered_field(D)
     => ! [A4: set(C),F: fun(C,D),K5: D] :
          ( ! [I3: C] :
              ( member2(C,I3,A4)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,I3)),divide_divide(D,K5,aa(nat,D,semiring_1_of_nat(D),finite_card(C,A4)))) )
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( ( A4 != bot_bot(set(C)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)),K5) ) ) ) ) ).

% sum_bounded_above_divide
tff(fact_3468_sum__bounded__above__strict,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ordere8940638589300402666id_add(D)
        & semiring_1(D) )
     => ! [A4: set(C),F: fun(C,D),K5: D] :
          ( ! [I3: C] :
              ( member2(C,I3,A4)
             => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,I3)),K5) )
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),finite_card(C,A4))
           => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),A4)),aa(D,D,aa(D,fun(D,D),times_times(D),aa(nat,D,semiring_1_of_nat(D),finite_card(C,A4))),K5)) ) ) ) ).

% sum_bounded_above_strict
tff(fact_3469_convex__sum__bound__le,axiom,
    ! [C: $tType,D: $tType] :
      ( linordered_idom(D)
     => ! [I5: set(C),X: fun(C,D),A3: fun(C,D),B2: D,Delta: D] :
          ( ! [I3: C] :
              ( member2(C,I3,I5)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),zero_zero(D)),aa(C,D,X,I3)) )
         => ( ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),X),I5) = one_one(D) )
           => ( ! [I3: C] :
                  ( member2(C,I3,I5)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(D,D,abs_abs(D),minus_minus(D,aa(C,D,A3,I3),B2))),Delta) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(D,D,abs_abs(D),minus_minus(D,aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(fun(C,D),fun(C,D),aTP_Lamp_gt(fun(C,D),fun(fun(C,D),fun(C,D)),X),A3)),I5),B2))),Delta) ) ) ) ) ).

% convex_sum_bound_le
tff(fact_3470_sum__fun__comp,axiom,
    ! [E2: $tType,C: $tType,D: $tType] :
      ( semiring_1(E2)
     => ! [S: set(C),R: set(D),G: fun(C,D),F: fun(D,E2)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(D),$o,finite_finite2(D),R)
           => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(C),set(D),image2(C,D,G),S)),R)
             => ( aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7311177749621191930dd_sum(C,E2),aa(fun(D,E2),fun(C,E2),aTP_Lamp_gu(fun(C,D),fun(fun(D,E2),fun(C,E2)),G),F)),S) = aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7311177749621191930dd_sum(D,E2),aa(fun(D,E2),fun(D,E2),aa(fun(C,D),fun(fun(D,E2),fun(D,E2)),aTP_Lamp_gw(set(C),fun(fun(C,D),fun(fun(D,E2),fun(D,E2))),S),G),F)),R) ) ) ) ) ) ).

% sum_fun_comp
tff(fact_3471_sum__gp__basic,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,one_one(C),X)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_atMost(nat,N))) = minus_minus(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(nat,nat,suc,N))) ) ).

% sum_gp_basic
tff(fact_3472_power__diff__sumr2,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,N: nat,Y: C] : minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N),aa(nat,C,aa(C,fun(nat,C),power_power(C),Y),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,X,Y)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aa(nat,fun(C,fun(nat,C)),aTP_Lamp_gx(C,fun(nat,fun(C,fun(nat,C))),X),N),Y)),set_ord_lessThan(nat,N))) ) ).

% power_diff_sumr2
tff(fact_3473_diff__power__eq__sum,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,N: nat,Y: C] : minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(nat,nat,suc,N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),Y),aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,X,Y)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aa(nat,fun(C,fun(nat,C)),aTP_Lamp_gy(C,fun(nat,fun(C,fun(nat,C))),X),N),Y)),set_ord_lessThan(nat,aa(nat,nat,suc,N)))) ) ).

% diff_power_eq_sum
tff(fact_3474_sum__gp__strict,axiom,
    ! [C: $tType] :
      ( ( division_ring(C)
        & comm_ring(C) )
     => ! [X: C,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_lessThan(nat,N)) = $ite(X = one_one(C),aa(nat,C,semiring_1_of_nat(C),N),divide_divide(C,minus_minus(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)),minus_minus(C,one_one(C),X))) ) ).

% sum_gp_strict
tff(fact_3475_sum__power__shift,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [M2: nat,N: nat,X: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_or1337092689740270186AtMost(nat,M2,N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_atMost(nat,minus_minus(nat,N,M2)))) ) ) ) ).

% sum_power_shift
tff(fact_3476_mask__eq__sum__exp,axiom,
    ! [C: $tType] :
      ( semiring_parity(C)
     => ! [N: nat] : minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N),one_one(C)) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2)))),collect(nat,aTP_Lamp_bf(nat,fun(nat,$o),N))) ) ).

% mask_eq_sum_exp
tff(fact_3477_sum__gp__multiplied,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [M2: nat,N: nat,X: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,one_one(C),X)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_or1337092689740270186AtMost(nat,M2,N))) = minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(nat,nat,suc,N))) ) ) ) ).

% sum_gp_multiplied
tff(fact_3478_one__diff__power__eq_H,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [X: C,N: nat] : minus_minus(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),minus_minus(C,one_one(C),X)),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(nat,fun(nat,C),aTP_Lamp_gz(C,fun(nat,fun(nat,C)),X),N)),set_ord_lessThan(nat,N))) ) ).

% one_diff_power_eq'
tff(fact_3479_gbinomial__sum__lower__neg,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: C,M2: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_ha(C,fun(nat,C),A3)),set_ord_atMost(nat,M2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),M2)),aa(nat,C,gbinomial(C,minus_minus(C,A3,one_one(C))),M2)) ) ).

% gbinomial_sum_lower_neg
tff(fact_3480_binomial__ring,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [A3: C,B2: C,N: nat] : aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),N) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(nat,fun(nat,C),aa(C,fun(nat,fun(nat,C)),aTP_Lamp_hb(C,fun(C,fun(nat,fun(nat,C))),A3),B2),N)),set_ord_atMost(nat,N)) ) ).

% binomial_ring
tff(fact_3481_pochhammer__binomial__sum,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [A3: C,B2: C,N: nat] : comm_s3205402744901411588hammer(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2),N) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(nat,fun(nat,C),aa(C,fun(nat,fun(nat,C)),aTP_Lamp_hc(C,fun(C,fun(nat,fun(nat,C))),A3),B2),N)),set_ord_atMost(nat,N)) ) ).

% pochhammer_binomial_sum
tff(fact_3482_horner__sum__eq__sum,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_semiring_1(C)
     => ! [F: fun(D,C),A3: C,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),Xs) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(list(D),fun(nat,C),aa(C,fun(list(D),fun(nat,C)),aTP_Lamp_hd(fun(D,C),fun(C,fun(list(D),fun(nat,C))),F),A3),Xs)),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(D),nat,size_size(list(D)),Xs))) ) ).

% horner_sum_eq_sum
tff(fact_3483_gbinomial__sum__up__index,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [K: nat,N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_he(nat,fun(nat,C),K)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),one_one(nat))) ) ).

% gbinomial_sum_up_index
tff(fact_3484_gbinomial__partial__sum__poly,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [M2: nat,A3: C,X: C,Y: C] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hf(nat,fun(C,fun(C,fun(C,fun(nat,C)))),M2),A3),X),Y)),set_ord_atMost(nat,M2)) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hg(nat,fun(C,fun(C,fun(C,fun(nat,C)))),M2),A3),X),Y)),set_ord_atMost(nat,M2)) ) ).

% gbinomial_partial_sum_poly
tff(fact_3485_filter__upt__last,axiom,
    ! [C: $tType,Pa: fun(C,$o),La: list(C),Js: list(nat),J: nat,I: nat] :
      ( ( aa(list(nat),list(nat),aa(fun(nat,$o),fun(list(nat),list(nat)),filter2(nat),aa(list(C),fun(nat,$o),aTP_Lamp_gl(fun(C,$o),fun(list(C),fun(nat,$o)),Pa),La)),upt(zero_zero(nat),aa(list(C),nat,size_size(list(C)),La))) = aa(list(nat),list(nat),aa(list(nat),fun(list(nat),list(nat)),append(nat),Js),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),J),nil(nat))) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),I)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
         => ~ aa(C,$o,Pa,aa(nat,C,nth(C,La),I)) ) ) ) ).

% filter_upt_last
tff(fact_3486_double__gauss__sum,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),semiring_1_of_nat(C)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))) ) ).

% double_gauss_sum
tff(fact_3487_double__arith__series,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [A3: C,D3: C,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aTP_Lamp_hh(C,fun(C,fun(nat,C)),A3),D3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),D3))) ) ).

% double_arith_series
tff(fact_3488_sum__gp0,axiom,
    ! [C: $tType] :
      ( ( division_ring(C)
        & comm_ring(C) )
     => ! [X: C,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_ord_atMost(nat,N)) = $ite(X = one_one(C),aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))),divide_divide(C,minus_minus(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(nat,nat,suc,N))),minus_minus(C,one_one(C),X))) ) ).

% sum_gp0
tff(fact_3489_gbinomial__partial__sum__poly__xpos,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [M2: nat,A3: C,X: C,Y: C] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hf(nat,fun(C,fun(C,fun(C,fun(nat,C)))),M2),A3),X),Y)),set_ord_atMost(nat,M2)) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hi(nat,fun(C,fun(C,fun(C,fun(nat,C)))),M2),A3),X),Y)),set_ord_atMost(nat,M2)) ) ).

% gbinomial_partial_sum_poly_xpos
tff(fact_3490_choose__alternating__linear__sum,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [N: nat] :
          ( ( N != one_one(nat) )
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_hj(nat,fun(nat,C),N)),set_ord_atMost(nat,N)) = zero_zero(C) ) ) ) ).

% choose_alternating_linear_sum
tff(fact_3491_card__lists__length__le,axiom,
    ! [C: $tType,A4: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( finite_card(list(C),collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_eh(set(C),fun(nat,fun(list(C),$o)),A4),N))) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aa(nat,fun(nat,nat),power_power(nat),finite_card(C,A4))),set_ord_atMost(nat,N)) ) ) ).

% card_lists_length_le
tff(fact_3492_double__gauss__sum__from__Suc__0,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),semiring_1_of_nat(C)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))) ) ).

% double_gauss_sum_from_Suc_0
tff(fact_3493_gauss__sum,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),semiring_1_of_nat(C)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% gauss_sum
tff(fact_3494_arith__series,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [A3: C,D3: C,N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),aTP_Lamp_hk(C,fun(C,fun(nat,C)),A3),D3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),D3))),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% arith_series
tff(fact_3495_sum__gp__offset,axiom,
    ! [C: $tType] :
      ( ( division_ring(C)
        & comm_ring(C) )
     => ! [X: C,M2: nat,N: nat] :
          aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(C,fun(nat,C),power_power(C),X)),set_or1337092689740270186AtMost(nat,M2,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N))) = $ite(X = one_one(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C)),divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)),minus_minus(C,one_one(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(nat,nat,suc,N)))),minus_minus(C,one_one(C),X))) ) ).

% sum_gp_offset
tff(fact_3496_choose__alternating__sum,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_hl(nat,fun(nat,C),N)),set_ord_atMost(nat,N)) = zero_zero(C) ) ) ) ).

% choose_alternating_sum
tff(fact_3497_gauss__sum__from__Suc__0,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),semiring_1_of_nat(C)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N)) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),N)),one_one(C))),aa(num,C,numeral_numeral(C),bit0(one2))) ) ).

% gauss_sum_from_Suc_0
tff(fact_3498_gchoose__row__sum__weighted,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [R3: C,M2: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aTP_Lamp_fx(C,fun(nat,C),R3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),M2)) = aa(C,C,aa(C,fun(C,C),times_times(C),divide_divide(C,aa(nat,C,semiring_1_of_nat(C),aa(nat,nat,suc,M2)),aa(num,C,numeral_numeral(C),bit0(one2)))),aa(nat,C,gbinomial(C,R3),aa(nat,nat,suc,M2))) ) ).

% gchoose_row_sum_weighted
tff(fact_3499_of__nat__code,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [N: nat] : aa(nat,C,semiring_1_of_nat(C),N) = semiri8178284476397505188at_aux(C,aTP_Lamp_hm(C,C),N,zero_zero(C)) ) ).

% of_nat_code
tff(fact_3500_remove__rev__alt__def,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),remove_rev(C,X),Xs) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),X)),aa(list(C),list(C),rev(C),Xs)) ).

% remove_rev_alt_def
tff(fact_3501_divmod__step__def,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [La: num,Qr: product_prod(C,C)] : unique1321980374590559556d_step(C,La,Qr) = aa(product_prod(C,C),product_prod(C,C),product_case_prod(C,C,product_prod(C,C),aTP_Lamp_hn(num,fun(C,fun(C,product_prod(C,C))),La)),Qr) ) ).

% divmod_step_def
tff(fact_3502_Pow__fold,axiom,
    ! [C: $tType,A4: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( pow(C,A4) = finite_fold(C,set(set(C)),aTP_Lamp_ho(C,fun(set(set(C)),set(set(C)))),aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),bot_bot(set(C))),bot_bot(set(set(C)))),A4) ) ) ).

% Pow_fold
tff(fact_3503_length__remdups__concat,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups(C),aa(list(list(C)),list(C),concat(C),Xss2))) = finite_card(C,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(list(C)),set(set(C)),image2(list(C),set(C),set2(C)),aa(list(list(C)),set(list(C)),set2(list(C)),Xss2)))) ).

% length_remdups_concat
tff(fact_3504_remdups__upt,axiom,
    ! [M2: nat,N: nat] : aa(list(nat),list(nat),remdups(nat),upt(M2,N)) = upt(M2,N) ).

% remdups_upt
tff(fact_3505_fold__empty,axiom,
    ! [D: $tType,C: $tType,F: fun(D,fun(C,C)),Z2: C] : finite_fold(D,C,F,Z2,bot_bot(set(D))) = Z2 ).

% fold_empty
tff(fact_3506_remdups__eq__nil__iff,axiom,
    ! [C: $tType,X: list(C)] :
      ( ( aa(list(C),list(C),remdups(C),X) = nil(C) )
    <=> ( X = nil(C) ) ) ).

% remdups_eq_nil_iff
tff(fact_3507_remdups__eq__nil__right__iff,axiom,
    ! [C: $tType,X: list(C)] :
      ( ( nil(C) = aa(list(C),list(C),remdups(C),X) )
    <=> ( X = nil(C) ) ) ).

% remdups_eq_nil_right_iff
tff(fact_3508_set__remdups,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),remdups(C),Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% set_remdups
tff(fact_3509_length__remdups__eq,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups(C),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) )
    <=> ( aa(list(C),list(C),remdups(C),Xs) = Xs ) ) ).

% length_remdups_eq
tff(fact_3510_distinct__remdups,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),$o,distinct(C),aa(list(C),list(C),remdups(C),Xs)) ).

% distinct_remdups
tff(fact_3511_remdups__id__iff__distinct,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),list(C),remdups(C),Xs) = Xs )
    <=> aa(list(C),$o,distinct(C),Xs) ) ).

% remdups_id_iff_distinct
tff(fact_3512_length__remdups__leq,axiom,
    ! [C: $tType,Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups(C),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_remdups_leq
tff(fact_3513_nested__case__prod__simp,axiom,
    ! [F4: $tType,C: $tType,E2: $tType,D: $tType,F: fun(D,fun(E2,fun(F4,C))),X: product_prod(D,E2),Y: F4] : aa(F4,C,aa(product_prod(D,E2),fun(F4,C),product_case_prod(D,E2,fun(F4,C),F),X),Y) = aa(product_prod(D,E2),C,product_case_prod(D,E2,C,aa(F4,fun(D,fun(E2,C)),aTP_Lamp_hp(fun(D,fun(E2,fun(F4,C))),fun(F4,fun(D,fun(E2,C))),F),Y)),X) ).

% nested_case_prod_simp
tff(fact_3514_remdups__remdups,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),remdups(C),aa(list(C),list(C),remdups(C),Xs)) = aa(list(C),list(C),remdups(C),Xs) ).

% remdups_remdups
tff(fact_3515_remdups_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),list(C),remdups(C),nil(C)) = nil(C) ).

% remdups.simps(1)
tff(fact_3516_remdups__map__remdups,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),remdups(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),remdups(D),Xs))) = aa(list(C),list(C),remdups(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) ).

% remdups_map_remdups
tff(fact_3517_remdups__append2,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),remdups(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),remdups(C),Ys))) = aa(list(C),list(C),remdups(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) ).

% remdups_append2
tff(fact_3518_distinct__remdups__id,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),list(C),remdups(C),Xs) = Xs ) ) ).

% distinct_remdups_id
tff(fact_3519_remdups__filter,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),remdups(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),remdups(C),Xs)) ).

% remdups_filter
tff(fact_3520_zip__left__commute,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Xs: list(C),Ys: list(D),Zs: list(E2)] : aa(list(product_prod(D,E2)),list(product_prod(C,product_prod(D,E2))),aa(list(C),fun(list(product_prod(D,E2)),list(product_prod(C,product_prod(D,E2)))),zip(C,product_prod(D,E2)),Xs),aa(list(E2),list(product_prod(D,E2)),aa(list(D),fun(list(E2),list(product_prod(D,E2))),zip(D,E2),Ys),Zs)) = aa(list(product_prod(D,product_prod(C,E2))),list(product_prod(C,product_prod(D,E2))),aa(fun(product_prod(D,product_prod(C,E2)),product_prod(C,product_prod(D,E2))),fun(list(product_prod(D,product_prod(C,E2))),list(product_prod(C,product_prod(D,E2)))),map(product_prod(D,product_prod(C,E2)),product_prod(C,product_prod(D,E2))),product_case_prod(D,product_prod(C,E2),product_prod(C,product_prod(D,E2)),aTP_Lamp_hr(D,fun(product_prod(C,E2),product_prod(C,product_prod(D,E2)))))),aa(list(product_prod(C,E2)),list(product_prod(D,product_prod(C,E2))),aa(list(D),fun(list(product_prod(C,E2)),list(product_prod(D,product_prod(C,E2)))),zip(D,product_prod(C,E2)),Ys),aa(list(E2),list(product_prod(C,E2)),aa(list(C),fun(list(E2),list(product_prod(C,E2))),zip(C,E2),Xs),Zs))) ).

% zip_left_commute
tff(fact_3521_insert__remdups,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),aa(list(C),list(C),remdups(C),Xs)) = aa(list(C),list(C),remdups(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),insert(C),X),Xs)) ).

% insert_remdups
tff(fact_3522_remdups_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      aa(list(C),list(C),remdups(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(member2(C,X,aa(list(C),set(C),set2(C),Xs)),aa(list(C),list(C),remdups(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),remdups(C),Xs))) ).

% remdups.simps(2)
tff(fact_3523_zip__commute,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys) = aa(list(product_prod(D,C)),list(product_prod(C,D)),aa(fun(product_prod(D,C),product_prod(C,D)),fun(list(product_prod(D,C)),list(product_prod(C,D))),map(product_prod(D,C),product_prod(C,D)),product_case_prod(D,C,product_prod(C,D),aTP_Lamp_hs(D,fun(C,product_prod(C,D))))),aa(list(C),list(product_prod(D,C)),aa(list(D),fun(list(C),list(product_prod(D,C))),zip(D,C),Ys),Xs)) ).

% zip_commute
tff(fact_3524_sorted__remdups,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),remdups(C),Xs)) ) ) ).

% sorted_remdups
tff(fact_3525_map2__map__map,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,H: fun(D,fun(E2,C)),F: fun(F4,D),Xs: list(F4),G: fun(F4,E2)] : aa(list(product_prod(D,E2)),list(C),aa(fun(product_prod(D,E2),C),fun(list(product_prod(D,E2)),list(C)),map(product_prod(D,E2),C),product_case_prod(D,E2,C,H)),aa(list(E2),list(product_prod(D,E2)),aa(list(D),fun(list(E2),list(product_prod(D,E2))),zip(D,E2),aa(list(F4),list(D),aa(fun(F4,D),fun(list(F4),list(D)),map(F4,D),F),Xs)),aa(list(F4),list(E2),aa(fun(F4,E2),fun(list(F4),list(E2)),map(F4,E2),G),Xs))) = aa(list(F4),list(C),aa(fun(F4,C),fun(list(F4),list(C)),map(F4,C),aa(fun(F4,E2),fun(F4,C),aa(fun(F4,D),fun(fun(F4,E2),fun(F4,C)),aTP_Lamp_ht(fun(D,fun(E2,C)),fun(fun(F4,D),fun(fun(F4,E2),fun(F4,C))),H),F),G)),Xs) ).

% map2_map_map
tff(fact_3526_remove1__remdups,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),remdups(C),Xs)) = aa(list(C),list(C),remdups(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)) ) ) ).

% remove1_remdups
tff(fact_3527_zip__map1,axiom,
    ! [C: $tType,E2: $tType,D: $tType,F: fun(E2,C),Xs: list(E2),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),F),Xs)),Ys) = aa(list(product_prod(E2,D)),list(product_prod(C,D)),aa(fun(product_prod(E2,D),product_prod(C,D)),fun(list(product_prod(E2,D)),list(product_prod(C,D))),map(product_prod(E2,D),product_prod(C,D)),product_case_prod(E2,D,product_prod(C,D),aTP_Lamp_hu(fun(E2,C),fun(E2,fun(D,product_prod(C,D))),F))),aa(list(D),list(product_prod(E2,D)),aa(list(E2),fun(list(D),list(product_prod(E2,D))),zip(E2,D),Xs),Ys)) ).

% zip_map1
tff(fact_3528_zip__map2,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Xs: list(C),F: fun(E2,D),Ys: list(E2)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),Ys)) = aa(list(product_prod(C,E2)),list(product_prod(C,D)),aa(fun(product_prod(C,E2),product_prod(C,D)),fun(list(product_prod(C,E2)),list(product_prod(C,D))),map(product_prod(C,E2),product_prod(C,D)),product_case_prod(C,E2,product_prod(C,D),aTP_Lamp_hv(fun(E2,D),fun(C,fun(E2,product_prod(C,D))),F))),aa(list(E2),list(product_prod(C,E2)),aa(list(C),fun(list(E2),list(product_prod(C,E2))),zip(C,E2),Xs),Ys)) ).

% zip_map2
tff(fact_3529_map__prod__fun__zip,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,F: fun(E2,C),G: fun(F4,D),Xs: list(E2),Ys: list(F4)] : aa(list(product_prod(E2,F4)),list(product_prod(C,D)),aa(fun(product_prod(E2,F4),product_prod(C,D)),fun(list(product_prod(E2,F4)),list(product_prod(C,D))),map(product_prod(E2,F4),product_prod(C,D)),product_case_prod(E2,F4,product_prod(C,D),aa(fun(F4,D),fun(E2,fun(F4,product_prod(C,D))),aTP_Lamp_hw(fun(E2,C),fun(fun(F4,D),fun(E2,fun(F4,product_prod(C,D)))),F),G))),aa(list(F4),list(product_prod(E2,F4)),aa(list(E2),fun(list(F4),list(product_prod(E2,F4))),zip(E2,F4),Xs),Ys)) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),F),Xs)),aa(list(F4),list(D),aa(fun(F4,D),fun(list(F4),list(D)),map(F4,D),G),Ys)) ).

% map_prod_fun_zip
tff(fact_3530_length__remdups__card,axiom,
    ! [C: $tType,La: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups(C),La)) = finite_card(C,aa(list(C),set(C),set2(C),La)) ).

% length_remdups_card
tff(fact_3531_length__remdups__card__conv,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups(C),Xs)) = finite_card(C,aa(list(C),set(C),set2(C),Xs)) ).

% length_remdups_card_conv
tff(fact_3532_map__zip__map,axiom,
    ! [D: $tType,C: $tType,F4: $tType,E2: $tType,F: fun(product_prod(D,E2),C),G: fun(F4,D),Xs: list(F4),Ys: list(E2)] : aa(list(product_prod(D,E2)),list(C),aa(fun(product_prod(D,E2),C),fun(list(product_prod(D,E2)),list(C)),map(product_prod(D,E2),C),F),aa(list(E2),list(product_prod(D,E2)),aa(list(D),fun(list(E2),list(product_prod(D,E2))),zip(D,E2),aa(list(F4),list(D),aa(fun(F4,D),fun(list(F4),list(D)),map(F4,D),G),Xs)),Ys)) = aa(list(product_prod(F4,E2)),list(C),aa(fun(product_prod(F4,E2),C),fun(list(product_prod(F4,E2)),list(C)),map(product_prod(F4,E2),C),product_case_prod(F4,E2,C,aa(fun(F4,D),fun(F4,fun(E2,C)),aTP_Lamp_hx(fun(product_prod(D,E2),C),fun(fun(F4,D),fun(F4,fun(E2,C))),F),G))),aa(list(E2),list(product_prod(F4,E2)),aa(list(F4),fun(list(E2),list(product_prod(F4,E2))),zip(F4,E2),Xs),Ys)) ).

% map_zip_map
tff(fact_3533_map__zip__map2,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,F: fun(product_prod(D,E2),C),Xs: list(D),G: fun(F4,E2),Ys: list(F4)] : aa(list(product_prod(D,E2)),list(C),aa(fun(product_prod(D,E2),C),fun(list(product_prod(D,E2)),list(C)),map(product_prod(D,E2),C),F),aa(list(E2),list(product_prod(D,E2)),aa(list(D),fun(list(E2),list(product_prod(D,E2))),zip(D,E2),Xs),aa(list(F4),list(E2),aa(fun(F4,E2),fun(list(F4),list(E2)),map(F4,E2),G),Ys))) = aa(list(product_prod(D,F4)),list(C),aa(fun(product_prod(D,F4),C),fun(list(product_prod(D,F4)),list(C)),map(product_prod(D,F4),C),product_case_prod(D,F4,C,aa(fun(F4,E2),fun(D,fun(F4,C)),aTP_Lamp_hy(fun(product_prod(D,E2),C),fun(fun(F4,E2),fun(D,fun(F4,C))),F),G))),aa(list(F4),list(product_prod(D,F4)),aa(list(D),fun(list(F4),list(product_prod(D,F4))),zip(D,F4),Xs),Ys)) ).

% map_zip_map2
tff(fact_3534_sum__diff1__nat,axiom,
    ! [C: $tType,F: fun(C,nat),A4: set(C),A3: C] :
      aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = $ite(member2(C,A3,A4),minus_minus(nat,aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),A4),aa(C,nat,F,A3)),aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),A4)) ).

% sum_diff1_nat
tff(fact_3535_Sup__fold__sup,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),C,complete_Sup_Sup(C),A4) = finite_fold(C,C,sup_sup(C),bot_bot(C),A4) ) ) ) ).

% Sup_fold_sup
tff(fact_3536_Inf__fin_Oeq__fold,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = finite_fold(C,C,inf_inf(C),X,A4) ) ) ) ).

% Inf_fin.eq_fold
tff(fact_3537_image__fold__insert,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,D)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),set(D),image2(C,D,F),A4) = finite_fold(C,set(D),aTP_Lamp_hz(fun(C,D),fun(C,fun(set(D),set(D))),F),bot_bot(set(D)),A4) ) ) ).

% image_fold_insert
tff(fact_3538_sum__Un__nat,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),F: fun(C,nat)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),$o,finite_finite2(C),B3)
       => ( aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = minus_minus(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),A4)),aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),B3)),aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ).

% sum_Un_nat
tff(fact_3539_foldl__snd__zip,axiom,
    ! [D: $tType,E2: $tType,C: $tType,Ys: list(C),Xs: list(D),F: fun(E2,fun(C,E2)),B2: E2] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Ys)),aa(list(D),nat,size_size(list(D)),Xs))
     => ( aa(list(product_prod(D,C)),E2,aa(E2,fun(list(product_prod(D,C)),E2),aa(fun(E2,fun(product_prod(D,C),E2)),fun(E2,fun(list(product_prod(D,C)),E2)),foldl(E2,product_prod(D,C)),aTP_Lamp_ib(fun(E2,fun(C,E2)),fun(E2,fun(product_prod(D,C),E2)),F)),B2),aa(list(C),list(product_prod(D,C)),aa(list(D),fun(list(C),list(product_prod(D,C))),zip(D,C),Xs),Ys)) = aa(list(C),E2,aa(E2,fun(list(C),E2),aa(fun(E2,fun(C,E2)),fun(E2,fun(list(C),E2)),foldl(E2,C),F),B2),Ys) ) ) ).

% foldl_snd_zip
tff(fact_3540_prod_Oset__conv__list,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),Xs: list(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),G),aa(list(D),set(D),set2(D),Xs)) = aa(list(C),C,groups5270119922927024881d_list(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),aa(list(D),list(D),remdups(D),Xs))) ) ).

% prod.set_conv_list
tff(fact_3541_sum__count__set,axiom,
    ! [C: $tType,Xs: list(C),X5: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),X5)
     => ( aa(set(C),$o,finite_finite2(C),X5)
       => ( aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),count_list(C,Xs)),X5) = aa(list(C),nat,size_size(list(C)),Xs) ) ) ) ).

% sum_count_set
tff(fact_3542_card__UN__disjoint,axiom,
    ! [D: $tType,C: $tType,I5: set(C),A4: fun(C,set(D))] :
      ( aa(set(C),$o,finite_finite2(C),I5)
     => ( ! [X2: C] :
            ( member2(C,X2,I5)
           => aa(set(D),$o,finite_finite2(D),aa(C,set(D),A4,X2)) )
       => ( ! [X2: C] :
              ( member2(C,X2,I5)
             => ! [Xa4: C] :
                  ( member2(C,Xa4,I5)
                 => ( ( X2 != Xa4 )
                   => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(C,set(D),A4,X2)),aa(C,set(D),A4,Xa4)) = bot_bot(set(D)) ) ) ) )
         => ( finite_card(D,aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I5))) = aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),aTP_Lamp_ic(fun(C,set(D)),fun(C,nat),A4)),I5) ) ) ) ) ).

% card_UN_disjoint
tff(fact_3543_divmod__algorithm__code_I6_J,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [M2: num,N: num] : unique8689654367752047608divmod(C,bit1(M2),bit0(N)) = aa(product_prod(C,C),product_prod(C,C),product_case_prod(C,C,product_prod(C,C),aTP_Lamp_id(C,fun(C,product_prod(C,C)))),unique8689654367752047608divmod(C,M2,N)) ) ).

% divmod_algorithm_code(6)
tff(fact_3544_divmod__algorithm__code_I5_J,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [M2: num,N: num] : unique8689654367752047608divmod(C,bit0(M2),bit0(N)) = aa(product_prod(C,C),product_prod(C,C),product_case_prod(C,C,product_prod(C,C),aTP_Lamp_ie(C,fun(C,product_prod(C,C)))),unique8689654367752047608divmod(C,M2,N)) ) ).

% divmod_algorithm_code(5)
tff(fact_3545_listset_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(set(C)),set(list(C)),listset(C),nil(set(C))) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),nil(C)),bot_bot(set(list(C)))) ).

% listset.simps(1)
tff(fact_3546_transpose__transpose,axiom,
    ! [C: $tType,Xs: list(list(C))] :
      ( sorted_wrt(nat,ord_less_eq(nat),aa(list(nat),list(nat),rev(nat),aa(list(list(C)),list(nat),aa(fun(list(C),nat),fun(list(list(C)),list(nat)),map(list(C),nat),size_size(list(C))),Xs)))
     => ( transpose(C,transpose(C,Xs)) = aa(list(list(C)),list(list(C)),aa(fun(list(C),$o),fun(list(list(C)),list(list(C))),takeWhile(list(C)),aTP_Lamp_fi(list(C),$o)),Xs) ) ) ).

% transpose_transpose
tff(fact_3547_Set__filter__fold,axiom,
    ! [C: $tType,A4: set(C),Pa: fun(C,$o)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( filter3(C,Pa,A4) = finite_fold(C,set(C),aTP_Lamp_if(fun(C,$o),fun(C,fun(set(C),set(C))),Pa),bot_bot(set(C)),A4) ) ) ).

% Set_filter_fold
tff(fact_3548_takeWhile__idem,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) ).

% takeWhile_idem
tff(fact_3549_member__filter,axiom,
    ! [C: $tType,X: C,Pa: fun(C,$o),A4: set(C)] :
      ( member2(C,X,filter3(C,Pa,A4))
    <=> ( member2(C,X,A4)
        & aa(C,$o,Pa,X) ) ) ).

% member_filter
tff(fact_3550_takeWhile__eq__all__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) = Xs )
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) ) ) ).

% takeWhile_eq_all_conv
tff(fact_3551_takeWhile__append1,axiom,
    ! [C: $tType,X: C,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( ~ aa(C,$o,Pa,X)
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) ) ) ) ).

% takeWhile_append1
tff(fact_3552_takeWhile__append2,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X2) )
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Ys)) ) ) ).

% takeWhile_append2
tff(fact_3553_Set_Ofilter__def,axiom,
    ! [C: $tType,Pa: fun(C,$o),A4: set(C)] : filter3(C,Pa,A4) = collect(C,aa(set(C),fun(C,$o),aTP_Lamp_ig(fun(C,$o),fun(set(C),fun(C,$o)),Pa),A4)) ).

% Set.filter_def
tff(fact_3554_distinct__takeWhile,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)) ) ).

% distinct_takeWhile
tff(fact_3555_takeWhile_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),nil(C)) = nil(C) ).

% takeWhile.simps(1)
tff(fact_3556_set__takeWhileD,axiom,
    ! [C: $tType,X: C,Pa: fun(C,$o),Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)))
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
        & aa(C,$o,Pa,X) ) ) ).

% set_takeWhileD
tff(fact_3557_takeWhile__cong,axiom,
    ! [C: $tType,La: list(C),K: list(C),Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ( La = K )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),La))
           => ( aa(C,$o,Pa,X2)
            <=> aa(C,$o,Q,X2) ) )
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),La) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Q),K) ) ) ) ).

% takeWhile_cong
tff(fact_3558_inj__split__Cons,axiom,
    ! [C: $tType,X5: set(product_prod(list(C),C))] : inj_on(product_prod(list(C),C),list(C),product_case_prod(list(C),C,list(C),aTP_Lamp_dm(list(C),fun(C,list(C)))),X5) ).

% inj_split_Cons
tff(fact_3559_takeWhile_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(aa(C,$o,Pa,X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)),nil(C)) ).

% takeWhile.simps(2)
tff(fact_3560_takeWhile__tail,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C),La: list(C)] :
      ( ~ aa(C,$o,Pa,X)
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),La))) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) ) ) ).

% takeWhile_tail
tff(fact_3561_length__takeWhile__le,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_takeWhile_le
tff(fact_3562_sorted__takeWhile,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Pa: fun(C,$o)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)) ) ) ).

% sorted_takeWhile
tff(fact_3563_takeWhile__eq__take,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs))),Xs) ).

% takeWhile_eq_take
tff(fact_3564_takeWhile__eq__Nil__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) = nil(C) )
    <=> ( ( Xs = nil(C) )
        | ~ aa(C,$o,Pa,aa(list(C),C,hd(C),Xs)) ) ) ).

% takeWhile_eq_Nil_iff
tff(fact_3565_nth__length__takeWhile,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs))),aa(list(C),nat,size_size(list(C)),Xs))
     => ~ aa(C,$o,Pa,aa(nat,C,nth(C,Xs),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)))) ) ).

% nth_length_takeWhile
tff(fact_3566_takeWhile__nth,axiom,
    ! [C: $tType,J: nat,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)),J) = aa(nat,C,nth(C,Xs),J) ) ) ).

% takeWhile_nth
tff(fact_3567_drop__takeWhile,axiom,
    ! [C: $tType,I: nat,Pa: fun(C,$o),La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),La)))
     => ( aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),La)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),La)) ) ) ).

% drop_takeWhile
tff(fact_3568_zip__assoc,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Xs: list(C),Ys: list(D),Zs: list(E2)] : aa(list(product_prod(D,E2)),list(product_prod(C,product_prod(D,E2))),aa(list(C),fun(list(product_prod(D,E2)),list(product_prod(C,product_prod(D,E2)))),zip(C,product_prod(D,E2)),Xs),aa(list(E2),list(product_prod(D,E2)),aa(list(D),fun(list(E2),list(product_prod(D,E2))),zip(D,E2),Ys),Zs)) = aa(list(product_prod(product_prod(C,D),E2)),list(product_prod(C,product_prod(D,E2))),aa(fun(product_prod(product_prod(C,D),E2),product_prod(C,product_prod(D,E2))),fun(list(product_prod(product_prod(C,D),E2)),list(product_prod(C,product_prod(D,E2)))),map(product_prod(product_prod(C,D),E2),product_prod(C,product_prod(D,E2))),product_case_prod(product_prod(C,D),E2,product_prod(C,product_prod(D,E2)),product_case_prod(C,D,fun(E2,product_prod(C,product_prod(D,E2))),aTP_Lamp_ih(C,fun(D,fun(E2,product_prod(C,product_prod(D,E2)))))))),aa(list(E2),list(product_prod(product_prod(C,D),E2)),aa(list(product_prod(C,D)),fun(list(E2),list(product_prod(product_prod(C,D),E2))),zip(product_prod(C,D),E2),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)),Zs)) ).

% zip_assoc
tff(fact_3569_listrel__def,axiom,
    ! [D: $tType,C: $tType,X3: set(product_prod(C,D))] : listrel(C,D,X3) = collect(product_prod(list(C),list(D)),product_case_prod(list(C),list(D),$o,listrelp(C,D,aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),X3)))) ).

% listrel_def
tff(fact_3570_takeWhile__not__last,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),aTP_Lamp_ii(list(C),fun(C,$o),Xs)),Xs) = aa(list(C),list(C),butlast(C),Xs) ) ) ).

% takeWhile_not_last
tff(fact_3571_length__takeWhile__less__P__nth,axiom,
    ! [C: $tType,J: nat,Pa: fun(C,$o),Xs: list(C)] :
      ( ! [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),J)
         => aa(C,$o,Pa,aa(nat,C,nth(C,Xs),I3)) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs))) ) ) ).

% length_takeWhile_less_P_nth
tff(fact_3572_eq__len__takeWhile__conv,axiom,
    ! [C: $tType,I: nat,Pa: fun(C,$o),La: list(C)] :
      ( ( I = aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),La)) )
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),aa(list(C),nat,size_size(list(C)),La))
        & ! [J2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),I)
           => aa(C,$o,Pa,aa(nat,C,nth(C,La),J2)) )
        & ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
         => ~ aa(C,$o,Pa,aa(nat,C,nth(C,La),I)) ) ) ) ).

% eq_len_takeWhile_conv
tff(fact_3573_less__length__takeWhile__conv,axiom,
    ! [C: $tType,I: nat,Pa: fun(C,$o),La: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),La)))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),La))
        & ! [J2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J2),I)
           => aa(C,$o,Pa,aa(nat,C,nth(C,La),J2)) ) ) ) ).

% less_length_takeWhile_conv
tff(fact_3574_filter__set,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : filter3(C,Pa,aa(list(C),set(C),set2(C),Xs)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) ).

% filter_set
tff(fact_3575_takeWhile__eq__take__P__nth,axiom,
    ! [C: $tType,N: nat,Xs: list(C),Pa: fun(C,$o)] :
      ( ! [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),N)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Xs))
           => aa(C,$o,Pa,aa(nat,C,nth(C,Xs),I3)) ) )
     => ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(C),nat,size_size(list(C)),Xs))
         => ~ aa(C,$o,Pa,aa(nat,C,nth(C,Xs),N)) )
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs) ) ) ) ).

% takeWhile_eq_take_P_nth
tff(fact_3576_listset_Osimps_I2_J,axiom,
    ! [C: $tType,A4: set(C),As3: list(set(C))] : aa(list(set(C)),set(list(C)),listset(C),aa(list(set(C)),list(set(C)),aa(set(C),fun(list(set(C)),list(set(C))),cons(set(C)),A4),As3)) = aa(set(list(C)),set(list(C)),aa(set(C),fun(set(list(C)),set(list(C))),set_Cons(C),A4),aa(list(set(C)),set(list(C)),listset(C),As3)) ).

% listset.simps(2)
tff(fact_3577_lexordp__conv__lexord,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Ys: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),ord_lexordp(C),Xs),Ys)
        <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lexord(C,collect(product_prod(C,C),product_case_prod(C,C,$o,ord_less(C))))) ) ) ).

% lexordp_conv_lexord
tff(fact_3578_foldr__snd__zip,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Ys: list(C),Xs: list(D),F: fun(C,fun(E2,E2)),B2: E2] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Ys)),aa(list(D),nat,size_size(list(D)),Xs))
     => ( aa(E2,E2,aa(list(product_prod(D,C)),fun(E2,E2),aa(fun(product_prod(D,C),fun(E2,E2)),fun(list(product_prod(D,C)),fun(E2,E2)),foldr(product_prod(D,C),E2),product_case_prod(D,C,fun(E2,E2),aTP_Lamp_ij(fun(C,fun(E2,E2)),fun(D,fun(C,fun(E2,E2))),F))),aa(list(C),list(product_prod(D,C)),aa(list(D),fun(list(C),list(product_prod(D,C))),zip(D,C),Xs),Ys)),B2) = aa(E2,E2,aa(list(C),fun(E2,E2),aa(fun(C,fun(E2,E2)),fun(list(C),fun(E2,E2)),foldr(C,E2),F),Ys),B2) ) ) ).

% foldr_snd_zip
tff(fact_3579_inter__Set__filter,axiom,
    ! [C: $tType,B3: set(C),A4: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),B3)
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = filter3(C,aTP_Lamp_a(set(C),fun(C,$o),A4),B3) ) ) ).

% inter_Set_filter
tff(fact_3580_lenlex__conv,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : lenlex(C,R3) = collect(product_prod(list(C),list(C)),product_case_prod(list(C),list(C),$o,aTP_Lamp_ik(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),R3))) ).

% lenlex_conv
tff(fact_3581_filter__equals__takeWhile__sorted__rev,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D),T4: C] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)))
         => ( aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),aa(C,fun(D,$o),aTP_Lamp_il(fun(D,C),fun(C,fun(D,$o)),F),T4)),Xs) = aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),takeWhile(D),aa(C,fun(D,$o),aTP_Lamp_il(fun(D,C),fun(C,fun(D,$o)),F),T4)),Xs) ) ) ) ).

% filter_equals_takeWhile_sorted_rev
tff(fact_3582_List_Olexordp__def,axiom,
    ! [C: $tType,R3: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( lexordp(C,R3,Xs,Ys)
    <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),lexord(C,collect(product_prod(C,C),product_case_prod(C,C,$o,R3)))) ) ).

% List.lexordp_def
tff(fact_3583_listrel1p__def,axiom,
    ! [C: $tType,R3: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( listrel1p(C,R3,Xs,Ys)
    <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,collect(product_prod(C,C),product_case_prod(C,C,$o,R3)))) ) ).

% listrel1p_def
tff(fact_3584_transpose_Opelims,axiom,
    ! [C: $tType,X: list(list(C)),Y: list(list(C))] :
      ( ( transpose(C,X) = Y )
     => ( accp(list(list(C)),transpose_rel(C),X)
       => ( ( ( X = nil(list(C)) )
           => ( ( Y = nil(list(C)) )
             => ~ accp(list(list(C)),transpose_rel(C),nil(list(C))) ) )
         => ( ! [Xss: list(list(C))] :
                ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss) )
               => ( ( Y = transpose(C,Xss) )
                 => ~ accp(list(list(C)),transpose_rel(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss)) ) )
           => ~ ! [X2: C,Xs2: list(C),Xss: list(list(C))] :
                  ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xss) )
                 => ( ( Y = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aTP_Lamp_eq(C,fun(list(C),list(C))))),Xss)))),transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Xs2),aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aa(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C))),aa(list(list(C)),fun(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C)))),case_list(list(list(C)),C),nil(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))))),Xss))))) )
                   => ~ accp(list(list(C)),transpose_rel(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xss)) ) ) ) ) ) ) ).

% transpose.pelims
tff(fact_3585_transpose_Opsimps_I3_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Xss2: list(list(C))] :
      ( accp(list(list(C)),transpose_rel(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Xss2))
     => ( transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Xss2)) = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aTP_Lamp_eq(C,fun(list(C),list(C))))),Xss2)))),transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Xs),aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aa(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C))),aa(list(list(C)),fun(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C)))),case_list(list(list(C)),C),nil(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))))),Xss2))))) ) ) ).

% transpose.psimps(3)
tff(fact_3586_quicksort_Osimps_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] : aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_im(C,fun(C,$o),X)),Xs))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))),aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),ord_less_eq(C),X)),Xs)))) ) ).

% quicksort.simps(2)
tff(fact_3587_set__quicksort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),linorder_quicksort(C),Xs)) = aa(list(C),set(C),set2(C),Xs) ) ).

% set_quicksort
tff(fact_3588_transpose_Opsimps_I1_J,axiom,
    ! [C: $tType] :
      ( accp(list(list(C)),transpose_rel(C),nil(list(C)))
     => ( transpose(C,nil(list(C))) = nil(list(C)) ) ) ).

% transpose.psimps(1)
tff(fact_3589_quicksort_Osimps_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( aa(list(C),list(C),linorder_quicksort(C),nil(C)) = nil(C) ) ) ).

% quicksort.simps(1)
tff(fact_3590_transpose_Opsimps_I2_J,axiom,
    ! [C: $tType,Xss2: list(list(C))] :
      ( accp(list(list(C)),transpose_rel(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss2))
     => ( transpose(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss2)) = transpose(C,Xss2) ) ) ).

% transpose.psimps(2)
tff(fact_3591_sorted__quicksort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),linorder_quicksort(C),Xs)) ) ).

% sorted_quicksort
tff(fact_3592_transpose_Opinduct,axiom,
    ! [C: $tType,A0: list(list(C)),Pa: fun(list(list(C)),$o)] :
      ( accp(list(list(C)),transpose_rel(C),A0)
     => ( ( accp(list(list(C)),transpose_rel(C),nil(list(C)))
         => aa(list(list(C)),$o,Pa,nil(list(C))) )
       => ( ! [Xss: list(list(C))] :
              ( accp(list(list(C)),transpose_rel(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss))
             => ( aa(list(list(C)),$o,Pa,Xss)
               => aa(list(list(C)),$o,Pa,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),nil(C)),Xss)) ) )
         => ( ! [X2: C,Xs2: list(C),Xss: list(list(C))] :
                ( accp(list(list(C)),transpose_rel(C),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xss))
               => ( aa(list(list(C)),$o,Pa,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Xs2),aa(list(list(list(C))),list(list(C)),concat(list(C)),aa(list(list(C)),list(list(list(C))),aa(fun(list(C),list(list(C))),fun(list(list(C)),list(list(list(C)))),map(list(C),list(list(C))),aa(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C))),aa(list(list(C)),fun(fun(C,fun(list(C),list(list(C)))),fun(list(C),list(list(C)))),case_list(list(list(C)),C),nil(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))))),Xss))))
                 => aa(list(list(C)),$o,Pa,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xss)) ) )
           => aa(list(list(C)),$o,Pa,A0) ) ) ) ) ).

% transpose.pinduct
tff(fact_3593_quicksort_Oelims,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(C),Y: list(C)] :
          ( ( aa(list(C),list(C),linorder_quicksort(C),X) = Y )
         => ( ( ( X = nil(C) )
             => ( Y != nil(C) ) )
           => ~ ! [X2: C,Xs2: list(C)] :
                  ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                 => ( Y != aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_im(C,fun(C,$o),X2)),Xs2))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))),aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),ord_less_eq(C),X2)),Xs2)))) ) ) ) ) ) ).

% quicksort.elims
tff(fact_3594_quicksort_Opelims,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(C),Y: list(C)] :
          ( ( aa(list(C),list(C),linorder_quicksort(C),X) = Y )
         => ( accp(list(C),linord6200660962353139674rt_rel(C),X)
           => ( ( ( X = nil(C) )
               => ( ( Y = nil(C) )
                 => ~ accp(list(C),linord6200660962353139674rt_rel(C),nil(C)) ) )
             => ~ ! [X2: C,Xs2: list(C)] :
                    ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                   => ( ( Y = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aTP_Lamp_im(C,fun(C,$o),X2)),Xs2))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))),aa(list(C),list(C),linorder_quicksort(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),ord_less_eq(C),X2)),Xs2)))) )
                     => ~ accp(list(C),linord6200660962353139674rt_rel(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)) ) ) ) ) ) ) ).

% quicksort.pelims
tff(fact_3595_sum__diff1_H__aux,axiom,
    ! [D: $tType,C: $tType] :
      ( ab_group_add(D)
     => ! [F2: set(C),I5: set(C),F: fun(C,D),I: C] :
          ( aa(set(C),$o,finite_finite2(C),F2)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_in(set(C),fun(fun(C,D),fun(C,$o)),I5),F))),F2)
           => ( groups1027152243600224163dd_sum(C,D,F,minus_minus(set(C),I5,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),I),bot_bot(set(C))))) = $ite(member2(C,I,I5),minus_minus(D,groups1027152243600224163dd_sum(C,D,F,I5),aa(C,D,F,I)),groups1027152243600224163dd_sum(C,D,F,I5)) ) ) ) ) ).

% sum_diff1'_aux
tff(fact_3596_sort__key__by__quicksort__code,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs) = aa(list(C),list(C),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),nil(C)),aa(list(C),fun(C,fun(list(C),list(C))),aTP_Lamp_is(fun(C,D),fun(list(C),fun(C,fun(list(C),list(C)))),F),Xs)),Xs) ) ).

% sort_key_by_quicksort_code
tff(fact_3597_insort__key__remove1,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [A3: C,Xs: list(C),F: fun(C,D)] :
          ( member2(C,A3,aa(list(C),set(C),set2(C),Xs))
         => ( sorted_wrt(D,ord_less_eq(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))
           => ( ( aa(list(C),C,hd(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(fun(C,D),fun(C,$o),aTP_Lamp_it(C,fun(fun(C,D),fun(C,$o)),A3),F)),Xs)) = A3 )
             => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),A3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),A3),Xs)) = Xs ) ) ) ) ) ).

% insort_key_remove1
tff(fact_3598_sort__upt,axiom,
    ! [M2: nat,N: nat] : aa(list(nat),list(nat),aa(fun(nat,nat),fun(list(nat),list(nat)),linorder_sort_key(nat,nat),aTP_Lamp_ez(nat,nat)),upt(M2,N)) = upt(M2,N) ).

% sort_upt
tff(fact_3599_sort__upto,axiom,
    ! [I: int,J: int] : aa(list(int),list(int),aa(fun(int,int),fun(list(int),list(int)),linorder_sort_key(int,int),aTP_Lamp_iu(int,int)),upto(I,J)) = upto(I,J) ).

% sort_upto
tff(fact_3600_sort__key__simps_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D)] : aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),nil(C)) = nil(C) ) ).

% sort_key_simps(1)
tff(fact_3601_set__sort,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs)) = aa(list(C),set(C),set2(C),Xs) ) ).

% set_sort
tff(fact_3602_length__sort,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs)) = aa(list(C),nat,size_size(list(C)),Xs) ) ).

% length_sort
tff(fact_3603_distinct__sort,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C)] :
          ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs))
        <=> aa(list(C),$o,distinct(C),Xs) ) ) ).

% distinct_sort
tff(fact_3604_remove1__insort__key,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [X: C,F: fun(C,D),Xs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Xs)) = Xs ) ).

% remove1_insort_key
tff(fact_3605_sum_Oempty_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(C)
     => ! [P3: fun(D,C)] : groups1027152243600224163dd_sum(D,C,P3,bot_bot(set(D))) = zero_zero(C) ) ).

% sum.empty'
tff(fact_3606_length__insort,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Xs: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Xs)) = aa(nat,nat,suc,aa(list(C),nat,size_size(list(C)),Xs)) ) ).

% length_insort
tff(fact_3607_sort__key__simps_I2_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Xs: list(C)] : aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs)) ) ).

% sort_key_simps(2)
tff(fact_3608_sorted__list__of__set_Osorted__key__list__of__set__insert,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ~ member2(C,X,A4)
           => ( aa(set(C),list(C),linord4507533701916653071of_set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),aa(set(C),list(C),linord4507533701916653071of_set(C),A4)) ) ) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_insert
tff(fact_3609_sorted__list__of__set_Osorted__key__list__of__set__insert__remove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),list(C),linord4507533701916653071of_set(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),aa(set(C),list(C),linord4507533701916653071of_set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ).

% sorted_list_of_set.sorted_key_list_of_set_insert_remove
tff(fact_3610_filter__insort__triv,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Pa: fun(C,$o),X: C,F: fun(C,D),Xs: list(C)] :
          ( ~ aa(C,$o,Pa,X)
         => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) ) ) ) ).

% filter_insort_triv
tff(fact_3611_insort__key__left__comm,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),X: D,Y: D,Xs: list(D)] :
          ( ( aa(D,C,F,X) != aa(D,C,F,Y) )
         => ( aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),Y),aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),Xs)) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),Y),Xs)) ) ) ) ).

% insort_key_left_comm
tff(fact_3612_insort__left__comm,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Y: C,Xs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),Y),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),Y),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),Xs)) ) ).

% insort_left_comm
tff(fact_3613_sort__key__const,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [C3: D,Xs: list(C)] : aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),aTP_Lamp_at(D,fun(C,D),C3)),Xs) = Xs ) ).

% sort_key_const
tff(fact_3614_insort__not__Nil,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),A3: C,Xs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),A3),Xs) != nil(C) ) ).

% insort_not_Nil
tff(fact_3615_filter__sort,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Pa: fun(C,$o),F: fun(C,D),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs)) = aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs)) ) ).

% filter_sort
tff(fact_3616_sort__key__def,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),foldr(C,list(C)),linorder_insort_key(C,D,F)),Xs),nil(C)) ) ).

% sort_key_def
tff(fact_3617_sort__key__stable,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),K: D,Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(D,fun(C,$o),aTP_Lamp_iv(fun(C,D),fun(D,fun(C,$o)),F),K)),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(D,fun(C,$o),aTP_Lamp_iv(fun(C,D),fun(D,fun(C,$o)),F),K)),Xs) ) ).

% sort_key_stable
tff(fact_3618_sort__quicksort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)) = linorder_quicksort(C) ) ) ).

% sort_quicksort
tff(fact_3619_insort__key_Osimps_I2_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Y: C,Ys: list(C)] :
          aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) = $ite(aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X)),aa(C,D,F,Y)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Ys))) ) ).

% insort_key.simps(2)
tff(fact_3620_insort__key_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),nil(C)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ) ).

% insort_key.simps(1)
tff(fact_3621_set__insort__key,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Xs)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(list(C),set(C),set2(C),Xs)) ) ).

% set_insort_key
tff(fact_3622_distinct__insort,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Xs: list(C)] :
          ( aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Xs))
        <=> ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
            & aa(list(C),$o,distinct(C),Xs) ) ) ) ).

% distinct_insort
tff(fact_3623_sorted__insort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),Xs))
        <=> sorted_wrt(C,ord_less_eq(C),Xs) ) ) ).

% sorted_insort
tff(fact_3624_sorted__sort__id,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)),Xs) = Xs ) ) ) ).

% sorted_sort_id
tff(fact_3625_sorted__sort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)),Xs)) ) ).

% sorted_sort
tff(fact_3626_sorted__list__of__set_Ofold__insort__key_Oeq__fold,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] : aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = finite_fold(C,list(C),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),nil(C),A4) ) ).

% sorted_list_of_set.fold_insort_key.eq_fold
tff(fact_3627_sort__mergesort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)) = mergesort(C) ) ) ).

% sort_mergesort
tff(fact_3628_sort__mergesort__by__rel,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)) = mergesort_by_rel(C,ord_less_eq(C)) ) ) ).

% sort_mergesort_by_rel
tff(fact_3629_insort__insert__insort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] :
          ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
         => ( linord329482645794927042rt_key(C,C,aTP_Lamp_az(C,C),X,Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),Xs) ) ) ) ).

% insort_insert_insort
tff(fact_3630_insort__is__Cons,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Xs: list(C),F: fun(C,D),A3: C] :
          ( ! [X2: C] :
              ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,A3)),aa(C,D,F,X2)) )
         => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),A3),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),Xs) ) ) ) ).

% insort_is_Cons
tff(fact_3631_sorted__insort__key,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),X: D,Xs: list(D)] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),Xs)))
        <=> sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) ) ) ).

% sorted_insort_key
tff(fact_3632_sorted__sort__key,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D)] : sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,C),fun(list(D),list(D)),linorder_sort_key(D,C),F),Xs))) ) ).

% sorted_sort_key
tff(fact_3633_insort__insert__key__def,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),X: C,Xs: list(C)] :
          linord329482645794927042rt_key(C,D,F,X,Xs) = $ite(member2(D,aa(C,D,F,X),aa(set(C),set(D),image2(C,D,F),aa(list(C),set(C),set2(C),Xs))),Xs,aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,D,F),X),Xs)) ) ).

% insort_insert_key_def
tff(fact_3634_insort__insert__insort__key,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),X: D,Xs: list(D)] :
          ( ~ member2(C,aa(D,C,F,X),aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),Xs)))
         => ( linord329482645794927042rt_key(D,C,F,X,Xs) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),Xs) ) ) ) ).

% insort_insert_insort_key
tff(fact_3635_sorted__list__of__set__sort__remdups,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : aa(set(C),list(C),linord4507533701916653071of_set(C),aa(list(C),set(C),set2(C),Xs)) = aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)),aa(list(C),list(C),remdups(C),Xs)) ) ).

% sorted_list_of_set_sort_remdups
tff(fact_3636_distinct__insort__key,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),X: D,Xs: list(D)] :
          ( aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),Xs)))
        <=> ( ~ member2(C,aa(D,C,F,X),aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),Xs)))
            & aa(list(C),$o,distinct(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) ) ) ) ).

% distinct_insort_key
tff(fact_3637_filter__insort,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [F: fun(D,C),Xs: list(D),Pa: fun(D,$o),X: D] :
          ( sorted_wrt(C,ord_less_eq(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
         => ( aa(D,$o,Pa,X)
           => ( aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),Xs)) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),linorder_insort_key(D,C,F),X),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs)) ) ) ) ) ).

% filter_insort
tff(fact_3638_insort__remove1,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,Xs: list(C)] :
          ( member2(C,A3,aa(list(C),set(C),set2(C),Xs))
         => ( sorted_wrt(C,ord_less_eq(C),Xs)
           => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),A3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),A3),Xs)) = Xs ) ) ) ) ).

% insort_remove1
tff(fact_3639_part__code_I1_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Pivot: D] : linorder_part(C,D,F,Pivot,nil(C)) = aa(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C))),aa(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C)))),product_Pair(list(C),product_prod(list(C),list(C))),nil(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C))) ) ).

% part_code(1)
tff(fact_3640_sorted__list__of__set_Ofold__insort__key_Oremove,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( aa(set(C),list(C),linord4507533701916653071of_set(C),A4) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),aa(set(C),list(C),linord4507533701916653071of_set(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ).

% sorted_list_of_set.fold_insort_key.remove
tff(fact_3641_sorted__insort__is__snoc,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),A3: C] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( ! [X2: C] :
                ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),A3) )
           => ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),A3),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C))) ) ) ) ) ).

% sorted_insort_is_snoc
tff(fact_3642_sum__diff1_H,axiom,
    ! [D: $tType,C: $tType] :
      ( ab_group_add(D)
     => ! [I5: set(C),F: fun(C,D),I: C] :
          ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_in(set(C),fun(fun(C,D),fun(C,$o)),I5),F)))
         => ( groups1027152243600224163dd_sum(C,D,F,minus_minus(set(C),I5,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),I),bot_bot(set(C))))) = $ite(member2(C,I,I5),minus_minus(D,groups1027152243600224163dd_sum(C,D,F,I5),aa(C,D,F,I)),groups1027152243600224163dd_sum(C,D,F,I5)) ) ) ) ).

% sum_diff1'
tff(fact_3643_part__code_I2_J,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Pivot: D,X: C,Xs: list(C)] : linorder_part(C,D,F,Pivot,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(product_prod(list(C),product_prod(list(C),list(C))),product_prod(list(C),product_prod(list(C),list(C))),product_case_prod(list(C),product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C))),aa(C,fun(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C))))),aa(D,fun(C,fun(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C)))))),aTP_Lamp_ix(fun(C,D),fun(D,fun(C,fun(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C))))))),F),Pivot),X)),linorder_part(C,D,F,Pivot,Xs)) ) ).

% part_code(2)
tff(fact_3644_Bleast__code,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Pa: fun(C,$o)] : bleast(C,aa(list(C),set(C),set2(C),Xs),Pa) = aa(list(C),C,aa(fun(C,fun(list(C),C)),fun(list(C),C),aa(C,fun(fun(C,fun(list(C),C)),fun(list(C),C)),case_list(C,C),abort_Bleast(C,aa(list(C),set(C),set2(C),Xs),Pa)),aTP_Lamp_iy(C,fun(list(C),C))),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)),Xs))) ) ).

% Bleast_code
tff(fact_3645_Fpow__Pow__finite,axiom,
    ! [C: $tType,A4: set(C)] : finite_Fpow(C,A4) = aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),inf_inf(set(set(C))),pow(C,A4)),collect(set(C),finite_finite2(C))) ).

% Fpow_Pow_finite
tff(fact_3646_set__zip,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = collect(product_prod(C,D),aa(list(D),fun(product_prod(C,D),$o),aTP_Lamp_iz(list(C),fun(list(D),fun(product_prod(C,D),$o)),Xs),Ys)) ).

% set_zip
tff(fact_3647_listrel__iff__zip,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D),R3: set(product_prod(C,D))] :
      ( member2(product_prod(list(C),list(D)),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xs),Ys),listrel(C,D,R3))
    <=> ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
        & ! [X4: product_prod(C,D)] :
            ( member2(product_prod(C,D),X4,aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)))
           => aa(product_prod(C,D),$o,product_case_prod(C,D,$o,aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),R3)),X4) ) ) ) ).

% listrel_iff_zip
tff(fact_3648_ball__empty,axiom,
    ! [C: $tType,Pa: fun(C,$o),X3: C] :
      ( member2(C,X3,bot_bot(set(C)))
     => aa(C,$o,Pa,X3) ) ).

% ball_empty
tff(fact_3649_eq__or__mem__image__simp,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A3: D,B3: set(D)] : collect(C,aa(set(D),fun(C,$o),aa(D,fun(set(D),fun(C,$o)),aTP_Lamp_ja(fun(D,C),fun(D,fun(set(D),fun(C,$o))),F),A3),B3)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(D,C,F,A3)),collect(C,aa(set(D),fun(C,$o),aTP_Lamp_jb(fun(D,C),fun(set(D),fun(C,$o)),F),B3))) ).

% eq_or_mem_image_simp
tff(fact_3650_set__Cons__def,axiom,
    ! [C: $tType,A4: set(C),XS: set(list(C))] : aa(set(list(C)),set(list(C)),aa(set(C),fun(set(list(C)),set(list(C))),set_Cons(C),A4),XS) = collect(list(C),aa(set(list(C)),fun(list(C),$o),aTP_Lamp_jc(set(C),fun(set(list(C)),fun(list(C),$o)),A4),XS)) ).

% set_Cons_def
tff(fact_3651_setcompr__eq__image,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Pa: fun(D,$o)] : collect(C,aa(fun(D,$o),fun(C,$o),aTP_Lamp_jd(fun(D,C),fun(fun(D,$o),fun(C,$o)),F),Pa)) = aa(set(D),set(C),image2(D,C,F),collect(D,Pa)) ).

% setcompr_eq_image
tff(fact_3652_Setcompr__eq__image,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] : collect(C,aa(set(D),fun(C,$o),aTP_Lamp_jb(fun(D,C),fun(set(D),fun(C,$o)),F),A4)) = aa(set(D),set(C),image2(D,C,F),A4) ).

% Setcompr_eq_image
tff(fact_3653_empty__in__Fpow,axiom,
    ! [C: $tType,A4: set(C)] : member2(set(C),bot_bot(set(C)),finite_Fpow(C,A4)) ).

% empty_in_Fpow
tff(fact_3654_Field__not__elem,axiom,
    ! [C: $tType,V: C,R: set(product_prod(C,C))] :
      ( ~ member2(C,V,field2(C,R))
     => ! [X3: product_prod(C,C)] :
          ( member2(product_prod(C,C),X3,R)
         => aa(product_prod(C,C),$o,product_case_prod(C,C,$o,aTP_Lamp_je(C,fun(C,fun(C,$o)),V)),X3) ) ) ).

% Field_not_elem
tff(fact_3655_listrel1__def,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : listrel1(C,R3) = collect(product_prod(list(C),list(C)),product_case_prod(list(C),list(C),$o,aTP_Lamp_jf(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),R3))) ).

% listrel1_def
tff(fact_3656_lexord__def,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : lexord(C,R3) = collect(product_prod(list(C),list(C)),product_case_prod(list(C),list(C),$o,aTP_Lamp_jg(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),R3))) ).

% lexord_def
tff(fact_3657_sorted__wrt_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),X: C,Ys: list(C)] :
      ( sorted_wrt(C,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys))
    <=> ( ! [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),Ys))
           => aa(C,$o,aa(C,fun(C,$o),Pa,X),X4) )
        & sorted_wrt(C,Pa,Ys) ) ) ).

% sorted_wrt.simps(2)
tff(fact_3658_sorted__wrt_Oelims_I3_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( ~ sorted_wrt(C,X,Xa)
     => ~ ! [X2: C,Ys2: list(C)] :
            ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2) )
           => ( ! [Xa4: C] :
                  ( member2(C,Xa4,aa(list(C),set(C),set2(C),Ys2))
                 => aa(C,$o,aa(C,fun(C,$o),X,X2),Xa4) )
              & sorted_wrt(C,X,Ys2) ) ) ) ).

% sorted_wrt.elims(3)
tff(fact_3659_Un__interval,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(C)
     => ! [B1: C,B22: C,B32: C,F: fun(C,D)] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B1),B22)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B22),B32)
           => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),collect(D,aa(fun(C,D),fun(D,$o),aa(C,fun(fun(C,D),fun(D,$o)),aTP_Lamp_jh(C,fun(C,fun(fun(C,D),fun(D,$o))),B1),B22),F))),collect(D,aa(fun(C,D),fun(D,$o),aa(C,fun(fun(C,D),fun(D,$o)),aTP_Lamp_jh(C,fun(C,fun(fun(C,D),fun(D,$o))),B22),B32),F))) = collect(D,aa(fun(C,D),fun(D,$o),aa(C,fun(fun(C,D),fun(D,$o)),aTP_Lamp_jh(C,fun(C,fun(fun(C,D),fun(D,$o))),B1),B32),F)) ) ) ) ) ).

% Un_interval
tff(fact_3660_lex__conv,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : lex(C,R3) = collect(product_prod(list(C),list(C)),product_case_prod(list(C),list(C),$o,aTP_Lamp_ji(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),R3))) ).

% lex_conv
tff(fact_3661_takeWhile__append,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C)] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = $ite(
        ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) ),
        aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Ys)),
        aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) ) ).

% takeWhile_append
tff(fact_3662_list__collect__set__def,axiom,
    ! [C: $tType,D: $tType,F: fun(D,set(C)),La: list(D)] : list_collect_set(D,C,F,La) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),collect(set(C),aa(list(D),fun(set(C),$o),aTP_Lamp_jj(fun(D,set(C)),fun(list(D),fun(set(C),$o)),F),La))) ).

% list_collect_set_def
tff(fact_3663_sorted__wrt_Oelims_I2_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( sorted_wrt(C,X,Xa)
     => ( ( Xa != nil(C) )
       => ~ ! [X2: C,Ys2: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2) )
             => ~ ( ! [Xa3: C] :
                      ( member2(C,Xa3,aa(list(C),set(C),set2(C),Ys2))
                     => aa(C,$o,aa(C,fun(C,$o),X,X2),Xa3) )
                  & sorted_wrt(C,X,Ys2) ) ) ) ) ).

% sorted_wrt.elims(2)
tff(fact_3664_sorted__wrt_Oelims_I1_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Y: $o] :
      ( ( sorted_wrt(C,X,Xa)
      <=> (Y) )
     => ( ( ( Xa = nil(C) )
         => ~ (Y) )
       => ~ ! [X2: C,Ys2: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2) )
             => ( (Y)
              <=> ~ ( ! [Xa2: C] :
                        ( member2(C,Xa2,aa(list(C),set(C),set2(C),Ys2))
                       => aa(C,$o,aa(C,fun(C,$o),X,X2),Xa2) )
                    & sorted_wrt(C,X,Ys2) ) ) ) ) ) ).

% sorted_wrt.elims(1)
tff(fact_3665_set__conv__nth,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(C),set2(C),Xs) = collect(C,aTP_Lamp_jk(list(C),fun(C,$o),Xs)) ).

% set_conv_nth
tff(fact_3666_inf__Sup1__distrib,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),lattic5882676163264333800up_fin(C,A4)) = lattic5882676163264333800up_fin(C,collect(C,aa(C,fun(C,$o),aTP_Lamp_jl(set(C),fun(C,fun(C,$o)),A4),X))) ) ) ) ) ).

% inf_Sup1_distrib
tff(fact_3667_inf__Sup2__distrib,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( B3 != bot_bot(set(C)) )
               => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),lattic5882676163264333800up_fin(C,A4)),lattic5882676163264333800up_fin(C,B3)) = lattic5882676163264333800up_fin(C,collect(C,aa(set(C),fun(C,$o),aTP_Lamp_jm(set(C),fun(set(C),fun(C,$o)),A4),B3))) ) ) ) ) ) ) ).

% inf_Sup2_distrib
tff(fact_3668_sup__Inf2__distrib,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( B3 != bot_bot(set(C)) )
               => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)),aa(set(C),C,lattic7752659483105999362nf_fin(C),B3)) = aa(set(C),C,lattic7752659483105999362nf_fin(C),collect(C,aa(set(C),fun(C,$o),aTP_Lamp_jn(set(C),fun(set(C),fun(C,$o)),A4),B3))) ) ) ) ) ) ) ).

% sup_Inf2_distrib
tff(fact_3669_sup__Inf1__distrib,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [A4: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(set(C),C,lattic7752659483105999362nf_fin(C),A4)) = aa(set(C),C,lattic7752659483105999362nf_fin(C),collect(C,aa(C,fun(C,$o),aTP_Lamp_jo(set(C),fun(C,fun(C,$o)),A4),X))) ) ) ) ) ).

% sup_Inf1_distrib
tff(fact_3670_list__eq__iff__zip__eq,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs = Ys )
    <=> ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(C),nat,size_size(list(C)),Ys) )
        & ! [X4: product_prod(C,C)] :
            ( member2(product_prod(C,C),X4,aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),aa(list(C),list(product_prod(C,C)),aa(list(C),fun(list(C),list(product_prod(C,C))),zip(C,C),Xs),Ys)))
           => aa(product_prod(C,C),$o,product_case_prod(C,C,$o,fequal(C)),X4) ) ) ) ).

% list_eq_iff_zip_eq
tff(fact_3671_concat__eq__concat__iff,axiom,
    ! [C: $tType,Xs: list(list(C)),Ys: list(list(C))] :
      ( ! [X2: product_prod(list(C),list(C))] :
          ( member2(product_prod(list(C),list(C)),X2,aa(list(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),set2(product_prod(list(C),list(C))),aa(list(list(C)),list(product_prod(list(C),list(C))),aa(list(list(C)),fun(list(list(C)),list(product_prod(list(C),list(C)))),zip(list(C),list(C)),Xs),Ys)))
         => aa(product_prod(list(C),list(C)),$o,product_case_prod(list(C),list(C),$o,aTP_Lamp_jp(list(C),fun(list(C),$o))),X2) )
     => ( ( aa(list(list(C)),nat,size_size(list(list(C))),Xs) = aa(list(list(C)),nat,size_size(list(list(C))),Ys) )
       => ( ( aa(list(list(C)),list(C),concat(C),Xs) = aa(list(list(C)),list(C),concat(C),Ys) )
        <=> ( Xs = Ys ) ) ) ) ).

% concat_eq_concat_iff
tff(fact_3672_concat__injective,axiom,
    ! [C: $tType,Xs: list(list(C)),Ys: list(list(C))] :
      ( ( aa(list(list(C)),list(C),concat(C),Xs) = aa(list(list(C)),list(C),concat(C),Ys) )
     => ( ( aa(list(list(C)),nat,size_size(list(list(C))),Xs) = aa(list(list(C)),nat,size_size(list(list(C))),Ys) )
       => ( ! [X2: product_prod(list(C),list(C))] :
              ( member2(product_prod(list(C),list(C)),X2,aa(list(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),set2(product_prod(list(C),list(C))),aa(list(list(C)),list(product_prod(list(C),list(C))),aa(list(list(C)),fun(list(list(C)),list(product_prod(list(C),list(C)))),zip(list(C),list(C)),Xs),Ys)))
             => aa(product_prod(list(C),list(C)),$o,product_case_prod(list(C),list(C),$o,aTP_Lamp_jp(list(C),fun(list(C),$o))),X2) )
         => ( Xs = Ys ) ) ) ) ).

% concat_injective
tff(fact_3673_list__collect__set__alt,axiom,
    ! [C: $tType,D: $tType,F: fun(D,set(C)),La: list(D)] : list_collect_set(D,C,F,La) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),collect(set(C),aa(list(D),fun(set(C),$o),aTP_Lamp_jq(fun(D,set(C)),fun(list(D),fun(set(C),$o)),F),La))) ).

% list_collect_set_alt
tff(fact_3674_set__drop__conv,axiom,
    ! [C: $tType,N: nat,La: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),La)) = collect(C,aa(list(C),fun(C,$o),aTP_Lamp_jr(nat,fun(list(C),fun(C,$o)),N),La)) ).

% set_drop_conv
tff(fact_3675_lexn__conv,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),N: nat] : aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),N) = collect(product_prod(list(C),list(C)),product_case_prod(list(C),list(C),$o,aa(nat,fun(list(C),fun(list(C),$o)),aTP_Lamp_js(set(product_prod(C,C)),fun(nat,fun(list(C),fun(list(C),$o))),R3),N))) ).

% lexn_conv
tff(fact_3676_finite__inf__Sup,axiom,
    ! [C: $tType] :
      ( finite8700451911770168679attice(C)
     => ! [A3: C,A4: set(C)] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Sup_Sup(C),A4)) = aa(set(C),C,complete_Sup_Sup(C),collect(C,aa(set(C),fun(C,$o),aTP_Lamp_jt(C,fun(set(C),fun(C,$o)),A3),A4))) ) ).

% finite_inf_Sup
tff(fact_3677_pairself__image__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Pa: fun(D,fun(D,$o))] : aa(set(product_prod(D,D)),set(product_prod(C,C)),image2(product_prod(D,D),product_prod(C,C),pairself(D,C,F)),collect(product_prod(D,D),product_case_prod(D,D,$o,Pa))) = collect(product_prod(C,C),aa(fun(D,fun(D,$o)),fun(product_prod(C,C),$o),aTP_Lamp_ju(fun(D,C),fun(fun(D,fun(D,$o)),fun(product_prod(C,C),$o)),F),Pa)) ).

% pairself_image_eq
tff(fact_3678_brk__rel__def,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D))] : brk_rel(C,D,R) = aa(set(product_prod(product_prod($o,C),product_prod($o,D))),set(product_prod(product_prod($o,C),product_prod($o,D))),aa(set(product_prod(product_prod($o,C),product_prod($o,D))),fun(set(product_prod(product_prod($o,C),product_prod($o,D))),set(product_prod(product_prod($o,C),product_prod($o,D)))),sup_sup(set(product_prod(product_prod($o,C),product_prod($o,D)))),collect(product_prod(product_prod($o,C),product_prod($o,D)),aTP_Lamp_jv(set(product_prod(C,D)),fun(product_prod(product_prod($o,C),product_prod($o,D)),$o),R))),collect(product_prod(product_prod($o,C),product_prod($o,D)),aTP_Lamp_jw(product_prod(product_prod($o,C),product_prod($o,D)),$o))) ).

% brk_rel_def
tff(fact_3679_lexn_Osimps_I1_J,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),zero_zero(nat)) = bot_bot(set(product_prod(list(C),list(C)))) ).

% lexn.simps(1)
tff(fact_3680_pairself_Osimps,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A3: D,B2: D] : aa(product_prod(D,D),product_prod(C,C),pairself(D,C,F),aa(D,product_prod(D,D),aa(D,fun(D,product_prod(D,D)),product_Pair(D,D),A3),B2)) = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(D,C,F,A3)),aa(D,C,F,B2)) ).

% pairself.simps
tff(fact_3681_pairself_Oelims,axiom,
    ! [C: $tType,D: $tType,X: fun(D,C),Xa: product_prod(D,D),Y: product_prod(C,C)] :
      ( ( aa(product_prod(D,D),product_prod(C,C),pairself(D,C,X),Xa) = Y )
     => ~ ! [A5: D,B4: D] :
            ( ( Xa = aa(D,product_prod(D,D),aa(D,fun(D,product_prod(D,D)),product_Pair(D,D),A5),B4) )
           => ( Y != aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(D,C,X,A5)),aa(D,C,X,B4)) ) ) ) ).

% pairself.elims
tff(fact_3682_Pow__Compl,axiom,
    ! [C: $tType,A4: set(C)] : pow(C,aa(set(C),set(C),uminus_uminus(set(C)),A4)) = collect(set(C),aTP_Lamp_jx(set(C),fun(set(C),$o),A4)) ).

% Pow_Compl
tff(fact_3683_lexn__length,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C)),N: nat] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),N))
     => ( ( aa(list(C),nat,size_size(list(C)),Xs) = N )
        & ( aa(list(C),nat,size_size(list(C)),Ys) = N ) ) ) ).

% lexn_length
tff(fact_3684_pairself_Opelims,axiom,
    ! [C: $tType,D: $tType,X: fun(D,C),Xa: product_prod(D,D),Y: product_prod(C,C)] :
      ( ( aa(product_prod(D,D),product_prod(C,C),pairself(D,C,X),Xa) = Y )
     => ( accp(product_prod(fun(D,C),product_prod(D,D)),pairself_rel(D,C),aa(product_prod(D,D),product_prod(fun(D,C),product_prod(D,D)),aa(fun(D,C),fun(product_prod(D,D),product_prod(fun(D,C),product_prod(D,D))),product_Pair(fun(D,C),product_prod(D,D)),X),Xa))
       => ~ ! [A5: D,B4: D] :
              ( ( Xa = aa(D,product_prod(D,D),aa(D,fun(D,product_prod(D,D)),product_Pair(D,D),A5),B4) )
             => ( ( Y = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(D,C,X,A5)),aa(D,C,X,B4)) )
               => ~ accp(product_prod(fun(D,C),product_prod(D,D)),pairself_rel(D,C),aa(product_prod(D,D),product_prod(fun(D,C),product_prod(D,D)),aa(fun(D,C),fun(product_prod(D,D),product_prod(fun(D,C),product_prod(D,D))),product_Pair(fun(D,C),product_prod(D,D)),X),aa(D,product_prod(D,D),aa(D,fun(D,product_prod(D,D)),product_Pair(D,D),A5),B4))) ) ) ) ) ).

% pairself.pelims
tff(fact_3685_ord__class_Olexordp__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ( ord_lexordp(C) = complete_lattice_lfp(fun(list(C),fun(list(C),$o)),aTP_Lamp_jy(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o)))) ) ) ).

% ord_class.lexordp_def
tff(fact_3686_comp__fun__commute__on_Ofold__set__union__disj,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,fun(D,D)),A4: set(C),B3: set(C),Z2: D] :
      ( finite4664212375090638736ute_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),S)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),S)
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( aa(set(C),$o,finite_finite2(C),B3)
             => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
               => ( finite_fold(C,D,F,Z2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = finite_fold(C,D,F,finite_fold(C,D,F,Z2,A4),B3) ) ) ) ) ) ) ) ).

% comp_fun_commute_on.fold_set_union_disj
tff(fact_3687_horner__sum__eq__sum__funpow,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_semiring_0(C)
     => ! [F: fun(D,C),A3: C,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(D,C),fun(C,fun(list(D),C)),groups4207007520872428315er_sum(D,C),F),A3),Xs) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(list(D),fun(nat,C),aa(C,fun(list(D),fun(nat,C)),aTP_Lamp_jz(fun(D,C),fun(C,fun(list(D),fun(nat,C))),F),A3),Xs)),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(D),nat,size_size(list(D)),Xs))) ) ).

% horner_sum_eq_sum_funpow
tff(fact_3688_funpow__times__power,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [F: fun(C,nat),X: C] : compow(fun(C,C),aa(C,nat,F,X),aa(C,fun(C,C),times_times(C),X)) = aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),aa(C,nat,F,X))) ) ).

% funpow_times_power
tff(fact_3689_rotate__def,axiom,
    ! [C: $tType,N: nat] : aa(nat,fun(list(C),list(C)),rotate(C),N) = compow(fun(list(C),list(C)),N,rotate1(C)) ).

% rotate_def
tff(fact_3690_of__nat__def,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [N: nat] : aa(nat,C,semiring_1_of_nat(C),N) = aa(C,C,compow(fun(C,C),N,aa(C,fun(C,C),plus_plus(C),one_one(C))),zero_zero(C)) ) ).

% of_nat_def
tff(fact_3691_numeral__add__unfold__funpow,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [K: num,A3: C] : aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(num,C,numeral_numeral(C),K)),A3) = aa(C,C,compow(fun(C,C),aa(num,nat,numeral_numeral(nat),K),aa(C,fun(C,C),plus_plus(C),one_one(C))),A3) ) ).

% numeral_add_unfold_funpow
tff(fact_3692_butlast__power,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),compow(fun(list(C),list(C)),N,butlast(C)),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),minus_minus(nat,aa(list(C),nat,size_size(list(C)),Xs),N)),Xs) ).

% butlast_power
tff(fact_3693_numeral__unfold__funpow,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [K: num] : aa(num,C,numeral_numeral(C),K) = aa(C,C,compow(fun(C,C),aa(num,nat,numeral_numeral(nat),K),aa(C,fun(C,C),plus_plus(C),one_one(C))),zero_zero(C)) ) ).

% numeral_unfold_funpow
tff(fact_3694_comp__fun__commute__on_Ofold__insert__remove,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,fun(D,D)),X: C,A4: set(C),Z2: D] :
      ( finite4664212375090638736ute_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)),S)
       => ( aa(set(C),$o,finite_finite2(C),A4)
         => ( finite_fold(C,D,F,Z2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(D,D,aa(C,fun(D,D),F,X),finite_fold(C,D,F,Z2,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ).

% comp_fun_commute_on.fold_insert_remove
tff(fact_3695_comp__fun__commute__on_Ofold__rec,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,fun(D,D)),A4: set(C),X: C,Z2: D] :
      ( finite4664212375090638736ute_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),S)
       => ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( finite_fold(C,D,F,Z2,A4) = aa(D,D,aa(C,fun(D,D),F,X),finite_fold(C,D,F,Z2,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ) ).

% comp_fun_commute_on.fold_rec
tff(fact_3696_ord_Olexordp__def,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o))] : lexordp2(C,Less) = complete_lattice_lfp(fun(list(C),fun(list(C),$o)),aTP_Lamp_ka(fun(C,fun(C,$o)),fun(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o))),Less)) ).

% ord.lexordp_def
tff(fact_3697_enumerate__Suc,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [S: set(C),N: nat] : infini527867602293511546merate(C,S,aa(nat,nat,suc,N)) = infini527867602293511546merate(C,minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),ord_Least(C,aTP_Lamp_kb(set(C),fun(C,$o),S))),bot_bot(set(C)))),N) ) ).

% enumerate_Suc
tff(fact_3698_sup__bot_Osemilattice__neutr__order__axioms,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => semila1105856199041335345_order(C,sup_sup(C),bot_bot(C),aTP_Lamp_kc(C,fun(C,$o)),aTP_Lamp_kd(C,fun(C,$o))) ) ).

% sup_bot.semilattice_neutr_order_axioms
tff(fact_3699_min__list_Oelims,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: list(C),Y: C] :
          ( ( min_list(C,X) = Y )
         => ( ! [X2: C,Xs2: list(C)] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ( Y != aa(list(C),C,aa(fun(C,fun(list(C),C)),fun(list(C),C),aa(C,fun(fun(C,fun(list(C),C)),fun(list(C),C)),case_list(C,C),X2),aa(list(C),fun(C,fun(list(C),C)),aTP_Lamp_dp(C,fun(list(C),fun(C,fun(list(C),C))),X2),Xs2)),Xs2) ) )
           => ~ ( ( X = nil(C) )
               => ( Y != undefined(C) ) ) ) ) ) ).

% min_list.elims
tff(fact_3700_ord_Olexordp__simps_I3_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Xs: list(C),Y: C,Ys: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))
    <=> ( aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
        | ( ~ aa(C,$o,aa(C,fun(C,$o),Less,Y),X)
          & aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs),Ys) ) ) ) ).

% ord.lexordp_simps(3)
tff(fact_3701_ord_Olexordp__simps_I1_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Ys: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),nil(C)),Ys)
    <=> ( Ys != nil(C) ) ) ).

% ord.lexordp_simps(1)
tff(fact_3702_ord_Olexordp__simps_I2_J,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Xs: list(C)] : ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs),nil(C)) ).

% ord.lexordp_simps(2)
tff(fact_3703_LeastI,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),K: C] :
          ( aa(C,$o,Pa,K)
         => aa(C,$o,Pa,ord_Least(C,Pa)) ) ) ).

% LeastI
tff(fact_3704_LeastI2__ex,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),Q: fun(C,$o)] :
          ( ? [X_13: C] : aa(C,$o,Pa,X_13)
         => ( ! [X2: C] :
                ( aa(C,$o,Pa,X2)
               => aa(C,$o,Q,X2) )
           => aa(C,$o,Q,ord_Least(C,Pa)) ) ) ) ).

% LeastI2_ex
tff(fact_3705_LeastI__ex,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o)] :
          ( ? [X_13: C] : aa(C,$o,Pa,X_13)
         => aa(C,$o,Pa,ord_Least(C,Pa)) ) ) ).

% LeastI_ex
tff(fact_3706_LeastI2,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),A3: C,Q: fun(C,$o)] :
          ( aa(C,$o,Pa,A3)
         => ( ! [X2: C] :
                ( aa(C,$o,Pa,X2)
               => aa(C,$o,Q,X2) )
           => aa(C,$o,Q,ord_Least(C,Pa)) ) ) ) ).

% LeastI2
tff(fact_3707_ord_Olexordp__irreflexive,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Xs: list(C)] :
      ( ! [X2: C] : ~ aa(C,$o,aa(C,fun(C,$o),Less,X2),X2)
     => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs),Xs) ) ).

% ord.lexordp_irreflexive
tff(fact_3708_ord_Olexordp_Ocong,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o))] : lexordp2(C,Less) = lexordp2(C,Less) ).

% ord.lexordp.cong
tff(fact_3709_semilattice__neutr__order_Oneutr__eq__iff,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semila1105856199041335345_order(C,F,Z2,Less_eq,Less)
     => ( ( Z2 = aa(C,C,aa(C,fun(C,C),F,A3),B2) )
      <=> ( ( A3 = Z2 )
          & ( B2 = Z2 ) ) ) ) ).

% semilattice_neutr_order.neutr_eq_iff
tff(fact_3710_semilattice__neutr__order_Oeq__neutr__iff,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semila1105856199041335345_order(C,F,Z2,Less_eq,Less)
     => ( ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = Z2 )
      <=> ( ( A3 = Z2 )
          & ( B2 = Z2 ) ) ) ) ).

% semilattice_neutr_order.eq_neutr_iff
tff(fact_3711_ord_Olexordp_OCons,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Y: C,Xs: list(C),Ys: list(C)] :
      ( aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ).

% ord.lexordp.Cons
tff(fact_3712_ord_Olexordp_OCons__eq,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Y: C,Xs: list(C),Ys: list(C)] :
      ( ~ aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
     => ( ~ aa(C,$o,aa(C,fun(C,$o),Less,Y),X)
       => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs),Ys)
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ) ).

% ord.lexordp.Cons_eq
tff(fact_3713_LeastI2__wellorder__ex,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),Q: fun(C,$o)] :
          ( ? [X_13: C] : aa(C,$o,Pa,X_13)
         => ( ! [A5: C] :
                ( aa(C,$o,Pa,A5)
               => ( ! [B11: C] :
                      ( aa(C,$o,Pa,B11)
                     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A5),B11) )
                 => aa(C,$o,Q,A5) ) )
           => aa(C,$o,Q,ord_Least(C,Pa)) ) ) ) ).

% LeastI2_wellorder_ex
tff(fact_3714_LeastI2__wellorder,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),A3: C,Q: fun(C,$o)] :
          ( aa(C,$o,Pa,A3)
         => ( ! [A5: C] :
                ( aa(C,$o,Pa,A5)
               => ( ! [B11: C] :
                      ( aa(C,$o,Pa,B11)
                     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A5),B11) )
                 => aa(C,$o,Q,A5) ) )
           => aa(C,$o,Q,ord_Least(C,Pa)) ) ) ) ).

% LeastI2_wellorder
tff(fact_3715_Least__equality,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o),X: C] :
          ( aa(C,$o,Pa,X)
         => ( ! [Y2: C] :
                ( aa(C,$o,Pa,Y2)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y2) )
           => ( ord_Least(C,Pa) = X ) ) ) ) ).

% Least_equality
tff(fact_3716_LeastI2__order,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o),X: C,Q: fun(C,$o)] :
          ( aa(C,$o,Pa,X)
         => ( ! [Y2: C] :
                ( aa(C,$o,Pa,Y2)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y2) )
           => ( ! [X2: C] :
                  ( aa(C,$o,Pa,X2)
                 => ( ! [Y4: C] :
                        ( aa(C,$o,Pa,Y4)
                       => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y4) )
                   => aa(C,$o,Q,X2) ) )
             => aa(C,$o,Q,ord_Least(C,Pa)) ) ) ) ) ).

% LeastI2_order
tff(fact_3717_Least1__le,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o),Z2: C] :
          ( ? [X3: C] :
              ( aa(C,$o,Pa,X3)
              & ! [Y2: C] :
                  ( aa(C,$o,Pa,Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X3),Y2) )
              & ! [Y2: C] :
                  ( ( aa(C,$o,Pa,Y2)
                    & ! [Ya2: C] :
                        ( aa(C,$o,Pa,Ya2)
                       => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),Ya2) ) )
                 => ( Y2 = X3 ) ) )
         => ( aa(C,$o,Pa,Z2)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),ord_Least(C,Pa)),Z2) ) ) ) ).

% Least1_le
tff(fact_3718_Least1I,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o)] :
          ( ? [X3: C] :
              ( aa(C,$o,Pa,X3)
              & ! [Y2: C] :
                  ( aa(C,$o,Pa,Y2)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X3),Y2) )
              & ! [Y2: C] :
                  ( ( aa(C,$o,Pa,Y2)
                    & ! [Ya2: C] :
                        ( aa(C,$o,Pa,Ya2)
                       => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),Ya2) ) )
                 => ( Y2 = X3 ) ) )
         => aa(C,$o,Pa,ord_Least(C,Pa)) ) ) ).

% Least1I
tff(fact_3719_ord_Olexordp__append__leftI,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Us2: list(C),Vs: list(C),Xs: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Us2),Vs)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Vs)) ) ).

% ord.lexordp_append_leftI
tff(fact_3720_ord_Olexordp__append__leftD,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Xs: list(C),Us2: list(C),Vs: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Vs))
     => ( ! [A5: C] : ~ aa(C,$o,aa(C,fun(C,$o),Less,A5),A5)
       => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Us2),Vs) ) ) ).

% ord.lexordp_append_leftD
tff(fact_3721_ord_Olexordp__into__lexordp__eq,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs),Ys)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp_eq(C,Less),Xs),Ys) ) ).

% ord.lexordp_into_lexordp_eq
tff(fact_3722_Least__le,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Pa: fun(C,$o),K: C] :
          ( aa(C,$o,Pa,K)
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),ord_Least(C,Pa)),K) ) ) ).

% Least_le
tff(fact_3723_not__less__Least,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [K: C,Pa: fun(C,$o)] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),K),ord_Least(C,Pa))
         => ~ aa(C,$o,Pa,K) ) ) ).

% not_less_Least
tff(fact_3724_ord_Olexordp_ONil,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Y: C,Ys: list(C)] : aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),nil(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ).

% ord.lexordp.Nil
tff(fact_3725_ord_Olexordp_Ocases,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),A1: list(C),A22: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),A1),A22)
     => ( ( ( A1 = nil(C) )
         => ! [Y2: C,Ys2: list(C)] : A22 != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
       => ( ! [X2: C] :
              ( ? [Xs2: list(C)] : A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)
             => ! [Y2: C] :
                  ( ? [Ys2: list(C)] : A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)
                 => ~ aa(C,$o,aa(C,fun(C,$o),Less,X2),Y2) ) )
         => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ! [Ys2: list(C)] :
                    ( ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                   => ( ~ aa(C,$o,aa(C,fun(C,$o),Less,X2),Y2)
                     => ( ~ aa(C,$o,aa(C,fun(C,$o),Less,Y2),X2)
                       => ~ aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs2),Ys2) ) ) ) ) ) ) ) ).

% ord.lexordp.cases
tff(fact_3726_ord_Olexordp_Osimps,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),A1: list(C),A22: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),A1),A22)
    <=> ( ? [Y3: C,Ys3: list(C)] :
            ( ( A1 = nil(C) )
            & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) ) )
        | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
            ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
            & aa(C,$o,aa(C,fun(C,$o),Less,X4),Y3) )
        | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
            ( ( A1 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
            & ~ aa(C,$o,aa(C,fun(C,$o),Less,X4),Y3)
            & ~ aa(C,$o,aa(C,fun(C,$o),Less,Y3),X4)
            & aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs3),Ys3) ) ) ) ).

% ord.lexordp.simps
tff(fact_3727_ord_Olexordp__append__left__rightI,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),X: C,Y: C,Us2: list(C),Xs: list(C),Ys: list(C)] :
      ( aa(C,$o,aa(C,fun(C,$o),Less,X),Y)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))) ) ).

% ord.lexordp_append_left_rightI
tff(fact_3728_ord_Olexordp__append__rightI,axiom,
    ! [C: $tType,Ys: list(C),Less: fun(C,fun(C,$o)),Xs: list(C)] :
      ( ( Ys != nil(C) )
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),lexordp2(C,Less),Xs),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) ) ).

% ord.lexordp_append_rightI
tff(fact_3729_hd__def,axiom,
    ! [C: $tType,List: list(C)] : aa(list(C),C,hd(C),List) = aa(list(C),C,aa(fun(C,fun(list(C),C)),fun(list(C),C),aa(C,fun(fun(C,fun(list(C),C)),fun(list(C),C)),case_list(C,C),undefined(C)),aTP_Lamp_ke(C,fun(list(C),C))),List) ).

% hd_def
tff(fact_3730_Bleast__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [S: set(C),Pa: fun(C,$o)] : bleast(C,S,Pa) = ord_Least(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_kf(set(C),fun(fun(C,$o),fun(C,$o)),S),Pa)) ) ).

% Bleast_def
tff(fact_3731_abort__Bleast__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [S: set(C),Pa: fun(C,$o)] : abort_Bleast(C,S,Pa) = ord_Least(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_kf(set(C),fun(fun(C,$o),fun(C,$o)),S),Pa)) ) ).

% abort_Bleast_def
tff(fact_3732_zipf_Oelims,axiom,
    ! [E2: $tType,D: $tType,C: $tType,X: fun(D,fun(E2,C)),Xa: list(D),Xb: list(E2),Y: list(C)] :
      ( ( zipf(D,E2,C,X,Xa,Xb) = Y )
     => ( ( ( Xa = nil(D) )
         => ( ( Xb = nil(E2) )
           => ( Y != nil(C) ) ) )
       => ( ! [A5: D,As: list(D)] :
              ( ( Xa = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),As) )
             => ! [B4: E2,Bs2: list(E2)] :
                  ( ( Xb = aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),B4),Bs2) )
                 => ( Y != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(E2,C,aa(D,fun(E2,C),X,A5),B4)),zipf(D,E2,C,X,As,Bs2)) ) ) )
         => ( ( ? [V2: D,Va2: list(D)] : Xa = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)
             => ( ( Xb = nil(E2) )
               => ( Y != undefined(list(C)) ) ) )
           => ~ ( ( Xa = nil(D) )
               => ( ? [V2: E2,Va2: list(E2)] : Xb = aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),V2),Va2)
                 => ( Y != undefined(list(C)) ) ) ) ) ) ) ) ).

% zipf.elims
tff(fact_3733_arg__min__list_Oelims,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [X: fun(C,D),Xa: list(C),Y: C] :
          ( ( arg_min_list(C,D,X,Xa) = Y )
         => ( ! [X2: C] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
               => ( Y != X2 ) )
           => ( ! [X2: C,Y2: C,Zs3: list(C)] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Zs3)) )
                 => ( Y != $let(
                        m: C,
                        m:= arg_min_list(C,D,X,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Zs3)),
                        $ite(aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,X,X2)),aa(C,D,X,m)),X2,m) ) ) )
             => ~ ( ( Xa = nil(C) )
                 => ( Y != undefined(C) ) ) ) ) ) ) ).

% arg_min_list.elims
tff(fact_3734_min__list_Opelims,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [X: list(C),Y: C] :
          ( ( min_list(C,X) = Y )
         => ( accp(list(C),min_list_rel(C),X)
           => ( ! [X2: C,Xs2: list(C)] :
                  ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                 => ( ( Y = aa(list(C),C,aa(fun(C,fun(list(C),C)),fun(list(C),C),aa(C,fun(fun(C,fun(list(C),C)),fun(list(C),C)),case_list(C,C),X2),aa(list(C),fun(C,fun(list(C),C)),aTP_Lamp_dp(C,fun(list(C),fun(C,fun(list(C),C))),X2),Xs2)),Xs2) )
                   => ~ accp(list(C),min_list_rel(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)) ) )
             => ~ ( ( X = nil(C) )
                 => ( ( Y = undefined(C) )
                   => ~ accp(list(C),min_list_rel(C),nil(C)) ) ) ) ) ) ) ).

% min_list.pelims
tff(fact_3735_zipf_Opelims,axiom,
    ! [C: $tType,D: $tType,E2: $tType,X: fun(D,fun(E2,C)),Xa: list(D),Xb: list(E2),Y: list(C)] :
      ( ( zipf(D,E2,C,X,Xa,Xb) = Y )
     => ( accp(product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),zipf_rel(D,E2,C),aa(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),aa(fun(D,fun(E2,C)),fun(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2)))),product_Pair(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),X),aa(list(E2),product_prod(list(D),list(E2)),aa(list(D),fun(list(E2),product_prod(list(D),list(E2))),product_Pair(list(D),list(E2)),Xa),Xb)))
       => ( ( ( Xa = nil(D) )
           => ( ( Xb = nil(E2) )
             => ( ( Y = nil(C) )
               => ~ accp(product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),zipf_rel(D,E2,C),aa(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),aa(fun(D,fun(E2,C)),fun(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2)))),product_Pair(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),X),aa(list(E2),product_prod(list(D),list(E2)),aa(list(D),fun(list(E2),product_prod(list(D),list(E2))),product_Pair(list(D),list(E2)),nil(D)),nil(E2)))) ) ) )
         => ( ! [A5: D,As: list(D)] :
                ( ( Xa = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),As) )
               => ! [B4: E2,Bs2: list(E2)] :
                    ( ( Xb = aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),B4),Bs2) )
                   => ( ( Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(E2,C,aa(D,fun(E2,C),X,A5),B4)),zipf(D,E2,C,X,As,Bs2)) )
                     => ~ accp(product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),zipf_rel(D,E2,C),aa(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),aa(fun(D,fun(E2,C)),fun(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2)))),product_Pair(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),X),aa(list(E2),product_prod(list(D),list(E2)),aa(list(D),fun(list(E2),product_prod(list(D),list(E2))),product_Pair(list(D),list(E2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A5),As)),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),B4),Bs2)))) ) ) )
           => ( ! [V2: D,Va2: list(D)] :
                  ( ( Xa = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2) )
                 => ( ( Xb = nil(E2) )
                   => ( ( Y = undefined(list(C)) )
                     => ~ accp(product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),zipf_rel(D,E2,C),aa(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),aa(fun(D,fun(E2,C)),fun(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2)))),product_Pair(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),X),aa(list(E2),product_prod(list(D),list(E2)),aa(list(D),fun(list(E2),product_prod(list(D),list(E2))),product_Pair(list(D),list(E2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)),nil(E2)))) ) ) )
             => ~ ( ( Xa = nil(D) )
                 => ! [V2: E2,Va2: list(E2)] :
                      ( ( Xb = aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),V2),Va2) )
                     => ( ( Y = undefined(list(C)) )
                       => ~ accp(product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),zipf_rel(D,E2,C),aa(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),aa(fun(D,fun(E2,C)),fun(product_prod(list(D),list(E2)),product_prod(fun(D,fun(E2,C)),product_prod(list(D),list(E2)))),product_Pair(fun(D,fun(E2,C)),product_prod(list(D),list(E2))),X),aa(list(E2),product_prod(list(D),list(E2)),aa(list(D),fun(list(E2),product_prod(list(D),list(E2))),product_Pair(list(D),list(E2)),nil(D)),aa(list(E2),list(E2),aa(E2,fun(list(E2),list(E2)),cons(E2),V2),Va2)))) ) ) ) ) ) ) ) ) ).

% zipf.pelims
tff(fact_3736_filter__rev__alt,axiom,
    ! [C: $tType,Pa: fun(C,$o),La: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter_rev(C),Pa),La) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),rev(C),La)) ).

% filter_rev_alt
tff(fact_3737_filter__rev__aux__alt,axiom,
    ! [C: $tType,A3: list(C),Pa: fun(C,$o),La: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter_rev_aux(C,A3),Pa),La) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(C),list(C),rev(C),La))),A3) ).

% filter_rev_aux_alt
tff(fact_3738_filter__rev__def,axiom,
    ! [C: $tType] : filter_rev(C) = filter_rev_aux(C,nil(C)) ).

% filter_rev_def
tff(fact_3739_filter__rev__aux_Osimps_I2_J,axiom,
    ! [C: $tType,A3: list(C),Pa: fun(C,$o),X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter_rev_aux(C,A3),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(aa(C,$o,Pa,X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter_rev_aux(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),A3)),Pa),Xs),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter_rev_aux(C,A3),Pa),Xs)) ).

% filter_rev_aux.simps(2)
tff(fact_3740_filter__rev__aux_Osimps_I1_J,axiom,
    ! [C: $tType,A3: list(C),Pa: fun(C,$o)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter_rev_aux(C,A3),Pa),nil(C)) = A3 ).

% filter_rev_aux.simps(1)
tff(fact_3741_precise__extr__pure_I2_J,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,assn)),Pa: $o] :
      ( precise(C,D,aa($o,fun(C,fun(D,assn)),aTP_Lamp_kg(fun(C,fun(D,assn)),fun($o,fun(C,fun(D,assn))),R),(Pa)))
    <=> ( (Pa)
       => precise(C,D,R) ) ) ).

% precise_extr_pure(2)
tff(fact_3742_precise__extr__pure_I1_J,axiom,
    ! [D: $tType,C: $tType,Pa: $o,R: fun(C,fun(D,assn))] :
      ( precise(C,D,aa(fun(C,fun(D,assn)),fun(C,fun(D,assn)),aTP_Lamp_kh($o,fun(fun(C,fun(D,assn)),fun(C,fun(D,assn))),(Pa)),R))
    <=> ( (Pa)
       => precise(C,D,R) ) ) ).

% precise_extr_pure(1)
tff(fact_3743_prod_Oinsert_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [I5: set(C),P3: fun(C,D),I: C] :
          ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_ch(set(C),fun(fun(C,D),fun(C,$o)),I5),P3)))
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),P3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),I),I5)) = $ite(member2(C,I,I5),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),P3),I5),aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,P3,I)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),P3),I5))) ) ) ) ).

% prod.insert'
tff(fact_3744_set__nths,axiom,
    ! [C: $tType,Xs: list(C),I5: set(nat)] : aa(list(C),set(C),set2(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5)) = collect(C,aa(set(nat),fun(C,$o),aTP_Lamp_ki(list(C),fun(set(nat),fun(C,$o)),Xs),I5)) ).

% set_nths
tff(fact_3745_nths__nil,axiom,
    ! [C: $tType,A4: set(nat)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),nil(C)),A4) = nil(C) ).

% nths_nil
tff(fact_3746_nths__empty,axiom,
    ! [C: $tType,Xs: list(C)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),bot_bot(set(nat))) = nil(C) ).

% nths_empty
tff(fact_3747_prod_Oempty_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [P3: fun(D,C)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups1962203154675924110t_prod(D,C),P3),bot_bot(set(D))) = one_one(C) ) ).

% prod.empty'
tff(fact_3748_nths__upt__eq__take,axiom,
    ! [C: $tType,La: list(C),N: nat] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),La),set_ord_lessThan(nat,N)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),La) ).

% nths_upt_eq_take
tff(fact_3749_nths__singleton,axiom,
    ! [C: $tType,X: C,A4: set(nat)] :
      aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))),A4) = $ite(member2(nat,zero_zero(nat),A4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)),nil(C)) ).

% nths_singleton
tff(fact_3750_notin__set__nthsI,axiom,
    ! [C: $tType,X: C,Xs: list(C),I5: set(nat)] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ~ member2(C,X,aa(list(C),set(C),set2(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5))) ) ).

% notin_set_nthsI
tff(fact_3751_in__set__nthsD,axiom,
    ! [C: $tType,X: C,Xs: list(C),I5: set(nat)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% in_set_nthsD
tff(fact_3752_nths__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),I5: set(nat)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)),I5) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(set(nat),list(D),aa(list(D),fun(set(nat),list(D)),nths(D),Xs),I5)) ).

% nths_map
tff(fact_3753_distinct__nthsI,axiom,
    ! [C: $tType,Xs: list(C),I5: set(nat)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5)) ) ).

% distinct_nthsI
tff(fact_3754_prod_Onon__neutral_H,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),I5: set(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups1962203154675924110t_prod(D,C),G),collect(D,aa(set(D),fun(D,$o),aTP_Lamp_kj(fun(D,C),fun(set(D),fun(D,$o)),G),I5))) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups1962203154675924110t_prod(D,C),G),I5) ) ).

% prod.non_neutral'
tff(fact_3755_set__nths__subset,axiom,
    ! [C: $tType,Xs: list(C),I5: set(nat)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5))),aa(list(C),set(C),set2(C),Xs)) ).

% set_nths_subset
tff(fact_3756_nths__all,axiom,
    ! [C: $tType,Xs: list(C),I5: set(nat)] :
      ( ! [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Xs))
         => member2(nat,I3,I5) )
     => ( aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5) = Xs ) ) ).

% nths_all
tff(fact_3757_sorted__nths,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),I5: set(nat)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5)) ) ) ).

% sorted_nths
tff(fact_3758_nths__drop,axiom,
    ! [C: $tType,N: nat,Xs: list(C),I5: set(nat)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)),I5) = aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),aa(set(nat),set(nat),image2(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N)),I5)) ).

% nths_drop
tff(fact_3759_prod_Odistrib__triv_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [I5: set(C),G: fun(C,D),H: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),I5)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),aa(fun(C,D),fun(C,D),aTP_Lamp_kk(fun(C,D),fun(fun(C,D),fun(C,D)),G),H)),I5) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),I5)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),H),I5)) ) ) ) ).

% prod.distrib_triv'
tff(fact_3760_snga__prec,axiom,
    ! [C: $tType] :
      ( heap(C)
     => precise(list(C),array(C),aTP_Lamp_kl(list(C),fun(array(C),assn))) ) ).

% snga_prec
tff(fact_3761_drop__eq__nths,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs) = aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),collect(nat,aa(nat,fun(nat,$o),ord_less_eq(nat),N))) ).

% drop_eq_nths
tff(fact_3762_sngr__prec,axiom,
    ! [C: $tType] :
      ( heap(C)
     => precise(C,ref(C),aTP_Lamp_km(C,fun(ref(C),assn))) ) ).

% sngr_prec
tff(fact_3763_prod_Omono__neutral__left_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),T: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
         => ( ! [X2: C] :
                ( member2(C,X2,minus_minus(set(C),T,S))
               => ( aa(C,D,G,X2) = one_one(D) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),S) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),T) ) ) ) ) ).

% prod.mono_neutral_left'
tff(fact_3764_prod_Omono__neutral__right_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),T: set(C),G: fun(C,D)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
         => ( ! [X2: C] :
                ( member2(C,X2,minus_minus(set(C),T,S))
               => ( aa(C,D,G,X2) = one_one(D) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),T) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),S) ) ) ) ) ).

% prod.mono_neutral_right'
tff(fact_3765_prod_Omono__neutral__cong__left_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),T: set(C),H: fun(C,D),G: fun(C,D)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
         => ( ! [I3: C] :
                ( member2(C,I3,minus_minus(set(C),T,S))
               => ( aa(C,D,H,I3) = one_one(D) ) )
           => ( ! [X2: C] :
                  ( member2(C,X2,S)
                 => ( aa(C,D,G,X2) = aa(C,D,H,X2) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),S) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),H),T) ) ) ) ) ) ).

% prod.mono_neutral_cong_left'
tff(fact_3766_prod_Omono__neutral__cong__right_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S: set(C),T: set(C),G: fun(C,D),H: fun(C,D)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S),T)
         => ( ! [X2: C] :
                ( member2(C,X2,minus_minus(set(C),T,S))
               => ( aa(C,D,G,X2) = one_one(D) ) )
           => ( ! [X2: C] :
                  ( member2(C,X2,S)
                 => ( aa(C,D,G,X2) = aa(C,D,H,X2) ) )
             => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),T) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),H),S) ) ) ) ) ) ).

% prod.mono_neutral_cong_right'
tff(fact_3767_prod_Odistrib_H,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [I5: set(C),G: fun(C,D),H: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_ch(set(C),fun(fun(C,D),fun(C,$o)),I5),G)))
         => ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,D),fun(C,$o),aTP_Lamp_ch(set(C),fun(fun(C,D),fun(C,$o)),I5),H)))
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),aa(fun(C,D),fun(C,D),aTP_Lamp_kk(fun(C,D),fun(fun(C,D),fun(C,D)),G),H)),I5) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),G),I5)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups1962203154675924110t_prod(C,D),H),I5)) ) ) ) ) ).

% prod.distrib'
tff(fact_3768_nths__append,axiom,
    ! [C: $tType,La: list(C),L_a: list(C),A4: set(nat)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),La),L_a)),A4) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),La),A4)),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),L_a),collect(nat,aa(set(nat),fun(nat,$o),aTP_Lamp_kn(list(C),fun(set(nat),fun(nat,$o)),La),A4)))) ).

% nths_append
tff(fact_3769_prod_OG__def,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [P3: fun(D,C),I5: set(D)] :
          aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups1962203154675924110t_prod(D,C),P3),I5) = $ite(aa(set(D),$o,finite_finite2(D),collect(D,aa(set(D),fun(D,$o),aTP_Lamp_kj(fun(D,C),fun(set(D),fun(D,$o)),P3),I5))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),P3),collect(D,aa(set(D),fun(D,$o),aTP_Lamp_kj(fun(D,C),fun(set(D),fun(D,$o)),P3),I5))),one_one(C)) ) ).

% prod.G_def
tff(fact_3770_filter__in__nths,axiom,
    ! [C: $tType,Xs: list(C),S4: set(nat)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(set(nat),fun(C,$o),aTP_Lamp_ko(list(C),fun(set(nat),fun(C,$o)),Xs),S4)),Xs) = aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),S4) ) ) ).

% filter_in_nths
tff(fact_3771_length__nths,axiom,
    ! [C: $tType,Xs: list(C),I5: set(nat)] : aa(list(C),nat,size_size(list(C)),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),I5)) = finite_card(nat,collect(nat,aa(set(nat),fun(nat,$o),aTP_Lamp_kp(list(C),fun(set(nat),fun(nat,$o)),Xs),I5))) ).

% length_nths
tff(fact_3772_filter__eq__nths,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) = aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),collect(nat,aa(list(C),fun(nat,$o),aTP_Lamp_fl(fun(C,$o),fun(list(C),fun(nat,$o)),Pa),Xs))) ).

% filter_eq_nths
tff(fact_3773_nths__Cons,axiom,
    ! [C: $tType,X: C,La: list(C),A4: set(nat)] :
      aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),La)),A4) = aa(list(C),list(C),
        aa(list(C),fun(list(C),list(C)),append(C),
          $ite(member2(nat,zero_zero(nat),A4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)),nil(C))),
        aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),La),collect(nat,aTP_Lamp_kq(set(nat),fun(nat,$o),A4)))) ).

% nths_Cons
tff(fact_3774_sorted__list__of__set__def,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( linord4507533701916653071of_set(C) = linord144544945434240204of_set(C,C,aTP_Lamp_az(C,C)) ) ) ).

% sorted_list_of_set_def
tff(fact_3775_enumerate__replicate__eq,axiom,
    ! [C: $tType,N: nat,M2: nat,A3: C] : enumerate(C,N,aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),M2),A3)) = aa(list(nat),list(product_prod(nat,C)),aa(fun(nat,product_prod(nat,C)),fun(list(nat),list(product_prod(nat,C))),map(nat,product_prod(nat,C)),aTP_Lamp_kr(C,fun(nat,product_prod(nat,C)),A3)),upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M2))) ).

% enumerate_replicate_eq
tff(fact_3776_finite__def,axiom,
    ! [C: $tType] : finite_finite2(C) = complete_lattice_lfp(fun(set(C),$o),aTP_Lamp_ks(fun(set(C),$o),fun(set(C),$o))) ).

% finite_def
tff(fact_3777_listrel1__subset__listrel,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),R6: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R3),R6)
     => ( refl_on(C,top_top(set(C)),R6)
       => aa(set(product_prod(list(C),list(C))),$o,aa(set(product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),$o),ord_less_eq(set(product_prod(list(C),list(C)))),listrel1(C,R3)),listrel(C,C,R6)) ) ) ).

% listrel1_subset_listrel
tff(fact_3778_top__apply,axiom,
    ! [D: $tType,C: $tType] :
      ( top(C)
     => ! [X: D] : aa(D,C,top_top(fun(D,C)),X) = top_top(C) ) ).

% top_apply
tff(fact_3779_UNIV__I,axiom,
    ! [C: $tType,X: C] : member2(C,X,top_top(set(C))) ).

% UNIV_I
tff(fact_3780_inf__top__left,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),top_top(C)),X) = X ) ).

% inf_top_left
tff(fact_3781_inf__top__right,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),top_top(C)) = X ) ).

% inf_top_right
tff(fact_3782_inf__eq__top__iff,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = top_top(C) )
        <=> ( ( X = top_top(C) )
            & ( Y = top_top(C) ) ) ) ) ).

% inf_eq_top_iff
tff(fact_3783_top__eq__inf__iff,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [X: C,Y: C] :
          ( ( top_top(C) = aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) )
        <=> ( ( X = top_top(C) )
            & ( Y = top_top(C) ) ) ) ) ).

% top_eq_inf_iff
tff(fact_3784_inf__top_Oeq__neutr__iff,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) = top_top(C) )
        <=> ( ( A3 = top_top(C) )
            & ( B2 = top_top(C) ) ) ) ) ).

% inf_top.eq_neutr_iff
tff(fact_3785_inf__top_Oleft__neutral,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),top_top(C)),A3) = A3 ) ).

% inf_top.left_neutral
tff(fact_3786_inf__top_Oneutr__eq__iff,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [A3: C,B2: C] :
          ( ( top_top(C) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),B2) )
        <=> ( ( A3 = top_top(C) )
            & ( B2 = top_top(C) ) ) ) ) ).

% inf_top.neutr_eq_iff
tff(fact_3787_inf__top_Oright__neutral,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),top_top(C)) = A3 ) ).

% inf_top.right_neutral
tff(fact_3788_boolean__algebra_Odisj__one__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),top_top(C)) = top_top(C) ) ).

% boolean_algebra.disj_one_right
tff(fact_3789_boolean__algebra_Odisj__one__left,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),top_top(C)),X) = top_top(C) ) ).

% boolean_algebra.disj_one_left
tff(fact_3790_sup__top__right,axiom,
    ! [C: $tType] :
      ( bounded_lattice_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),top_top(C)) = top_top(C) ) ).

% sup_top_right
tff(fact_3791_sup__top__left,axiom,
    ! [C: $tType] :
      ( bounded_lattice_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),top_top(C)),X) = top_top(C) ) ).

% sup_top_left
tff(fact_3792_Int__UNIV,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = top_top(set(C)) )
    <=> ( ( A4 = top_top(set(C)) )
        & ( B3 = top_top(set(C)) ) ) ) ).

% Int_UNIV
tff(fact_3793_card__eq__UNIV,axiom,
    ! [C: $tType] :
      ( finite_finite(C)
     => ! [S: set(C)] :
          ( ( finite_card(C,S) = finite_card(C,top_top(set(C))) )
        <=> ( S = top_top(set(C)) ) ) ) ).

% card_eq_UNIV
tff(fact_3794_card__eq__UNIV2,axiom,
    ! [C: $tType] :
      ( finite_finite(C)
     => ! [S: set(C)] :
          ( ( finite_card(C,top_top(set(C))) = finite_card(C,S) )
        <=> ( S = top_top(set(C)) ) ) ) ).

% card_eq_UNIV2
tff(fact_3795_min__top,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),top_top(C)),X) = X ) ).

% min_top
tff(fact_3796_min__top2,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_min(C),X),top_top(C)) = X ) ).

% min_top2
tff(fact_3797_max__top,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),top_top(C)),X) = top_top(C) ) ).

% max_top
tff(fact_3798_max__top2,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),ord_max(C),X),top_top(C)) = top_top(C) ) ).

% max_top2
tff(fact_3799_replicate__eq__replicate,axiom,
    ! [C: $tType,M2: nat,X: C,N: nat,Y: C] :
      ( ( aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),M2),X) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),Y) )
    <=> ( ( M2 = N )
        & ( ( M2 != zero_zero(nat) )
         => ( X = Y ) ) ) ) ).

% replicate_eq_replicate
tff(fact_3800_length__replicate,axiom,
    ! [C: $tType,N: nat,X: C] : aa(list(C),nat,size_size(list(C)),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = N ).

% length_replicate
tff(fact_3801_concat__replicate__trivial,axiom,
    ! [C: $tType,I: nat] : aa(list(list(C)),list(C),concat(C),aa(list(C),list(list(C)),aa(nat,fun(list(C),list(list(C))),replicate(list(C)),I),nil(C))) = nil(C) ).

% concat_replicate_trivial
tff(fact_3802_map__replicate,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),N: nat,X: D] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(D,list(D),aa(nat,fun(D,list(D)),replicate(D),N),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),aa(D,C,F,X)) ).

% map_replicate
tff(fact_3803_Pow__UNIV,axiom,
    ! [C: $tType] : pow(C,top_top(set(C))) = top_top(set(set(C))) ).

% Pow_UNIV
tff(fact_3804_rev__replicate,axiom,
    ! [C: $tType,N: nat,X: C] : aa(list(C),list(C),rev(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X) ).

% rev_replicate
tff(fact_3805_Collect__const,axiom,
    ! [C: $tType,Pa: $o] :
      collect(C,aTP_Lamp_kt($o,fun(C,$o),(Pa))) = $ite((Pa),top_top(set(C)),bot_bot(set(C))) ).

% Collect_const
tff(fact_3806_boolean__algebra_Ocompl__one,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ( aa(C,C,uminus_uminus(C),top_top(C)) = bot_bot(C) ) ) ).

% boolean_algebra.compl_one
tff(fact_3807_boolean__algebra_Ocompl__zero,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ( aa(C,C,uminus_uminus(C),bot_bot(C)) = top_top(C) ) ) ).

% boolean_algebra.compl_zero
tff(fact_3808_sup__compl__top__left1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),X)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y)) = top_top(C) ) ).

% sup_compl_top_left1
tff(fact_3809_sup__compl__top__left2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),X)),Y)) = top_top(C) ) ).

% sup_compl_top_left2
tff(fact_3810_boolean__algebra_Odisj__cancel__left,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),X)),X) = top_top(C) ) ).

% boolean_algebra.disj_cancel_left
tff(fact_3811_boolean__algebra_Odisj__cancel__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),X),aa(C,C,uminus_uminus(C),X)) = top_top(C) ) ).

% boolean_algebra.disj_cancel_right
tff(fact_3812_Diff__UNIV,axiom,
    ! [C: $tType,A4: set(C)] : minus_minus(set(C),A4,top_top(set(C))) = bot_bot(set(C)) ).

% Diff_UNIV
tff(fact_3813_card__ge__UNIV,axiom,
    ! [C: $tType] :
      ( finite_finite(C)
     => ! [S: set(C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(C,top_top(set(C)))),finite_card(C,S))
        <=> ( S = top_top(set(C)) ) ) ) ).

% card_ge_UNIV
tff(fact_3814_inj__map__eq__map,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),Xs: list(C),Ys: list(C)] :
      ( inj_on(C,D,F,top_top(set(C)))
     => ( ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Ys) )
      <=> ( Xs = Ys ) ) ) ).

% inj_map_eq_map
tff(fact_3815_empty__replicate,axiom,
    ! [C: $tType,N: nat,X: C] :
      ( ( nil(C) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X) )
    <=> ( N = zero_zero(nat) ) ) ).

% empty_replicate
tff(fact_3816_replicate__empty,axiom,
    ! [C: $tType,N: nat,X: C] :
      ( ( aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X) = nil(C) )
    <=> ( N = zero_zero(nat) ) ) ).

% replicate_empty
tff(fact_3817_in__set__replicate,axiom,
    ! [C: $tType,X: C,N: nat,Y: C] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),Y)))
    <=> ( ( X = Y )
        & ( N != zero_zero(nat) ) ) ) ).

% in_set_replicate
tff(fact_3818_Bex__set__replicate,axiom,
    ! [C: $tType,N: nat,A3: C,Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),A3)))
          & aa(C,$o,Pa,X4) )
    <=> ( aa(C,$o,Pa,A3)
        & ( N != zero_zero(nat) ) ) ) ).

% Bex_set_replicate
tff(fact_3819_Ball__set__replicate,axiom,
    ! [C: $tType,N: nat,A3: C,Pa: fun(C,$o)] :
      ( ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),A3)))
         => aa(C,$o,Pa,X4) )
    <=> ( aa(C,$o,Pa,A3)
        | ( N = zero_zero(nat) ) ) ) ).

% Ball_set_replicate
tff(fact_3820_Gcd__UNIV,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ( gcd_Gcd(C,top_top(set(C))) = one_one(C) ) ) ).

% Gcd_UNIV
tff(fact_3821_nth__replicate,axiom,
    ! [C: $tType,I: nat,N: nat,X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),N)
     => ( aa(nat,C,nth(C,aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),I) = X ) ) ).

% nth_replicate
tff(fact_3822_hd__replicate,axiom,
    ! [C: $tType,N: nat,X: C] :
      ( ( N != zero_zero(nat) )
     => ( aa(list(C),C,hd(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = X ) ) ).

% hd_replicate
tff(fact_3823_drop__replicate,axiom,
    ! [C: $tType,I: nat,K: nat,X: C] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),I),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),K),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),minus_minus(nat,K,I)),X) ).

% drop_replicate
tff(fact_3824_takeWhile__replicate,axiom,
    ! [C: $tType,Pa: fun(C,$o),N: nat,X: C] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = $ite(aa(C,$o,Pa,X),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X),nil(C)) ).

% takeWhile_replicate
tff(fact_3825_last__replicate,axiom,
    ! [C: $tType,N: nat,X: C] :
      ( ( N != zero_zero(nat) )
     => ( last(C,aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = X ) ) ).

% last_replicate
tff(fact_3826_foldr__replicate,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),N: nat,X: D] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),aa(D,list(D),aa(nat,fun(D,list(D)),replicate(D),N),X)) = compow(fun(C,C),N,aa(D,fun(C,C),F,X)) ).

% foldr_replicate
tff(fact_3827_take__replicate,axiom,
    ! [C: $tType,I: nat,K: nat,X: C] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),I),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),K),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),I),K)),X) ).

% take_replicate
tff(fact_3828_inj__mult__left,axiom,
    ! [C: $tType] :
      ( idom(C)
     => ! [A3: C] :
          ( inj_on(C,C,aa(C,fun(C,C),times_times(C),A3),top_top(set(C)))
        <=> ( A3 != zero_zero(C) ) ) ) ).

% inj_mult_left
tff(fact_3829_tl__replicate,axiom,
    ! [C: $tType,N: nat,X: C] : aa(list(C),list(C),tl(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),minus_minus(nat,N,one_one(nat))),X) ).

% tl_replicate
tff(fact_3830_zip__replicate,axiom,
    ! [C: $tType,D: $tType,I: nat,X: C,J: nat,Y: D] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),I),X)),aa(D,list(D),aa(nat,fun(D,list(D)),replicate(D),J),Y)) = aa(product_prod(C,D),list(product_prod(C,D)),aa(nat,fun(product_prod(C,D),list(product_prod(C,D))),replicate(product_prod(C,D)),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),I),J)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)) ).

% zip_replicate
tff(fact_3831_range__constant,axiom,
    ! [D: $tType,C: $tType,X: C] : aa(set(D),set(C),image2(D,C,aTP_Lamp_cj(C,fun(D,C),X)),top_top(set(D))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ).

% range_constant
tff(fact_3832_inj__mapI,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] :
      ( inj_on(C,D,F,top_top(set(C)))
     => inj_on(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),top_top(set(list(C)))) ) ).

% inj_mapI
tff(fact_3833_inj__map,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] :
      ( inj_on(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),top_top(set(list(C))))
    <=> inj_on(C,D,F,top_top(set(C))) ) ).

% inj_map
tff(fact_3834_set__replicate,axiom,
    ! [C: $tType,N: nat,X: C] :
      ( ( N != zero_zero(nat) )
     => ( aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ) ) ).

% set_replicate
tff(fact_3835_rangeI,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),X: D] : member2(C,aa(D,C,F,X),aa(set(D),set(C),image2(D,C,F),top_top(set(D)))) ).

% rangeI
tff(fact_3836_range__eqI,axiom,
    ! [C: $tType,D: $tType,B2: C,F: fun(D,C),X: D] :
      ( ( B2 = aa(D,C,F,X) )
     => member2(C,B2,aa(set(D),set(C),image2(D,C,F),top_top(set(D)))) ) ).

% range_eqI
tff(fact_3837_Un__UNIV__left,axiom,
    ! [C: $tType,B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),top_top(set(C))),B3) = top_top(set(C)) ).

% Un_UNIV_left
tff(fact_3838_Un__UNIV__right,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),top_top(set(C))) = top_top(set(C)) ).

% Un_UNIV_right
tff(fact_3839_Int__UNIV__left,axiom,
    ! [C: $tType,B3: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),top_top(set(C))),B3) = B3 ).

% Int_UNIV_left
tff(fact_3840_Int__UNIV__right,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),top_top(set(C))) = A4 ).

% Int_UNIV_right
tff(fact_3841_UNIV__eq__I,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ! [X2: C] : member2(C,X2,A4)
     => ( top_top(set(C)) = A4 ) ) ).

% UNIV_eq_I
tff(fact_3842_UNIV__witness,axiom,
    ! [C: $tType] :
    ? [X2: C] : member2(C,X2,top_top(set(C))) ).

% UNIV_witness
tff(fact_3843_append__replicate__commute,axiom,
    ! [C: $tType,N: nat,X: C,K: nat] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),K),X)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),K),X)),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) ).

% append_replicate_commute
tff(fact_3844_insert__UNIV,axiom,
    ! [C: $tType,X: C] : aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),top_top(set(C))) = top_top(set(C)) ).

% insert_UNIV
tff(fact_3845_total__lexord,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( total_on(C,top_top(set(C)),R3)
     => total_on(list(C),top_top(set(list(C))),lexord(C,R3)) ) ).

% total_lexord
tff(fact_3846_subset__UNIV,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),top_top(set(C))) ).

% subset_UNIV
tff(fact_3847_top_Oextremum__strict,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [A3: C] : ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),top_top(C)),A3) ) ).

% top.extremum_strict
tff(fact_3848_top_Onot__eq__extremum,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [A3: C] :
          ( ( A3 != top_top(C) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),top_top(C)) ) ) ).

% top.not_eq_extremum
tff(fact_3849_boolean__algebra_Oconj__one__right,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),inf_inf(C),X),top_top(C)) = X ) ).

% boolean_algebra.conj_one_right
tff(fact_3850_top_Oextremum__uniqueI,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),top_top(C)),A3)
         => ( A3 = top_top(C) ) ) ) ).

% top.extremum_uniqueI
tff(fact_3851_top_Oextremum__unique,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),top_top(C)),A3)
        <=> ( A3 = top_top(C) ) ) ) ).

% top.extremum_unique
tff(fact_3852_top__greatest,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ! [A3: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),top_top(C)) ) ).

% top_greatest
tff(fact_3853_total__lenlex,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( total_on(C,top_top(set(C)),R3)
     => total_on(list(C),top_top(set(list(C))),lenlex(C,R3)) ) ).

% total_lenlex
tff(fact_3854_atLeastAtMost__eq__UNIV__iff,axiom,
    ! [C: $tType] :
      ( bounded_lattice(C)
     => ! [X: C,Y: C] :
          ( ( set_or1337092689740270186AtMost(C,X,Y) = top_top(set(C)) )
        <=> ( ( X = bot_bot(C) )
            & ( Y = top_top(C) ) ) ) ) ).

% atLeastAtMost_eq_UNIV_iff
tff(fact_3855_empty__not__UNIV,axiom,
    ! [C: $tType] : bot_bot(set(C)) != top_top(set(C)) ).

% empty_not_UNIV
tff(fact_3856_UNIV__def,axiom,
    ! [C: $tType] : top_top(set(C)) = collect(C,aTP_Lamp_ku(C,$o)) ).

% UNIV_def
tff(fact_3857_range__composition,axiom,
    ! [C: $tType,E2: $tType,D: $tType,F: fun(E2,C),G: fun(D,E2)] : aa(set(D),set(C),image2(D,C,aa(fun(D,E2),fun(D,C),aTP_Lamp_kv(fun(E2,C),fun(fun(D,E2),fun(D,C)),F),G)),top_top(set(D))) = aa(set(E2),set(C),image2(E2,C,F),aa(set(D),set(E2),image2(D,E2,G),top_top(set(D)))) ).

% range_composition
tff(fact_3858_rangeE,axiom,
    ! [C: $tType,D: $tType,B2: C,F: fun(D,C)] :
      ( member2(C,B2,aa(set(D),set(C),image2(D,C,F),top_top(set(D))))
     => ~ ! [X2: D] : B2 != aa(D,C,F,X2) ) ).

% rangeE
tff(fact_3859_infinite__UNIV__listI,axiom,
    ! [C: $tType] : ~ aa(set(list(C)),$o,finite_finite2(list(C)),top_top(set(list(C)))) ).

% infinite_UNIV_listI
tff(fact_3860_sorted__list__of__set_Oinj__on,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => inj_on(C,C,aTP_Lamp_az(C,C),top_top(set(C))) ) ).

% sorted_list_of_set.inj_on
tff(fact_3861_inj__mapD,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] :
      ( inj_on(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),top_top(set(list(C))))
     => inj_on(C,D,F,top_top(set(C))) ) ).

% inj_mapD
tff(fact_3862_replicate__Suc,axiom,
    ! [C: $tType,N: nat,X: C] : aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(nat,nat,suc,N)),X) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) ).

% replicate_Suc
tff(fact_3863_replicate__0,axiom,
    ! [C: $tType,X: C] : aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),zero_zero(nat)),X) = nil(C) ).

% replicate_0
tff(fact_3864_replicate__app__Cons__same,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),Xs)) ).

% replicate_app_Cons_same
tff(fact_3865_replicate__length__same,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( X2 = X ) )
     => ( aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(C),nat,size_size(list(C)),Xs)),X) = Xs ) ) ).

% replicate_length_same
tff(fact_3866_replicate__eqI,axiom,
    ! [C: $tType,Xs: list(C),N: nat,X: C] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = N )
     => ( ! [Y2: C] :
            ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( Y2 = X ) )
       => ( Xs = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X) ) ) ) ).

% replicate_eqI
tff(fact_3867_sup__cancel__left1,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),A3)),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),X)),B2)) = top_top(C) ) ).

% sup_cancel_left1
tff(fact_3868_sup__cancel__left2,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(C,C,uminus_uminus(C),X)),A3)),aa(C,C,aa(C,fun(C,C),sup_sup(C),X),B2)) = top_top(C) ) ).

% sup_cancel_left2
tff(fact_3869_sorted__replicate,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [N: nat,X: C] : sorted_wrt(C,ord_less_eq(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) ) ).

% sorted_replicate
tff(fact_3870_replicate__add,axiom,
    ! [C: $tType,N: nat,M2: nat,X: C] : aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M2)),X) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),M2),X)) ).

% replicate_add
tff(fact_3871_filter__replicate,axiom,
    ! [C: $tType,Pa: fun(C,$o),N: nat,X: C] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = $ite(aa(C,$o,Pa,X),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X),nil(C)) ).

% filter_replicate
tff(fact_3872_comm__append__are__replicate,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Xs) )
     => ? [M4: nat,N7: nat,Zs3: list(C)] :
          ( ( aa(list(list(C)),list(C),concat(C),aa(list(C),list(list(C)),aa(nat,fun(list(C),list(list(C))),replicate(list(C)),M4),Zs3)) = Xs )
          & ( aa(list(list(C)),list(C),concat(C),aa(list(C),list(list(C)),aa(nat,fun(list(C),list(list(C))),replicate(list(C)),N7),Zs3)) = Ys ) ) ) ).

% comm_append_are_replicate
tff(fact_3873_range__subsetD,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),B3: set(C),I: D] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),image2(D,C,F),top_top(set(D)))),B3)
     => member2(C,aa(D,C,F,I),B3) ) ).

% range_subsetD
tff(fact_3874_map__injective,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D),Ys: list(D)] :
      ( ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Ys) )
     => ( inj_on(D,C,F,top_top(set(D)))
       => ( Xs = Ys ) ) ) ).

% map_injective
tff(fact_3875_Compl__UNIV__eq,axiom,
    ! [C: $tType] : aa(set(C),set(C),uminus_uminus(set(C)),top_top(set(C))) = bot_bot(set(C)) ).

% Compl_UNIV_eq
tff(fact_3876_Compl__empty__eq,axiom,
    ! [C: $tType] : aa(set(C),set(C),uminus_uminus(set(C)),bot_bot(set(C))) = top_top(set(C)) ).

% Compl_empty_eq
tff(fact_3877_Compl__partition,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),uminus_uminus(set(C)),A4)) = top_top(set(C)) ).

% Compl_partition
tff(fact_3878_Compl__partition2,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),A4)),A4) = top_top(set(C)) ).

% Compl_partition2
tff(fact_3879_Compl__eq__Diff__UNIV,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(C),uminus_uminus(set(C)),A4) = minus_minus(set(C),top_top(set(C)),A4) ).

% Compl_eq_Diff_UNIV
tff(fact_3880_map__replicate__const,axiom,
    ! [D: $tType,C: $tType,K: C,Lst: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aTP_Lamp_cj(C,fun(D,C),K)),Lst) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(D),nat,size_size(list(D)),Lst)),K) ).

% map_replicate_const
tff(fact_3881_replicate__length__filter,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),fequal(C),X)),Xs))),X) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),fequal(C),X)),Xs) ).

% replicate_length_filter
tff(fact_3882_UNIV__coset,axiom,
    ! [C: $tType] : top_top(set(C)) = coset(C,nil(C)) ).

% UNIV_coset
tff(fact_3883_full__SetCompr__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C)] : collect(C,aTP_Lamp_kw(fun(D,C),fun(C,$o),F)) = aa(set(D),set(C),image2(D,C,F),top_top(set(D))) ).

% full_SetCompr_eq
tff(fact_3884_finite__Collect,axiom,
    ! [C: $tType,D: $tType,S: set(C),F: fun(D,C)] :
      ( aa(set(C),$o,finite_finite2(C),S)
     => ( inj_on(D,C,F,top_top(set(D)))
       => aa(set(D),$o,finite_finite2(D),collect(D,aa(fun(D,C),fun(D,$o),aTP_Lamp_kx(set(C),fun(fun(D,C),fun(D,$o)),S),F))) ) ) ).

% finite_Collect
tff(fact_3885_sup__shunt,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = top_top(C) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,uminus_uminus(C),X)),Y) ) ) ).

% sup_shunt
tff(fact_3886_replicate__append__same,axiom,
    ! [C: $tType,I: nat,X: C] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),I),X)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),I),X)) ).

% replicate_append_same
tff(fact_3887_boolean__algebra_Ocomplement__unique,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [A3: C,X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),X) = bot_bot(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),X) = top_top(C) )
           => ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),Y) = bot_bot(C) )
             => ( ( aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),Y) = top_top(C) )
               => ( X = Y ) ) ) ) ) ) ).

% boolean_algebra.complement_unique
tff(fact_3888_range__eq__singletonD,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A3: C,X: D] :
      ( ( aa(set(D),set(C),image2(D,C,F),top_top(set(D))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))) )
     => ( aa(D,C,F,X) = A3 ) ) ).

% range_eq_singletonD
tff(fact_3889_image__Int,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C),B3: set(C)] :
      ( inj_on(C,D,F,top_top(set(C)))
     => ( aa(set(C),set(D),image2(C,D,F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),image2(C,D,F),A4)),aa(set(C),set(D),image2(C,D,F),B3)) ) ) ).

% image_Int
tff(fact_3890_lex__def,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : lex(C,R3) = aa(set(set(product_prod(list(C),list(C)))),set(product_prod(list(C),list(C))),complete_Sup_Sup(set(product_prod(list(C),list(C)))),aa(set(nat),set(set(product_prod(list(C),list(C)))),image2(nat,set(product_prod(list(C),list(C))),lexn(C,R3)),top_top(set(nat)))) ).

% lex_def
tff(fact_3891_map__removeAll__inj,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),X: C,Xs: list(C)] :
      ( inj_on(C,D,F,top_top(set(C)))
     => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),removeAll(C),X),Xs)) = aa(list(D),list(D),aa(D,fun(list(D),list(D)),removeAll(D),aa(C,D,F,X)),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) ) ) ).

% map_removeAll_inj
tff(fact_3892_map__replicate__trivial,axiom,
    ! [C: $tType,X: C,I: nat] : aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),aTP_Lamp_ky(C,fun(nat,C),X)),upt(zero_zero(nat),I)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),I),X) ).

% map_replicate_trivial
tff(fact_3893_set__replicate__conv__if,axiom,
    ! [C: $tType,N: nat,X: C] :
      aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = $ite(N = zero_zero(nat),bot_bot(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ).

% set_replicate_conv_if
tff(fact_3894_set__replicate__Suc,axiom,
    ! [C: $tType,N: nat,X: C] : aa(list(C),set(C),set2(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(nat,nat,suc,N)),X)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ).

% set_replicate_Suc
tff(fact_3895_replicate__Suc__conv__snoc,axiom,
    ! [C: $tType,N: nat,X: C] : aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(nat,nat,suc,N)),X) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% replicate_Suc_conv_snoc
tff(fact_3896_sorted__list__of__set_Ofolding__insort__key__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => folding_insort_key(C,C,ord_less_eq(C),ord_less(C),top_top(set(C)),aTP_Lamp_az(C,C)) ) ).

% sorted_list_of_set.folding_insort_key_axioms
tff(fact_3897_boolean__algebra__class_Oboolean__algebra_Ocompl__unique,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => ! [X: C,Y: C] :
          ( ( aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y) = bot_bot(C) )
         => ( ( aa(C,C,aa(C,fun(C,C),sup_sup(C),X),Y) = top_top(C) )
           => ( aa(C,C,uminus_uminus(C),X) = Y ) ) ) ) ).

% boolean_algebra_class.boolean_algebra.compl_unique
tff(fact_3898_inf__top_Osemilattice__neutr__order__axioms,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => semila1105856199041335345_order(C,inf_inf(C),top_top(C),ord_less_eq(C),ord_less(C)) ) ).

% inf_top.semilattice_neutr_order_axioms
tff(fact_3899_zip__replicate1,axiom,
    ! [C: $tType,D: $tType,N: nat,X: C,Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)),Ys) = aa(list(D),list(product_prod(C,D)),aa(fun(D,product_prod(C,D)),fun(list(D),list(product_prod(C,D))),map(D,product_prod(C,D)),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X)),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),N),Ys)) ).

% zip_replicate1
tff(fact_3900_map__zip2,axiom,
    ! [C: $tType,D: $tType,K: C,La: list(D)] : aa(list(D),list(product_prod(C,D)),aa(fun(D,product_prod(C,D)),fun(list(D),list(product_prod(C,D))),map(D,product_prod(C,D)),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),K)),La) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(D),nat,size_size(list(D)),La)),K)),La) ).

% map_zip2
tff(fact_3901_map__zip1,axiom,
    ! [C: $tType,D: $tType,K: D,La: list(C)] : aa(list(C),list(product_prod(C,D)),aa(fun(C,product_prod(C,D)),fun(list(C),list(product_prod(C,D))),map(C,product_prod(C,D)),aa(D,fun(C,product_prod(C,D)),aTP_Lamp_hs(D,fun(C,product_prod(C,D))),K)),La) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),La),aa(D,list(D),aa(nat,fun(D,list(D)),replicate(D),aa(list(C),nat,size_size(list(C)),La)),K)) ).

% map_zip1
tff(fact_3902_zip__replicate2,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),N: nat,Y: D] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(D,list(D),aa(nat,fun(D,list(D)),replicate(D),N),Y)) = aa(list(C),list(product_prod(C,D)),aa(fun(C,product_prod(C,D)),fun(list(C),list(product_prod(C,D))),map(C,product_prod(C,D)),aa(D,fun(C,product_prod(C,D)),aTP_Lamp_hs(D,fun(C,product_prod(C,D))),Y)),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)) ).

% zip_replicate2
tff(fact_3903_Cons__replicate__eq,axiom,
    ! [C: $tType,X: C,Xs: list(C),N: nat,Y: C] :
      ( ( aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),Y) )
    <=> ( ( X = Y )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
        & ( Xs = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),minus_minus(nat,N,one_one(nat))),X) ) ) ) ).

% Cons_replicate_eq
tff(fact_3904_comm__append__is__replicate,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs != nil(C) )
     => ( ( Ys != nil(C) )
       => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),Xs) )
         => ? [N7: nat,Zs3: list(C)] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),N7)
              & ( aa(list(list(C)),list(C),concat(C),aa(list(C),list(list(C)),aa(nat,fun(list(C),list(list(C))),replicate(list(C)),N7),Zs3)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys) ) ) ) ) ) ).

% comm_append_is_replicate
tff(fact_3905_boolean__algebra_Oabstract__boolean__algebra__axioms,axiom,
    ! [C: $tType] :
      ( boolea8198339166811842893lgebra(C)
     => boolea2506097494486148201lgebra(C,inf_inf(C),sup_sup(C),uminus_uminus(C),bot_bot(C),top_top(C)) ) ).

% boolean_algebra.abstract_boolean_algebra_axioms
tff(fact_3906_map__fst__mk__fst,axiom,
    ! [D: $tType,C: $tType,K: C,La: list(D)] : aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),aa(list(D),list(product_prod(C,D)),aa(fun(D,product_prod(C,D)),fun(list(D),list(product_prod(C,D))),map(D,product_prod(C,D)),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),K)),La)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(D),nat,size_size(list(D)),La)),K) ).

% map_fst_mk_fst
tff(fact_3907_sorted__key__list__of__set__def,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D)] : linord144544945434240204of_set(C,D,F) = finite_folding_F(C,list(C),linorder_insort_key(C,D,F),nil(C)) ) ).

% sorted_key_list_of_set_def
tff(fact_3908_map__snd__mk__snd,axiom,
    ! [D: $tType,C: $tType,K: C,La: list(D)] : aa(list(product_prod(D,C)),list(C),aa(fun(product_prod(D,C),C),fun(list(product_prod(D,C)),list(C)),map(product_prod(D,C),C),product_snd(D,C)),aa(list(D),list(product_prod(D,C)),aa(fun(D,product_prod(D,C)),fun(list(D),list(product_prod(D,C))),map(D,product_prod(D,C)),aTP_Lamp_kz(C,fun(D,product_prod(D,C)),K)),La)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(D),nat,size_size(list(D)),La)),K) ).

% map_snd_mk_snd
tff(fact_3909_Id__on__set,axiom,
    ! [C: $tType,Xs: list(C)] : id_on(C,aa(list(C),set(C),set2(C),Xs)) = aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),aa(list(C),list(product_prod(C,C)),aa(fun(C,product_prod(C,C)),fun(list(C),list(product_prod(C,C))),map(C,product_prod(C,C)),aTP_Lamp_cz(C,product_prod(C,C))),Xs)) ).

% Id_on_set
tff(fact_3910_merge__true__star,axiom,
    aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),top_top(assn)),top_top(assn)) = top_top(assn) ).

% merge_true_star
tff(fact_3911_assn__basic__inequalities_I1_J,axiom,
    top_top(assn) != one_one(assn) ).

% assn_basic_inequalities(1)
tff(fact_3912_assn__basic__inequalities_I5_J,axiom,
    top_top(assn) != bot_bot(assn) ).

% assn_basic_inequalities(5)
tff(fact_3913_map__snd__enumerate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(product_prod(nat,C)),list(C),aa(fun(product_prod(nat,C),C),fun(list(product_prod(nat,C)),list(C)),map(product_prod(nat,C),C),product_snd(nat,C)),enumerate(C,N,Xs)) = Xs ).

% map_snd_enumerate
tff(fact_3914_img__fst,axiom,
    ! [D: $tType,C: $tType,A3: C,B2: D,S: set(product_prod(C,D))] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2),S)
     => member2(C,A3,aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),S)) ) ).

% img_fst
tff(fact_3915_img__snd,axiom,
    ! [D: $tType,C: $tType,A3: C,B2: D,S: set(product_prod(C,D))] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2),S)
     => member2(D,B2,aa(set(product_prod(C,D)),set(D),image2(product_prod(C,D),D,product_snd(C,D)),S)) ) ).

% img_snd
tff(fact_3916_Id__on__empty,axiom,
    ! [C: $tType] : id_on(C,bot_bot(set(C))) = bot_bot(set(product_prod(C,C))) ).

% Id_on_empty
tff(fact_3917_map__fst__zip,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = Xs ) ) ).

% map_fst_zip
tff(fact_3918_map__snd__zip,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( aa(list(product_prod(C,D)),list(D),aa(fun(product_prod(C,D),D),fun(list(product_prod(C,D)),list(D)),map(product_prod(C,D),D),product_snd(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = Ys ) ) ).

% map_snd_zip
tff(fact_3919_zip__map__fst__snd,axiom,
    ! [D: $tType,C: $tType,Zs: list(product_prod(C,D))] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Zs)),aa(list(product_prod(C,D)),list(D),aa(fun(product_prod(C,D),D),fun(list(product_prod(C,D)),list(D)),map(product_prod(C,D),D),product_snd(C,D)),Zs)) = Zs ).

% zip_map_fst_snd
tff(fact_3920_map__fst__enumerate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : aa(list(product_prod(nat,C)),list(nat),aa(fun(product_prod(nat,C),nat),fun(list(product_prod(nat,C)),list(nat)),map(product_prod(nat,C),nat),product_fst(nat,C)),enumerate(C,N,Xs)) = upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(C),nat,size_size(list(C)),Xs))) ).

% map_fst_enumerate
tff(fact_3921_sorted__wrt__map__linord,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(C)
     => ! [La: list(product_prod(C,D))] :
          ( sorted_wrt(product_prod(C,D),aTP_Lamp_la(product_prod(C,D),fun(product_prod(C,D),$o)),La)
        <=> sorted_wrt(C,ord_less_eq(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),La)) ) ) ).

% sorted_wrt_map_linord
tff(fact_3922_map__fst__mk__snd,axiom,
    ! [D: $tType,C: $tType,K: D,La: list(C)] : aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),aa(list(C),list(product_prod(C,D)),aa(fun(C,product_prod(C,D)),fun(list(C),list(product_prod(C,D))),map(C,product_prod(C,D)),aa(D,fun(C,product_prod(C,D)),aTP_Lamp_hs(D,fun(C,product_prod(C,D))),K)),La)) = La ).

% map_fst_mk_snd
tff(fact_3923_map__snd__mk__fst,axiom,
    ! [D: $tType,C: $tType,K: D,La: list(C)] : aa(list(product_prod(D,C)),list(C),aa(fun(product_prod(D,C),C),fun(list(product_prod(D,C)),list(C)),map(product_prod(D,C),C),product_snd(D,C)),aa(list(C),list(product_prod(D,C)),aa(fun(C,product_prod(D,C)),fun(list(C),list(product_prod(D,C))),map(C,product_prod(D,C)),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),K)),La)) = La ).

% map_snd_mk_fst
tff(fact_3924_sorted__wrt__map__rev__linord,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(C)
     => ! [La: list(product_prod(C,D))] :
          ( sorted_wrt(product_prod(C,D),aTP_Lamp_lb(product_prod(C,D),fun(product_prod(C,D),$o)),La)
        <=> sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),rev(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),La))) ) ) ).

% sorted_wrt_map_rev_linord
tff(fact_3925_one__div__numeral,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [N: num] : divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),N)) = aa(product_prod(C,C),C,product_fst(C,C),unique8689654367752047608divmod(C,one2,N)) ) ).

% one_div_numeral
tff(fact_3926_one__mod__numeral,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [N: num] : modulo_modulo(C,one_one(C),aa(num,C,numeral_numeral(C),N)) = aa(product_prod(C,C),C,product_snd(C,C),unique8689654367752047608divmod(C,one2,N)) ) ).

% one_mod_numeral
tff(fact_3927_norm__assertion__simps_I12_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),X),top_top(assn)) = top_top(assn) ).

% norm_assertion_simps(12)
tff(fact_3928_norm__assertion__simps_I11_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),top_top(assn)),X) = top_top(assn) ).

% norm_assertion_simps(11)
tff(fact_3929_norm__assertion__simps_I3_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),top_top(assn)),X) = X ).

% norm_assertion_simps(3)
tff(fact_3930_norm__assertion__simps_I4_J,axiom,
    ! [X: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),X),top_top(assn)) = X ).

% norm_assertion_simps(4)
tff(fact_3931_top__set__def,axiom,
    ! [C: $tType] : top_top(set(C)) = collect(C,top_top(fun(C,$o))) ).

% top_set_def
tff(fact_3932_merge__true__star__ctx,axiom,
    ! [Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),top_top(assn)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),top_top(assn)),Pa)) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),top_top(assn)),Pa) ).

% merge_true_star_ctx
tff(fact_3933_fs__contract,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F: fun(C,fun(D,E2)),S: set(E2)] : aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),collect(product_prod(C,D),aa(set(E2),fun(product_prod(C,D),$o),aTP_Lamp_lc(fun(C,fun(D,E2)),fun(set(E2),fun(product_prod(C,D),$o)),F),S))) = collect(C,aa(set(E2),fun(C,$o),aTP_Lamp_ld(fun(C,fun(D,E2)),fun(set(E2),fun(C,$o)),F),S)) ).

% fs_contract
tff(fact_3934_pair__list__eqI,axiom,
    ! [D: $tType,C: $tType,Xs: list(product_prod(C,D)),Ys: list(product_prod(C,D))] :
      ( ( aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs) = aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Ys) )
     => ( ( aa(list(product_prod(C,D)),list(D),aa(fun(product_prod(C,D),D),fun(list(product_prod(C,D)),list(D)),map(product_prod(C,D),D),product_snd(C,D)),Xs) = aa(list(product_prod(C,D)),list(D),aa(fun(product_prod(C,D),D),fun(list(product_prod(C,D)),list(D)),map(product_prod(C,D),D),product_snd(C,D)),Ys) )
       => ( Xs = Ys ) ) ) ).

% pair_list_eqI
tff(fact_3935_All__prod__contract,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,$o))] :
      ( ! [A6: C,X_12: D] : aa(D,$o,aa(C,fun(D,$o),Pa,A6),X_12)
    <=> ! [Z3: product_prod(C,D)] : aa(D,$o,aa(C,fun(D,$o),Pa,aa(product_prod(C,D),C,product_fst(C,D),Z3)),aa(product_prod(C,D),D,product_snd(C,D),Z3)) ) ).

% All_prod_contract
tff(fact_3936_Ex__prod__contract,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,$o))] :
      ( ? [A6: C,X_12: D] : aa(D,$o,aa(C,fun(D,$o),Pa,A6),X_12)
    <=> ? [Z3: product_prod(C,D)] : aa(D,$o,aa(C,fun(D,$o),Pa,aa(product_prod(C,D),C,product_fst(C,D),Z3)),aa(product_prod(C,D),D,product_snd(C,D),Z3)) ) ).

% Ex_prod_contract
tff(fact_3937_sndE,axiom,
    ! [C: $tType,D: $tType,X: product_prod(C,D),A3: C,B2: D,Pa: fun(D,$o)] :
      ( ( X = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2) )
     => ( aa(D,$o,Pa,aa(product_prod(C,D),D,product_snd(C,D),X))
       => aa(D,$o,Pa,B2) ) ) ).

% sndE
tff(fact_3938_fstE,axiom,
    ! [D: $tType,C: $tType,X: product_prod(C,D),A3: C,B2: D,Pa: fun(C,$o)] :
      ( ( X = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2) )
     => ( aa(C,$o,Pa,aa(product_prod(C,D),C,product_fst(C,D),X))
       => aa(C,$o,Pa,A3) ) ) ).

% fstE
tff(fact_3939_nths__shift__lemma__Suc,axiom,
    ! [C: $tType,Pa: fun(nat,$o),Xs: list(C),Is: list(nat)] : aa(list(product_prod(C,nat)),list(C),aa(fun(product_prod(C,nat),C),fun(list(product_prod(C,nat)),list(C)),map(product_prod(C,nat),C),product_fst(C,nat)),aa(list(product_prod(C,nat)),list(product_prod(C,nat)),aa(fun(product_prod(C,nat),$o),fun(list(product_prod(C,nat)),list(product_prod(C,nat))),filter2(product_prod(C,nat)),aTP_Lamp_le(fun(nat,$o),fun(product_prod(C,nat),$o),Pa)),aa(list(nat),list(product_prod(C,nat)),aa(list(C),fun(list(nat),list(product_prod(C,nat))),zip(C,nat),Xs),Is))) = aa(list(product_prod(C,nat)),list(C),aa(fun(product_prod(C,nat),C),fun(list(product_prod(C,nat)),list(C)),map(product_prod(C,nat),C),product_fst(C,nat)),aa(list(product_prod(C,nat)),list(product_prod(C,nat)),aa(fun(product_prod(C,nat),$o),fun(list(product_prod(C,nat)),list(product_prod(C,nat))),filter2(product_prod(C,nat)),aTP_Lamp_lf(fun(nat,$o),fun(product_prod(C,nat),$o),Pa)),aa(list(nat),list(product_prod(C,nat)),aa(list(C),fun(list(nat),list(product_prod(C,nat))),zip(C,nat),Xs),aa(list(nat),list(nat),aa(fun(nat,nat),fun(list(nat),list(nat)),map(nat,nat),suc),Is)))) ).

% nths_shift_lemma_Suc
tff(fact_3940_fn__snd__conv,axiom,
    ! [C: $tType,E2: $tType,D: $tType,F: fun(D,E2)] : aTP_Lamp_lg(fun(D,E2),fun(product_prod(C,D),E2),F) = product_case_prod(C,D,E2,aTP_Lamp_lh(fun(D,E2),fun(C,fun(D,E2)),F)) ).

% fn_snd_conv
tff(fact_3941_zip__eq__conv,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Zs: list(product_prod(C,D))] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( ( aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys) = Zs )
      <=> ( ( aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Zs) = Xs )
          & ( aa(list(product_prod(C,D)),list(D),aa(fun(product_prod(C,D),D),fun(list(product_prod(C,D)),list(D)),map(product_prod(C,D),D),product_snd(C,D)),Zs) = Ys ) ) ) ) ).

% zip_eq_conv
tff(fact_3942_fn__fst__conv,axiom,
    ! [D: $tType,E2: $tType,C: $tType,F: fun(C,E2)] : aTP_Lamp_li(fun(C,E2),fun(product_prod(C,D),E2),F) = product_case_prod(C,D,E2,aTP_Lamp_lj(fun(C,E2),fun(C,fun(D,E2)),F)) ).

% fn_fst_conv
tff(fact_3943_update__zip,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D),I: nat,Xy: product_prod(C,D)] : aa(product_prod(C,D),list(product_prod(C,D)),aa(nat,fun(product_prod(C,D),list(product_prod(C,D))),aa(list(product_prod(C,D)),fun(nat,fun(product_prod(C,D),list(product_prod(C,D)))),list_update(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)),I),Xy) = aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),aa(product_prod(C,D),C,product_fst(C,D),Xy))),aa(D,list(D),aa(nat,fun(D,list(D)),aa(list(D),fun(nat,fun(D,list(D))),list_update(D),Ys),I),aa(product_prod(C,D),D,product_snd(C,D),Xy))) ).

% update_zip
tff(fact_3944_nths__shift__lemma,axiom,
    ! [C: $tType,A4: set(nat),Xs: list(C),I: nat] : aa(list(product_prod(C,nat)),list(C),aa(fun(product_prod(C,nat),C),fun(list(product_prod(C,nat)),list(C)),map(product_prod(C,nat),C),product_fst(C,nat)),aa(list(product_prod(C,nat)),list(product_prod(C,nat)),aa(fun(product_prod(C,nat),$o),fun(list(product_prod(C,nat)),list(product_prod(C,nat))),filter2(product_prod(C,nat)),aTP_Lamp_lk(set(nat),fun(product_prod(C,nat),$o),A4)),aa(list(nat),list(product_prod(C,nat)),aa(list(C),fun(list(nat),list(product_prod(C,nat))),zip(C,nat),Xs),upt(I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),aa(list(C),nat,size_size(list(C)),Xs)))))) = aa(list(product_prod(C,nat)),list(C),aa(fun(product_prod(C,nat),C),fun(list(product_prod(C,nat)),list(C)),map(product_prod(C,nat),C),product_fst(C,nat)),aa(list(product_prod(C,nat)),list(product_prod(C,nat)),aa(fun(product_prod(C,nat),$o),fun(list(product_prod(C,nat)),list(product_prod(C,nat))),filter2(product_prod(C,nat)),aa(nat,fun(product_prod(C,nat),$o),aTP_Lamp_ll(set(nat),fun(nat,fun(product_prod(C,nat),$o)),A4),I)),aa(list(nat),list(product_prod(C,nat)),aa(list(C),fun(list(nat),list(product_prod(C,nat))),zip(C,nat),Xs),upt(zero_zero(nat),aa(list(C),nat,size_size(list(C)),Xs))))) ).

% nths_shift_lemma
tff(fact_3945_in__snd__imageE,axiom,
    ! [C: $tType,D: $tType,Y: C,S: set(product_prod(D,C))] :
      ( member2(C,Y,aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),S))
     => ~ ! [X2: D] : ~ member2(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),X2),Y),S) ) ).

% in_snd_imageE
tff(fact_3946_in__fst__imageE,axiom,
    ! [D: $tType,C: $tType,X: C,S: set(product_prod(C,D))] :
      ( member2(C,X,aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),S))
     => ~ ! [Y2: D] : ~ member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y2),S) ) ).

% in_fst_imageE
tff(fact_3947_nths__def,axiom,
    ! [C: $tType,Xs: list(C),A4: set(nat)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),A4) = aa(list(product_prod(C,nat)),list(C),aa(fun(product_prod(C,nat),C),fun(list(product_prod(C,nat)),list(C)),map(product_prod(C,nat),C),product_fst(C,nat)),aa(list(product_prod(C,nat)),list(product_prod(C,nat)),aa(fun(product_prod(C,nat),$o),fun(list(product_prod(C,nat)),list(product_prod(C,nat))),filter2(product_prod(C,nat)),aTP_Lamp_lk(set(nat),fun(product_prod(C,nat),$o),A4)),aa(list(nat),list(product_prod(C,nat)),aa(list(C),fun(list(nat),list(product_prod(C,nat))),zip(C,nat),Xs),upt(zero_zero(nat),aa(list(C),nat,size_size(list(C)),Xs))))) ).

% nths_def
tff(fact_3948_distinct__map__fst__filterI,axiom,
    ! [D: $tType,C: $tType,Xs: list(product_prod(C,D)),Pa: fun(product_prod(C,D),$o)] :
      ( aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs))
     => aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(fun(product_prod(C,D),$o),fun(list(product_prod(C,D)),list(product_prod(C,D))),filter2(product_prod(C,D)),Pa),Xs))) ) ).

% distinct_map_fst_filterI
tff(fact_3949_in__set__zip,axiom,
    ! [C: $tType,D: $tType,P3: product_prod(C,D),Xs: list(C),Ys: list(D)] :
      ( member2(product_prod(C,D),P3,aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)))
    <=> ? [N3: nat] :
          ( ( aa(nat,C,nth(C,Xs),N3) = aa(product_prod(C,D),C,product_fst(C,D),P3) )
          & ( aa(nat,D,nth(D,Ys),N3) = aa(product_prod(C,D),D,product_snd(C,D),P3) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(C),nat,size_size(list(C)),Xs))
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(D),nat,size_size(list(D)),Ys)) ) ) ).

% in_set_zip
tff(fact_3950_entails__solve__finalize_I1_J,axiom,
    ! [M: list(product_prod(assn,assn)),Pa: assn] : fI_RESULT(M,Pa,one_one(assn),top_top(assn)) ).

% entails_solve_finalize(1)
tff(fact_3951_snd__image__mp,axiom,
    ! [D: $tType,C: $tType,A4: set(product_prod(D,C)),B3: set(C),X: D,Y: C] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),A4)),B3)
     => ( member2(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),X),Y),A4)
       => member2(C,Y,B3) ) ) ).

% snd_image_mp
tff(fact_3952_fst__image__mp,axiom,
    ! [D: $tType,C: $tType,A4: set(product_prod(C,D)),B3: set(C),X: C,Y: D] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),A4)),B3)
     => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),A4)
       => member2(C,X,B3) ) ) ).

% fst_image_mp
tff(fact_3953_snd__in__Field,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(product_prod(C,C)),set(C),image2(product_prod(C,C),C,product_snd(C,C)),R)),field2(C,R)) ).

% snd_in_Field
tff(fact_3954_fst__in__Field,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(product_prod(C,C)),set(C),image2(product_prod(C,C),C,product_fst(C,C)),R)),field2(C,R)) ).

% fst_in_Field
tff(fact_3955_in__set__enumerate__eq,axiom,
    ! [C: $tType,P3: product_prod(nat,C),N: nat,Xs: list(C)] :
      ( member2(product_prod(nat,C),P3,aa(list(product_prod(nat,C)),set(product_prod(nat,C)),set2(product_prod(nat,C)),enumerate(C,N,Xs)))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(product_prod(nat,C),nat,product_fst(nat,C),P3))
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(product_prod(nat,C),nat,product_fst(nat,C),P3)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs)),N))
        & ( aa(nat,C,nth(C,Xs),minus_minus(nat,aa(product_prod(nat,C),nat,product_fst(nat,C),P3),N)) = aa(product_prod(nat,C),C,product_snd(nat,C),P3) ) ) ) ).

% in_set_enumerate_eq
tff(fact_3956_sorted__enumerate,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : sorted_wrt(nat,ord_less_eq(nat),aa(list(product_prod(nat,C)),list(nat),aa(fun(product_prod(nat,C),nat),fun(list(product_prod(nat,C)),list(nat)),map(product_prod(nat,C),nat),product_fst(nat,C)),enumerate(C,N,Xs))) ).

% sorted_enumerate
tff(fact_3957_fst__foldl,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(C,fun(E2,C)),G: fun(C,fun(D,fun(E2,D))),A3: C,B2: D,Xs: list(E2)] : aa(product_prod(C,D),C,product_fst(C,D),aa(list(E2),product_prod(C,D),aa(product_prod(C,D),fun(list(E2),product_prod(C,D)),aa(fun(product_prod(C,D),fun(E2,product_prod(C,D))),fun(product_prod(C,D),fun(list(E2),product_prod(C,D))),foldl(product_prod(C,D),E2),product_case_prod(C,D,fun(E2,product_prod(C,D)),aa(fun(C,fun(D,fun(E2,D))),fun(C,fun(D,fun(E2,product_prod(C,D)))),aTP_Lamp_lm(fun(C,fun(E2,C)),fun(fun(C,fun(D,fun(E2,D))),fun(C,fun(D,fun(E2,product_prod(C,D))))),F),G))),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2)),Xs)) = aa(list(E2),C,aa(C,fun(list(E2),C),aa(fun(C,fun(E2,C)),fun(C,fun(list(E2),C)),foldl(C,E2),F),A3),Xs) ).

% fst_foldl
tff(fact_3958_distinct__map__fstD,axiom,
    ! [C: $tType,D: $tType,Xs: list(product_prod(C,D)),X: C,Y: D,Z2: D] :
      ( aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs))
     => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),Xs))
       => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Z2),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),Xs))
         => ( Y = Z2 ) ) ) ) ).

% distinct_map_fstD
tff(fact_3959_map__snd__zip__take,axiom,
    ! [D: $tType,C: $tType,Xs: list(D),Ys: list(C)] : aa(list(product_prod(D,C)),list(C),aa(fun(product_prod(D,C),C),fun(list(product_prod(D,C)),list(C)),map(product_prod(D,C),C),product_snd(D,C)),aa(list(C),list(product_prod(D,C)),aa(list(D),fun(list(C),list(product_prod(D,C))),zip(D,C),Xs),Ys)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(D),nat,size_size(list(D)),Xs)),aa(list(C),nat,size_size(list(C)),Ys))),Ys) ).

% map_snd_zip_take
tff(fact_3960_map__fst__zip__take,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(D),nat,size_size(list(D)),Ys))),Xs) ).

% map_fst_zip_take
tff(fact_3961_mergesort__by__rel__split__length,axiom,
    ! [C: $tType,Xs1: list(C),Xs23: list(C),Xs: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),Xs))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs1)),divide_divide(nat,aa(list(C),nat,size_size(list(C)),Xs),aa(num,nat,numeral_numeral(nat),bit0(one2))))),modulo_modulo(nat,aa(list(C),nat,size_size(list(C)),Xs),aa(num,nat,numeral_numeral(nat),bit0(one2)))) )
      & ( aa(list(C),nat,size_size(list(C)),aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),Xs))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs23)),divide_divide(nat,aa(list(C),nat,size_size(list(C)),Xs),aa(num,nat,numeral_numeral(nat),bit0(one2)))) ) ) ).

% mergesort_by_rel_split_length
tff(fact_3962_folding__on_Oremove,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,fun(D,D)),A4: set(C),X: C,Z2: D] :
      ( finite_folding_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),S)
       => ( aa(set(C),$o,finite_finite2(C),A4)
         => ( member2(C,X,A4)
           => ( aa(set(C),D,finite_folding_F(C,D,F,Z2),A4) = aa(D,D,aa(C,fun(D,D),F,X),aa(set(C),D,finite_folding_F(C,D,F,Z2),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ) ).

% folding_on.remove
tff(fact_3963_folding__on_Oinsert__remove,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,fun(D,D)),X: C,A4: set(C),Z2: D] :
      ( finite_folding_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)),S)
       => ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),D,finite_folding_F(C,D,F,Z2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(D,D,aa(C,fun(D,D),F,X),aa(set(C),D,finite_folding_F(C,D,F,Z2),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ).

% folding_on.insert_remove
tff(fact_3964_top1I,axiom,
    ! [C: $tType,X: C] : aa(C,$o,top_top(fun(C,$o)),X) ).

% top1I
tff(fact_3965_mergesort__by__rel__split_Osimps_I3_J,axiom,
    ! [C: $tType,Xs1: list(C),Xs23: list(C),X12: C,X24: C,Xs: list(C)] : merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),Xs))) = merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),Xs1)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),Xs23)),Xs) ).

% mergesort_by_rel_split.simps(3)
tff(fact_3966_mergesort__by__rel__split_Osimps_I1_J,axiom,
    ! [C: $tType,Xs1: list(C),Xs23: list(C)] : merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),nil(C)) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23) ).

% mergesort_by_rel_split.simps(1)
tff(fact_3967_folding__on_Oempty,axiom,
    ! [C: $tType,D: $tType,S: set(C),F: fun(C,fun(D,D)),Z2: D] :
      ( finite_folding_on(C,D,S,F)
     => ( aa(set(C),D,finite_folding_F(C,D,F,Z2),bot_bot(set(C))) = Z2 ) ) ).

% folding_on.empty
tff(fact_3968_sorted__list__of__set_Ofold__insort__key_Ofolding__on__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => finite_folding_on(C,list(C),top_top(set(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C))) ) ).

% sorted_list_of_set.fold_insort_key.folding_on_axioms
tff(fact_3969_mergesort__by__rel__split_Oelims,axiom,
    ! [C: $tType,X: product_prod(list(C),list(C)),Xa: list(C),Y: product_prod(list(C),list(C))] :
      ( ( merges295452479951948502_split(C,X,Xa) = Y )
     => ( ! [Xs12: list(C),Xs22: list(C)] :
            ( ( X = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
           => ( ( Xa = nil(C) )
             => ( Y != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) ) ) )
       => ( ! [Xs12: list(C),Xs22: list(C)] :
              ( ( X = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
             => ! [X2: C] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
                 => ( Y != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs12)),Xs22) ) ) )
         => ~ ! [Xs12: list(C),Xs22: list(C)] :
                ( ( X = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
               => ! [X1: C,X23: C,Xs2: list(C)] :
                    ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs2)) )
                   => ( Y != merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),Xs12)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs22)),Xs2) ) ) ) ) ) ) ).

% mergesort_by_rel_split.elims
tff(fact_3970_mergesort__by__rel__split_Osimps_I2_J,axiom,
    ! [C: $tType,Xs1: list(C),Xs23: list(C),X: C] : merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs1)),Xs23) ).

% mergesort_by_rel_split.simps(2)
tff(fact_3971_mergesort__by__rel_Osimps,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] :
      aa(list(C),list(C),mergesort_by_rel(C,R),Xs) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(num,nat,numeral_numeral(nat),bit0(one2))),Xs,merges9089515139780605204_merge(C,R,aa(list(C),list(C),mergesort_by_rel(C,R),aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs))),aa(list(C),list(C),mergesort_by_rel(C,R),aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs))))) ).

% mergesort_by_rel.simps
tff(fact_3972_mergesort__by__rel_Oelims,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),mergesort_by_rel(C,X),Xa) = Y )
     => ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xa)),aa(num,nat,numeral_numeral(nat),bit0(one2))),Xa,merges9089515139780605204_merge(C,X,aa(list(C),list(C),mergesort_by_rel(C,X),aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xa))),aa(list(C),list(C),mergesort_by_rel(C,X),aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xa))))) ) ) ).

% mergesort_by_rel.elims
tff(fact_3973_mergesort__by__rel__simps_I3_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),X12: C,X24: C,Xs: list(C)] : aa(list(C),list(C),mergesort_by_rel(C,R),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),Xs))) = aa(product_prod(list(C),list(C)),list(C),product_case_prod(list(C),list(C),list(C),aTP_Lamp_ln(fun(C,fun(C,$o)),fun(list(C),fun(list(C),list(C))),R)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X12),nil(C))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X24),nil(C))),Xs)) ).

% mergesort_by_rel_simps(3)
tff(fact_3974_set__relcomp,axiom,
    ! [D: $tType,E2: $tType,C: $tType,Xys: list(product_prod(C,E2)),Yzs: list(product_prod(E2,D))] : relcomp(C,E2,D,aa(list(product_prod(C,E2)),set(product_prod(C,E2)),set2(product_prod(C,E2)),Xys),aa(list(product_prod(E2,D)),set(product_prod(E2,D)),set2(product_prod(E2,D)),Yzs)) = aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(list(product_prod(C,D))),list(product_prod(C,D)),concat(product_prod(C,D)),aa(list(product_prod(C,E2)),list(list(product_prod(C,D))),aa(fun(product_prod(C,E2),list(product_prod(C,D))),fun(list(product_prod(C,E2)),list(list(product_prod(C,D)))),map(product_prod(C,E2),list(product_prod(C,D))),aTP_Lamp_lp(list(product_prod(E2,D)),fun(product_prod(C,E2),list(product_prod(C,D))),Yzs)),Xys))) ).

% set_relcomp
tff(fact_3975_mergesort__by__rel__merge__simps_I3_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Ys: list(C)] : merges9089515139780605204_merge(C,R,nil(C),Ys) = Ys ).

% mergesort_by_rel_merge_simps(3)
tff(fact_3976_sorted__wrt__mergesort__by__rel__merge,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( ! [X2: C,Y2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
          | aa(C,$o,aa(C,fun(C,$o),R,Y2),X2) )
     => ( ! [X2: C,Y2: C,Z4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
           => ( aa(C,$o,aa(C,fun(C,$o),R,Y2),Z4)
             => aa(C,$o,aa(C,fun(C,$o),R,X2),Z4) ) )
       => ( sorted_wrt(C,R,merges9089515139780605204_merge(C,R,Xs,Ys))
        <=> ( sorted_wrt(C,R,Xs)
            & sorted_wrt(C,R,Ys) ) ) ) ) ).

% sorted_wrt_mergesort_by_rel_merge
tff(fact_3977_set__mergesort__by__rel__merge,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] : aa(list(C),set(C),set2(C),merges9089515139780605204_merge(C,R,Xs,Ys)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),aa(list(C),set(C),set2(C),Ys)) ).

% set_mergesort_by_rel_merge
tff(fact_3978_mergesort__by__rel__merge__simps_I1_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),X: C,Xs: list(C),Y: C,Ys: list(C)] :
      merges9089515139780605204_merge(C,R,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) = $ite(aa(C,$o,aa(C,fun(C,$o),R,X),Y),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),merges9089515139780605204_merge(C,R,Xs,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),merges9089515139780605204_merge(C,R,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),Ys))) ).

% mergesort_by_rel_merge_simps(1)
tff(fact_3979_mergesort__by__rel__merge__simps_I2_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] : merges9089515139780605204_merge(C,R,Xs,nil(C)) = Xs ).

% mergesort_by_rel_merge_simps(2)
tff(fact_3980_mergesort__by__rel__merge_Osimps_I3_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),V: C,Va: list(C)] : merges9089515139780605204_merge(C,R,nil(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va) ).

% mergesort_by_rel_merge.simps(3)
tff(fact_3981_mergesort__by__rel__merge_Oelims,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Xb: list(C),Y: list(C)] :
      ( ( merges9089515139780605204_merge(C,X,Xa,Xb) = Y )
     => ( ! [X2: C,Xs2: list(C)] :
            ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
           => ! [Y2: C,Ys2: list(C)] :
                ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
               => ( Y != $ite(aa(C,$o,aa(C,fun(C,$o),X,X2),Y2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),merges9089515139780605204_merge(C,X,Xs2,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),merges9089515139780605204_merge(C,X,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2),Ys2))) ) ) )
       => ( ( ( Xb = nil(C) )
           => ( Y != Xa ) )
         => ~ ( ( Xa = nil(C) )
             => ! [V2: C,Va2: list(C)] :
                  ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                 => ( Y != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) ) ) ) ) ) ) ).

% mergesort_by_rel_merge.elims
tff(fact_3982_trancl__Int__subset,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),S4: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R3),S4)
     => ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),relcomp(C,C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),transitive_trancl(C,R3)),S4),R3)),S4)
       => aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),transitive_trancl(C,R3)),S4) ) ) ).

% trancl_Int_subset
tff(fact_3983_mergesort__by__rel__merge_Opelims,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Xb: list(C),Y: list(C)] :
      ( ( merges9089515139780605204_merge(C,X,Xa,Xb) = Y )
     => ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),merges2244889521215249637ge_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xa),Xb)))
       => ( ! [X2: C,Xs2: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
             => ! [Y2: C,Ys2: list(C)] :
                  ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                 => ( ( Y = $ite(aa(C,$o,aa(C,fun(C,$o),X,X2),Y2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),merges9089515139780605204_merge(C,X,Xs2,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),merges9089515139780605204_merge(C,X,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2),Ys2))) )
                   => ~ accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),merges2244889521215249637ge_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)))) ) ) )
         => ( ( ( Xb = nil(C) )
             => ( ( Y = Xa )
               => ~ accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),merges2244889521215249637ge_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xa),nil(C)))) ) )
           => ~ ( ( Xa = nil(C) )
               => ! [V2: C,Va2: list(C)] :
                    ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                   => ( ( Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                     => ~ accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),merges2244889521215249637ge_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)))) ) ) ) ) ) ) ) ).

% mergesort_by_rel_merge.pelims
tff(fact_3984_mergesort__by__rel_Opsimps,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] :
      ( accp(product_prod(fun(C,fun(C,$o)),list(C)),mergesort_by_rel_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),R),Xs))
     => ( aa(list(C),list(C),mergesort_by_rel(C,R),Xs) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(num,nat,numeral_numeral(nat),bit0(one2))),Xs,merges9089515139780605204_merge(C,R,aa(list(C),list(C),mergesort_by_rel(C,R),aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs))),aa(list(C),list(C),mergesort_by_rel(C,R),aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs))))) ) ) ).

% mergesort_by_rel.psimps
tff(fact_3985_mergesort__by__rel_Opelims,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),mergesort_by_rel(C,X),Xa) = Y )
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),mergesort_by_rel_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ~ ( ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xa)),aa(num,nat,numeral_numeral(nat),bit0(one2))),Xa,merges9089515139780605204_merge(C,X,aa(list(C),list(C),mergesort_by_rel(C,X),aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xa))),aa(list(C),list(C),mergesort_by_rel(C,X),aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xa))))) )
           => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),mergesort_by_rel_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa)) ) ) ) ).

% mergesort_by_rel.pelims
tff(fact_3986_mergesort__by__rel_Opinduct,axiom,
    ! [C: $tType,A0: fun(C,fun(C,$o)),A1: list(C),Pa: fun(fun(C,fun(C,$o)),fun(list(C),$o))] :
      ( accp(product_prod(fun(C,fun(C,$o)),list(C)),mergesort_by_rel_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),A0),A1))
     => ( ! [R4: fun(C,fun(C,$o)),Xs2: list(C)] :
            ( accp(product_prod(fun(C,fun(C,$o)),list(C)),mergesort_by_rel_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),R4),Xs2))
           => ( ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xs2)),aa(num,nat,numeral_numeral(nat),bit0(one2)))
               => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),Pa,R4),aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs2))) )
             => ( ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xs2)),aa(num,nat,numeral_numeral(nat),bit0(one2)))
                 => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),Pa,R4),aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs2))) )
               => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),Pa,R4),Xs2) ) ) )
       => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),Pa,A0),A1) ) ) ).

% mergesort_by_rel.pinduct
tff(fact_3987_arg__min__list_Opelims,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [X: fun(C,D),Xa: list(C),Y: C] :
          ( ( arg_min_list(C,D,X,Xa) = Y )
         => ( accp(product_prod(fun(C,D),list(C)),arg_min_list_rel(C,D),aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),X),Xa))
           => ( ! [X2: C] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
                 => ( ( Y = X2 )
                   => ~ accp(product_prod(fun(C,D),list(C)),arg_min_list_rel(C,D),aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))) ) )
             => ( ! [X2: C,Y2: C,Zs3: list(C)] :
                    ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Zs3)) )
                   => ( ( Y = $let(
                            m: C,
                            m:= arg_min_list(C,D,X,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Zs3)),
                            $ite(aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,X,X2)),aa(C,D,X,m)),X2,m) ) )
                     => ~ accp(product_prod(fun(C,D),list(C)),arg_min_list_rel(C,D),aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Zs3)))) ) )
               => ~ ( ( Xa = nil(C) )
                   => ( ( Y = undefined(C) )
                     => ~ accp(product_prod(fun(C,D),list(C)),arg_min_list_rel(C,D),aa(list(C),product_prod(fun(C,D),list(C)),aa(fun(C,D),fun(list(C),product_prod(fun(C,D),list(C))),product_Pair(fun(C,D),list(C)),X),nil(C))) ) ) ) ) ) ) ) ).

% arg_min_list.pelims
tff(fact_3988_sorted__wrt_Opelims_I1_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Y: $o] :
      ( ( sorted_wrt(C,X,Xa)
      <=> (Y) )
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ( ( ( Xa = nil(C) )
           => ( (Y)
             => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),nil(C))) ) )
         => ~ ! [X2: C,Ys2: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2) )
               => ( ( (Y)
                  <=> ( ! [Xa2: C] :
                          ( member2(C,Xa2,aa(list(C),set(C),set2(C),Ys2))
                         => aa(C,$o,aa(C,fun(C,$o),X,X2),Xa2) )
                      & sorted_wrt(C,X,Ys2) ) )
                 => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2))) ) ) ) ) ) ).

% sorted_wrt.pelims(1)
tff(fact_3989_sorted__wrt_Opelims_I2_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( sorted_wrt(C,X,Xa)
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ( ( ( Xa = nil(C) )
           => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),nil(C))) )
         => ~ ! [X2: C,Ys2: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2) )
               => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2)))
                 => ~ ( ! [Xa3: C] :
                          ( member2(C,Xa3,aa(list(C),set(C),set2(C),Ys2))
                         => aa(C,$o,aa(C,fun(C,$o),X,X2),Xa3) )
                      & sorted_wrt(C,X,Ys2) ) ) ) ) ) ) ).

% sorted_wrt.pelims(2)
tff(fact_3990_sorted__wrt_Opelims_I3_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( ~ sorted_wrt(C,X,Xa)
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ~ ! [X2: C,Ys2: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2) )
             => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),sorted_wrt_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ys2)))
               => ( ! [Xa4: C] :
                      ( member2(C,Xa4,aa(list(C),set(C),set2(C),Ys2))
                     => aa(C,$o,aa(C,fun(C,$o),X,X2),Xa4) )
                  & sorted_wrt(C,X,Ys2) ) ) ) ) ) ).

% sorted_wrt.pelims(3)
tff(fact_3991_finite__range__prod,axiom,
    ! [C: $tType,E2: $tType,D: $tType,F: fun(D,product_prod(C,E2))] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(D),set(C),image2(D,C,comp(product_prod(C,E2),C,D,product_fst(C,E2),F)),top_top(set(D))))
     => ( aa(set(E2),$o,finite_finite2(E2),aa(set(D),set(E2),image2(D,E2,comp(product_prod(C,E2),E2,D,product_snd(C,E2),F)),top_top(set(D))))
       => aa(set(product_prod(C,E2)),$o,finite_finite2(product_prod(C,E2)),aa(set(D),set(product_prod(C,E2)),image2(D,product_prod(C,E2),F),top_top(set(D)))) ) ) ).

% finite_range_prod
tff(fact_3992_remdups__adj__singleton__iff,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups_adj(C),Xs)) = aa(nat,nat,suc,zero_zero(nat)) )
    <=> ( ( Xs != nil(C) )
        & ( Xs = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),C,hd(C),Xs)) ) ) ) ).

% remdups_adj_singleton_iff
tff(fact_3993_INT__simps_I4_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_lq(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4)) = $ite(C4 = bot_bot(set(D)),top_top(set(C)),minus_minus(set(C),A4,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4)))) ).

% INT_simps(4)
tff(fact_3994_card__quotient__disjoint,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( inj_on(C,set(set(C)),aTP_Lamp_lr(set(product_prod(C,C)),fun(C,set(set(C))),R3),A4)
       => ( finite_card(set(C),equiv_quotient(C,A4,R3)) = finite_card(C,A4) ) ) ) ).

% card_quotient_disjoint
tff(fact_3995_map__map,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(D,C),G: fun(E2,D),Xs: list(E2)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),G),Xs)) = aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),comp(D,C,E2,F,G)),Xs) ).

% map_map
tff(fact_3996_List_Omap_Ocompositionality,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(D,C),G: fun(E2,D),List: list(E2)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),G),List)) = aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),comp(D,C,E2,F,G)),List) ).

% List.map.compositionality
tff(fact_3997_list_Omap__comp,axiom,
    ! [D: $tType,C: $tType,E2: $tType,G: fun(D,C),F: fun(E2,D),V: list(E2)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),V)) = aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),comp(D,C,E2,G,F)),V) ).

% list.map_comp
tff(fact_3998_List_Omap_Ocomp,axiom,
    ! [D: $tType,E2: $tType,C: $tType,F: fun(E2,D),G: fun(C,E2)] : comp(list(E2),list(D),list(C),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),aa(fun(C,E2),fun(list(C),list(E2)),map(C,E2),G)) = aa(fun(C,D),fun(list(C),list(D)),map(C,D),comp(E2,D,C,F,G)) ).

% List.map.comp
tff(fact_3999_map__comp__map,axiom,
    ! [D: $tType,E2: $tType,C: $tType,F: fun(E2,D),G: fun(C,E2)] : comp(list(E2),list(D),list(C),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),aa(fun(C,E2),fun(list(C),list(E2)),map(C,E2),G)) = aa(fun(C,D),fun(list(C),list(D)),map(C,D),comp(E2,D,C,F,G)) ).

% map_comp_map
tff(fact_4000_remdups__adj__Nil__iff,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( aa(list(C),list(C),remdups_adj(C),Xs) = nil(C) )
    <=> ( Xs = nil(C) ) ) ).

% remdups_adj_Nil_iff
tff(fact_4001_remdups__adj__set,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),remdups_adj(C),Xs)) = aa(list(C),set(C),set2(C),Xs) ).

% remdups_adj_set
tff(fact_4002_remdups__adj__rev,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),remdups_adj(C),Xs)) ).

% remdups_adj_rev
tff(fact_4003_hd__remdups__adj,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),C,hd(C),aa(list(C),list(C),remdups_adj(C),Xs)) = aa(list(C),C,hd(C),Xs) ).

% hd_remdups_adj
tff(fact_4004_last__remdups__adj,axiom,
    ! [C: $tType,Xs: list(C)] : last(C,aa(list(C),list(C),remdups_adj(C),Xs)) = last(C,Xs) ).

% last_remdups_adj
tff(fact_4005_Inf__eq__bot__iff,axiom,
    ! [C: $tType] :
      ( comple5582772986160207858norder(C)
     => ! [A4: set(C)] :
          ( ( aa(set(C),C,complete_Inf_Inf(C),A4) = bot_bot(C) )
        <=> ! [X4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),bot_bot(C)),X4)
             => ? [Xa2: C] :
                  ( member2(C,Xa2,A4)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Xa2),X4) ) ) ) ) ).

% Inf_eq_bot_iff
tff(fact_4006_Inf__empty,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ( aa(set(C),C,complete_Inf_Inf(C),bot_bot(set(C))) = top_top(C) ) ) ).

% Inf_empty
tff(fact_4007_Inf__UNIV,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ( aa(set(C),C,complete_Inf_Inf(C),top_top(set(C))) = bot_bot(C) ) ) ).

% Inf_UNIV
tff(fact_4008_cInf__singleton,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X: C] : aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = X ) ).

% cInf_singleton
tff(fact_4009_Inf__insert,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A3: C,A4: set(C)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Inf_Inf(C),A4)) ) ).

% Inf_insert
tff(fact_4010_Inf__atMost,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [X: C] : aa(set(C),C,complete_Inf_Inf(C),set_ord_atMost(C,X)) = bot_bot(C) ) ).

% Inf_atMost
tff(fact_4011_remdups__adj__Cons__alt,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),tl(C),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)))) = aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) ).

% remdups_adj_Cons_alt
tff(fact_4012_INF__const,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),F: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,aTP_Lamp_ah(D,fun(C,D),F)),A4)) = F ) ) ) ).

% INF_const
tff(fact_4013_cINF__const,axiom,
    ! [C: $tType,D: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),C3: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,aTP_Lamp_ag(D,fun(C,D),C3)),A4)) = C3 ) ) ) ).

% cINF_const
tff(fact_4014_INF__eq__bot__iff,axiom,
    ! [D: $tType,C: $tType] :
      ( comple5582772986160207858norder(C)
     => ! [F: fun(D,C),A4: set(D)] :
          ( ( aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,F),A4)) = bot_bot(C) )
        <=> ! [X4: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),bot_bot(C)),X4)
             => ? [Xa2: D] :
                  ( member2(D,Xa2,A4)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(D,C,F,Xa2)),X4) ) ) ) ) ).

% INF_eq_bot_iff
tff(fact_4015_INT__constant,axiom,
    ! [D: $tType,C: $tType,C3: set(C),A4: set(D)] :
      aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_an(set(C),fun(D,set(C)),C3)),A4)) = $ite(A4 = bot_bot(set(D)),top_top(set(C)),C3) ).

% INT_constant
tff(fact_4016_INT__insert,axiom,
    ! [C: $tType,D: $tType,B3: fun(D,set(C)),A3: D,A4: set(D)] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),A4))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(D,set(C),B3,A3)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),A4))) ).

% INT_insert
tff(fact_4017_Inf__atMostLessThan,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),top_top(C)),X)
         => ( aa(set(C),C,complete_Inf_Inf(C),set_ord_lessThan(C,X)) = bot_bot(C) ) ) ) ).

% Inf_atMostLessThan
tff(fact_4018_INT__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_cu(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4)) = $ite(C4 = bot_bot(set(D)),top_top(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4)))) ).

% INT_simps(2)
tff(fact_4019_INT__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,A4: fun(D,set(C)),B3: set(C),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_cv(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4)) = $ite(C4 = bot_bot(set(D)),top_top(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4))),B3)) ).

% INT_simps(1)
tff(fact_4020_INT__simps_I3_J,axiom,
    ! [D: $tType,C: $tType,A4: fun(D,set(C)),B3: set(C),C4: set(D)] :
      aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_ls(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4)) = $ite(C4 = bot_bot(set(D)),top_top(set(C)),minus_minus(set(C),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4)),B3)) ).

% INT_simps(3)
tff(fact_4021_remdups__adj_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(C),list(C),remdups_adj(C),nil(C)) = nil(C) ).

% remdups_adj.simps(1)
tff(fact_4022_comp__cong__left,axiom,
    ! [D: $tType,C: $tType,E2: $tType,X: fun(C,D),Y: fun(C,D),F: fun(E2,C)] :
      ( ( X = Y )
     => ( comp(C,D,E2,X,F) = comp(C,D,E2,Y,F) ) ) ).

% comp_cong_left
tff(fact_4023_comp__cong__right,axiom,
    ! [E2: $tType,D: $tType,C: $tType,X: fun(C,D),Y: fun(C,D),F: fun(D,E2)] :
      ( ( X = Y )
     => ( comp(D,E2,C,F,X) = comp(D,E2,C,F,Y) ) ) ).

% comp_cong_right
tff(fact_4024_fun__comp__eq__conv,axiom,
    ! [E2: $tType,D: $tType,C: $tType,F: fun(E2,D),G: fun(C,E2),Fg: fun(C,D)] :
      ( ( comp(E2,D,C,F,G) = Fg )
    <=> ! [X4: C] : aa(E2,D,F,aa(C,E2,G,X4)) = aa(C,D,Fg,X4) ) ).

% fun_comp_eq_conv
tff(fact_4025_remdups__adj__distinct,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( aa(list(C),list(C),remdups_adj(C),Xs) = Xs ) ) ).

% remdups_adj_distinct
tff(fact_4026_remdups__adj_Osimps_I3_J,axiom,
    ! [C: $tType,X: C,Y: C,Xs: list(C)] :
      aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs))) = $ite(X = Y,aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)))) ).

% remdups_adj.simps(3)
tff(fact_4027_distinct__adj__remdups__adj,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),$o,distinct_adj(C),aa(list(C),list(C),remdups_adj(C),Xs)) ).

% distinct_adj_remdups_adj
tff(fact_4028_distinct__adj__altdef,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( aa(list(C),$o,distinct_adj(C),Xs)
    <=> ( aa(list(C),list(C),remdups_adj(C),Xs) = Xs ) ) ).

% distinct_adj_altdef
tff(fact_4029_INF__UNIV__bool__expand,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: fun($o,C)] : aa(set(C),C,complete_Inf_Inf(C),aa(set($o),set(C),image2($o,C,A4),top_top(set($o)))) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa($o,C,A4,$true)),aa($o,C,A4,$false)) ) ).

% INF_UNIV_bool_expand
tff(fact_4030_INT__bool__eq,axiom,
    ! [C: $tType,A4: fun($o,set(C))] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set($o),set(set(C)),image2($o,set(C),A4),top_top(set($o)))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa($o,set(C),A4,$true)),aa($o,set(C),A4,$false)) ).

% INT_bool_eq
tff(fact_4031_Inf__less__eq,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C),U: C] :
          ( ! [V2: C] :
              ( member2(C,V2,A4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),V2),U) )
         => ( ( A4 != bot_bot(set(C)) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Inf_Inf(C),A4)),U) ) ) ) ).

% Inf_less_eq
tff(fact_4032_cInf__eq__non__empty,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),A3: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,X5)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),X2) )
           => ( ! [Y2: C] :
                  ( ! [X3: C] :
                      ( member2(C,X3,X5)
                     => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),X3) )
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),A3) )
             => ( aa(set(C),C,complete_Inf_Inf(C),X5) = A3 ) ) ) ) ) ).

% cInf_eq_non_empty
tff(fact_4033_cInf__greatest,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),Z2: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,X5)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),X2) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Z2),aa(set(C),C,complete_Inf_Inf(C),X5)) ) ) ) ).

% cInf_greatest
tff(fact_4034_cInf__lessD,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C),Z2: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(set(C),C,complete_Inf_Inf(C),X5)),Z2)
           => ? [X2: C] :
                ( member2(C,X2,X5)
                & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X2),Z2) ) ) ) ) ).

% cInf_lessD
tff(fact_4035_INF__eq__const,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [I5: set(C),F: fun(C,D),X: D] :
          ( ( I5 != bot_bot(set(C)) )
         => ( ! [I3: C] :
                ( member2(C,I3,I5)
               => ( aa(C,D,F,I3) = X ) )
           => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),I5)) = X ) ) ) ) ).

% INF_eq_const
tff(fact_4036_bot__finite__def,axiom,
    ! [C: $tType] :
      ( finite_lattice(C)
     => ( bot_bot(C) = aa(set(C),C,complete_Inf_Inf(C),top_top(set(C))) ) ) ).

% bot_finite_def
tff(fact_4037_Inf__finite__insert,axiom,
    ! [C: $tType] :
      ( finite_lattice(C)
     => ! [A3: C,A4: set(C)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Inf_Inf(C),A4)) ) ).

% Inf_finite_insert
tff(fact_4038_Inf__union__distrib,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C),B3: set(C)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Inf_Inf(C),B3)) ) ).

% Inf_union_distrib
tff(fact_4039_foldr_Ofoldr__Cons,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),X: D,Xs: list(D)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)) = comp(C,C,C,aa(D,fun(C,C),F,X),aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),Xs)) ).

% foldr.foldr_Cons
tff(fact_4040_remdups__adj_Oelims,axiom,
    ! [C: $tType,X: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),remdups_adj(C),X) = Y )
     => ( ( ( X = nil(C) )
         => ( Y != nil(C) ) )
       => ( ! [X2: C] :
              ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
             => ( Y != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) ) )
         => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
               => ( Y != $ite(X2 = Y2,aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)))) ) ) ) ) ) ).

% remdups_adj.elims
tff(fact_4041_remdups__adj_Osimps_I2_J,axiom,
    ! [C: $tType,X: C] : aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ).

% remdups_adj.simps(2)
tff(fact_4042_remdups__adj__length,axiom,
    ! [C: $tType,Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups_adj(C),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% remdups_adj_length
tff(fact_4043_sorted__remdups__adj,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),remdups_adj(C),Xs)) ) ) ).

% sorted_remdups_adj
tff(fact_4044_INF__absorb,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [K: C,I5: set(C),A4: fun(C,D)] :
          ( member2(C,K,I5)
         => ( aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(C,D,A4,K)),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,A4),I5))) = aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,A4),I5)) ) ) ) ).

% INF_absorb
tff(fact_4045_INF__inf__distrib,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(D,C),A4: set(D),G: fun(D,C)] : aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,F),A4))),aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,G),A4))) = aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_lt(fun(D,C),fun(fun(D,C),fun(D,C)),F),G)),A4)) ) ).

% INF_inf_distrib
tff(fact_4046_Inter__insert,axiom,
    ! [C: $tType,A3: set(C),B3: set(set(C))] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),A3),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A3),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),B3)) ).

% Inter_insert
tff(fact_4047_Inter__UNIV,axiom,
    ! [C: $tType] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),top_top(set(set(C)))) = bot_bot(set(C)) ).

% Inter_UNIV
tff(fact_4048_Inter__Un__distrib,axiom,
    ! [C: $tType,A4: set(set(C)),B3: set(set(C))] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),sup_sup(set(set(C))),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),A4)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),B3)) ).

% Inter_Un_distrib
tff(fact_4049_INT__absorb,axiom,
    ! [D: $tType,C: $tType,K: C,I5: set(C),A4: fun(C,set(D))] :
      ( member2(C,K,I5)
     => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(C,set(D),A4,K)),aa(set(set(D)),set(D),complete_Inf_Inf(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I5))) = aa(set(set(D)),set(D),complete_Inf_Inf(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I5)) ) ) ).

% INT_absorb
tff(fact_4050_INT__Int__distrib,axiom,
    ! [C: $tType,D: $tType,A4: fun(D,set(C)),B3: fun(D,set(C)),I5: set(D)] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_lu(fun(D,set(C)),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),I5)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),I5))),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),I5))) ).

% INT_Int_distrib
tff(fact_4051_Int__Inter__image,axiom,
    ! [C: $tType,D: $tType,A4: fun(D,set(C)),B3: fun(D,set(C)),C4: set(D)] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_lu(fun(D,set(C)),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4))),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4))) ).

% Int_Inter_image
tff(fact_4052_cINF__greatest,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),M2: D,F: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),M2),aa(C,D,F,X2)) )
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),M2),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))) ) ) ) ).

% cINF_greatest
tff(fact_4053_INF__eq__iff,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [I5: set(C),F: fun(C,D),C3: D] :
          ( ( I5 != bot_bot(set(C)) )
         => ( ! [I3: C] :
                ( member2(C,I3,I5)
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,I3)),C3) )
           => ( ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),I5)) = C3 )
            <=> ! [X4: C] :
                  ( member2(C,X4,I5)
                 => ( aa(C,D,F,X4) = C3 ) ) ) ) ) ) ).

% INF_eq_iff
tff(fact_4054_finite__less__Inf__iff,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C),A3: C] :
          ( aa(set(C),$o,finite_finite2(C),X5)
         => ( ( X5 != bot_bot(set(C)) )
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),aa(set(C),C,complete_Inf_Inf(C),X5))
            <=> ! [X4: C] :
                  ( member2(C,X4,X5)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),X4) ) ) ) ) ) ).

% finite_less_Inf_iff
tff(fact_4055_Inf__le__Sup,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Sup_Sup(C),A4)) ) ) ).

% Inf_le_Sup
tff(fact_4056_finite__Inf__in,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [X2: C,Y2: C] :
                  ( member2(C,X2,A4)
                 => ( member2(C,Y2,A4)
                   => member2(C,aa(C,C,aa(C,fun(C,C),inf_inf(C),X2),Y2),A4) ) )
             => member2(C,aa(set(C),C,complete_Inf_Inf(C),A4),A4) ) ) ) ) ).

% finite_Inf_in
tff(fact_4057_cInf__abs__ge,axiom,
    ! [C: $tType] :
      ( ( condit6923001295902523014norder(C)
        & linordered_idom(C) )
     => ! [S: set(C),A3: C] :
          ( ( S != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,S)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),X2)),A3) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),aa(set(C),C,complete_Inf_Inf(C),S))),A3) ) ) ) ).

% cInf_abs_ge
tff(fact_4058_less__eq__Inf__inter,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C),B3: set(C)] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Inf_Inf(C),B3))),aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ).

% less_eq_Inf_inter
tff(fact_4059_Inf__finite__empty,axiom,
    ! [C: $tType] :
      ( finite_lattice(C)
     => ( aa(set(C),C,complete_Inf_Inf(C),bot_bot(set(C))) = aa(set(C),C,complete_Sup_Sup(C),top_top(set(C))) ) ) ).

% Inf_finite_empty
tff(fact_4060_Sup__finite__empty,axiom,
    ! [C: $tType] :
      ( finite_lattice(C)
     => ( aa(set(C),C,complete_Sup_Sup(C),bot_bot(set(C))) = aa(set(C),C,complete_Inf_Inf(C),top_top(set(C))) ) ) ).

% Sup_finite_empty
tff(fact_4061_inf__Inf__fold__inf,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C),B3: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Inf_Inf(C),A4)),B3) = finite_fold(C,C,inf_inf(C),B3,A4) ) ) ) ).

% inf_Inf_fold_inf
tff(fact_4062_Min__Inf,axiom,
    ! [C: $tType] :
      ( comple5582772986160207858norder(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( lattic643756798350308766er_Min(C,A4) = aa(set(C),C,complete_Inf_Inf(C),A4) ) ) ) ) ).

% Min_Inf
tff(fact_4063_cInf__eq__Min,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),X5)
         => ( ( X5 != bot_bot(set(C)) )
           => ( aa(set(C),C,complete_Inf_Inf(C),X5) = lattic643756798350308766er_Min(C,X5) ) ) ) ) ).

% cInf_eq_Min
tff(fact_4064_Inf__fin__Inf,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( aa(set(C),C,lattic7752659483105999362nf_fin(C),A4) = aa(set(C),C,complete_Inf_Inf(C),A4) ) ) ) ) ).

% Inf_fin_Inf
tff(fact_4065_cInf__eq__Inf__fin,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),X5)
         => ( ( X5 != bot_bot(set(C)) )
           => ( aa(set(C),C,complete_Inf_Inf(C),X5) = aa(set(C),C,lattic7752659483105999362nf_fin(C),X5) ) ) ) ) ).

% cInf_eq_Inf_fin
tff(fact_4066_remdups__adj__append__two,axiom,
    ! [C: $tType,Xs: list(C),X: C,Y: C] :
      aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C))))) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))))),
        $ite(X = Y,nil(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C)))) ).

% remdups_adj_append_two
tff(fact_4067_remdups__adj__map__injective,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),Xs: list(C)] :
      ( inj_on(C,D,F,top_top(set(C)))
     => ( aa(list(D),list(D),remdups_adj(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(list(C),list(C),remdups_adj(C),Xs)) ) ) ).

% remdups_adj_map_injective
tff(fact_4068_INF__empty,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(D,C)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,F),bot_bot(set(D)))) = top_top(C) ) ).

% INF_empty
tff(fact_4069_INF__constant,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [C3: C,A4: set(D)] :
          aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,aTP_Lamp_dg(C,fun(D,C),C3)),A4)) = $ite(A4 = bot_bot(set(D)),top_top(C),C3) ) ).

% INF_constant
tff(fact_4070_INF__inf__const1,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [I5: set(C),X: D,F: fun(C,D)] :
          ( ( I5 != bot_bot(set(C)) )
         => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_lv(D,fun(fun(C,D),fun(C,D)),X),F)),I5)) = aa(D,D,aa(D,fun(D,D),inf_inf(D),X),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),I5))) ) ) ) ).

% INF_inf_const1
tff(fact_4071_INF__inf__const2,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [I5: set(C),F: fun(C,D),X: D] :
          ( ( I5 != bot_bot(set(C)) )
         => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,aa(D,fun(C,D),aTP_Lamp_lw(fun(C,D),fun(D,fun(C,D)),F),X)),I5)) = aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),I5))),X) ) ) ) ).

% INF_inf_const2
tff(fact_4072_INF__insert,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(D,C),A3: D,A4: set(D)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),A4))) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(D,C,F,A3)),aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,F),A4))) ) ).

% INF_insert
tff(fact_4073_INF__union,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [M: fun(D,C),A4: set(D),B3: set(D)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,M),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3))) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,M),A4))),aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,M),B3))) ) ).

% INF_union
tff(fact_4074_INT__empty,axiom,
    ! [D: $tType,C: $tType,B3: fun(D,set(C))] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),bot_bot(set(D)))) = top_top(set(C)) ).

% INT_empty
tff(fact_4075_INT__extend__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4))) = $ite(C4 = bot_bot(set(D)),A4,aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_cu(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4))) ).

% INT_extend_simps(2)
tff(fact_4076_INT__extend__simps_I1_J,axiom,
    ! [C: $tType,D: $tType,A4: fun(D,set(C)),C4: set(D),B3: set(C)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4))),B3) = $ite(C4 = bot_bot(set(D)),B3,aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_cv(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4))) ).

% INT_extend_simps(1)
tff(fact_4077_inj__on__INTER,axiom,
    ! [E2: $tType,D: $tType,C: $tType,I5: set(C),F: fun(D,E2),A4: fun(C,set(D))] :
      ( ( I5 != bot_bot(set(C)) )
     => ( ! [I3: C] :
            ( member2(C,I3,I5)
           => inj_on(D,E2,F,aa(C,set(D),A4,I3)) )
       => inj_on(D,E2,F,aa(set(set(D)),set(D),complete_Inf_Inf(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I5))) ) ) ).

% inj_on_INTER
tff(fact_4078_INT__Un,axiom,
    ! [C: $tType,D: $tType,M: fun(D,set(C)),A4: set(D),B3: set(D)] : aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),M),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),M),A4))),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),M),B3))) ).

% INT_Un
tff(fact_4079_Inter__Un__subset,axiom,
    ! [C: $tType,A4: set(set(C)),B3: set(set(C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),A4)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),B3))),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),inf_inf(set(set(C))),A4),B3))) ).

% Inter_Un_subset
tff(fact_4080_prod_Oreindex__nontrivial,axiom,
    ! [D: $tType,E2: $tType,C: $tType] :
      ( comm_monoid_mult(E2)
     => ! [A4: set(C),H: fun(C,D),G: fun(D,E2)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ! [X2: C,Y2: C] :
                ( member2(C,X2,A4)
               => ( member2(C,Y2,A4)
                 => ( ( X2 != Y2 )
                   => ( ( aa(C,D,H,X2) = aa(C,D,H,Y2) )
                     => ( aa(D,E2,G,aa(C,D,H,X2)) = one_one(E2) ) ) ) ) )
           => ( aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7121269368397514597t_prod(D,E2),G),aa(set(C),set(D),image2(C,D,H),A4)) = aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7121269368397514597t_prod(C,E2),comp(D,E2,C,G,H)),A4) ) ) ) ) ).

% prod.reindex_nontrivial
tff(fact_4081_Int__Inter__eq_I2_J,axiom,
    ! [C: $tType,B12: set(set(C)),A4: set(C)] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),B12)),A4) = $ite(B12 = bot_bot(set(set(C))),A4,aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aTP_Lamp_cy(set(C),fun(set(C),set(C)),A4)),B12))) ).

% Int_Inter_eq(2)
tff(fact_4082_Int__Inter__eq_I1_J,axiom,
    ! [C: $tType,A4: set(C),B12: set(set(C))] :
      aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),B12)) = $ite(B12 = bot_bot(set(set(C))),A4,aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4)),B12))) ).

% Int_Inter_eq(1)
tff(fact_4083_INF__le__SUP,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),F: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))) ) ) ).

% INF_le_SUP
tff(fact_4084_remdups__adj__Cons,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))),aTP_Lamp_lx(C,fun(C,fun(list(C),list(C))),X)),aa(list(C),list(C),remdups_adj(C),Xs)) ).

% remdups_adj_Cons
tff(fact_4085_cInf__asclose,axiom,
    ! [C: $tType] :
      ( ( condit6923001295902523014norder(C)
        & linordered_idom(C) )
     => ! [S: set(C),La: C,E4: C] :
          ( ( S != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,S)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,X2,La))),E4) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),minus_minus(C,aa(set(C),C,complete_Inf_Inf(C),S),La))),E4) ) ) ) ).

% cInf_asclose
tff(fact_4086_Inf__insert__finite,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [S: set(C),X: C] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),S)) = $ite(S = bot_bot(set(C)),X,aa(C,C,aa(C,fun(C,C),ord_min(C),X),aa(set(C),C,complete_Inf_Inf(C),S))) ) ) ) ).

% Inf_insert_finite
tff(fact_4087_Inf__fold__inf,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),C,complete_Inf_Inf(C),A4) = finite_fold(C,C,inf_inf(C),top_top(C),A4) ) ) ) ).

% Inf_fold_inf
tff(fact_4088_remdups__adj__adjacent,axiom,
    ! [C: $tType,I: nat,Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,I)),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups_adj(C),Xs)))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),remdups_adj(C),Xs)),I) != aa(nat,C,nth(C,aa(list(C),list(C),remdups_adj(C),Xs)),aa(nat,nat,suc,I)) ) ) ).

% remdups_adj_adjacent
tff(fact_4089_remdups__adj__replicate,axiom,
    ! [C: $tType,N: nat,X: C] :
      aa(list(C),list(C),remdups_adj(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = $ite(N = zero_zero(nat),nil(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% remdups_adj_replicate
tff(fact_4090_remdups__adj__singleton,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( ( aa(list(C),list(C),remdups_adj(C),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) )
     => ( Xs = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(list(C),nat,size_size(list(C)),Xs)),X) ) ) ).

% remdups_adj_singleton
tff(fact_4091_remdups__adj__append,axiom,
    ! [C: $tType,Xs_1: list(C),X: C,Xs_2: list(C)] : aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs_1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs_2))) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs_1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))))),aa(list(C),list(C),tl(C),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs_2)))) ).

% remdups_adj_append
tff(fact_4092_INT__extend__simps_I3_J,axiom,
    ! [C: $tType,D: $tType,A4: fun(D,set(C)),C4: set(D),B3: set(C)] :
      minus_minus(set(C),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),A4),C4)),B3) = $ite(C4 = bot_bot(set(D)),minus_minus(set(C),top_top(set(C)),B3),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_ls(fun(D,set(C)),fun(set(C),fun(D,set(C))),A4),B3)),C4))) ).

% INT_extend_simps(3)
tff(fact_4093_INT__extend__simps_I4_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: fun(D,set(C)),C4: set(D)] :
      minus_minus(set(C),A4,aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),C4))) = $ite(C4 = bot_bot(set(D)),A4,aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_lq(set(C),fun(fun(D,set(C)),fun(D,set(C))),A4),B3)),C4))) ).

% INT_extend_simps(4)
tff(fact_4094_remdups__adj__append_H,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( ( Xs = nil(C) )
        | ( Ys = nil(C) )
        | ( last(C,Xs) != aa(list(C),C,hd(C),Ys) ) )
     => ( aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),remdups_adj(C),Xs)),aa(list(C),list(C),remdups_adj(C),Ys)) ) ) ).

% remdups_adj_append'
tff(fact_4095_remdups__adj__length__ge1,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,suc,zero_zero(nat))),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),remdups_adj(C),Xs))) ) ).

% remdups_adj_length_ge1
tff(fact_4096_quotient__empty,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : equiv_quotient(C,bot_bot(set(C)),R3) = bot_bot(set(set(C))) ).

% quotient_empty
tff(fact_4097_quotient__is__empty,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] :
      ( ( equiv_quotient(C,A4,R3) = bot_bot(set(set(C))) )
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% quotient_is_empty
tff(fact_4098_quotient__is__empty2,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] :
      ( ( bot_bot(set(set(C))) = equiv_quotient(C,A4,R3) )
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% quotient_is_empty2
tff(fact_4099_quotient__diff1,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),A3: C] :
      ( inj_on(C,set(set(C)),aTP_Lamp_lr(set(product_prod(C,C)),fun(C,set(set(C))),R3),A4)
     => ( member2(C,A3,A4)
       => ( equiv_quotient(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))),R3) = minus_minus(set(set(C)),equiv_quotient(C,A4,R3),equiv_quotient(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))),R3)) ) ) ) ).

% quotient_diff1
tff(fact_4100_size__list__map,axiom,
    ! [C: $tType,D: $tType,F: fun(C,nat),G: fun(D,C),Xs: list(D)] : aa(list(C),nat,size_list(C,F),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),Xs)) = aa(list(D),nat,size_list(D,comp(C,nat,D,F,G)),Xs) ).

% size_list_map
tff(fact_4101_subset__mset_OcINF__const,axiom,
    ! [C: $tType,D: $tType,A4: set(C),C3: multiset(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),aTP_Lamp_ac(multiset(D),fun(C,multiset(D)),C3)),A4)) = C3 ) ) ).

% subset_mset.cINF_const
tff(fact_4102_length__filter__map,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),F: fun(D,C),Xs: list(D)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))) = aa(list(D),nat,size_size(list(D)),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),comp(C,$o,D,Pa,F)),Xs)) ).

% length_filter_map
tff(fact_4103_list_Osize__gen__o__map,axiom,
    ! [D: $tType,C: $tType,F: fun(D,nat),G: fun(C,D)] : comp(list(D),nat,list(C),size_list(D,F),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G)) = size_list(C,comp(D,nat,C,F,G)) ).

% list.size_gen_o_map
tff(fact_4104_empty__natural,axiom,
    ! [E2: $tType,D: $tType,F4: $tType,C: $tType,F: fun(C,E2),G: fun(F4,D)] : comp(E2,set(D),C,aTP_Lamp_ly(E2,set(D)),F) = comp(set(F4),set(D),C,image2(F4,D,G),aTP_Lamp_lz(C,set(F4))) ).

% empty_natural
tff(fact_4105_UNIV__bool,axiom,
    top_top(set($o)) = aa(set($o),set($o),aa($o,fun(set($o),set($o)),insert2($o),$false),aa(set($o),set($o),aa($o,fun(set($o),set($o)),insert2($o),$true),bot_bot(set($o)))) ).

% UNIV_bool
tff(fact_4106_sorted__list__of__set_Ofold__insort__key_Ocomp__fun__commute__on,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Y: C,X: C] : comp(list(C),list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),Y),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X)) = comp(list(C),list(C),list(C),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),X),aa(C,fun(list(C),list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),Y)) ) ).

% sorted_list_of_set.fold_insort_key.comp_fun_commute_on
tff(fact_4107_filter__map,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),comp(C,$o,D,Pa,F)),Xs)) ).

% filter_map
tff(fact_4108_takeWhile__map,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),takeWhile(D),comp(C,$o,D,Pa,F)),Xs)) ).

% takeWhile_map
tff(fact_4109_foldr__map,axiom,
    ! [E2: $tType,D: $tType,C: $tType,G: fun(D,fun(C,C)),F: fun(E2,D),Xs: list(E2),A3: C] : aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),G),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),Xs)),A3) = aa(C,C,aa(list(E2),fun(C,C),aa(fun(E2,fun(C,C)),fun(list(E2),fun(C,C)),foldr(E2,C),comp(D,fun(C,C),E2,G,F)),Xs),A3) ).

% foldr_map
tff(fact_4110_rotate__add,axiom,
    ! [C: $tType,M2: nat,N: nat] : aa(nat,fun(list(C),list(C)),rotate(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N)) = comp(list(C),list(C),list(C),aa(nat,fun(list(C),list(C)),rotate(C),M2),aa(nat,fun(list(C),list(C)),rotate(C),N)) ).

% rotate_add
tff(fact_4111_folding__insort__key_Oinsort__key__commute,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C),X: D,Y: D] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => ( member2(D,X,S)
       => ( member2(D,Y,S)
         => ( comp(list(D),list(D),list(D),aa(D,fun(list(D),list(D)),aa(fun(D,C),fun(D,fun(list(D),list(D))),insort_key(C,D,Less_eq),F),Y),aa(D,fun(list(D),list(D)),aa(fun(D,C),fun(D,fun(list(D),list(D))),insort_key(C,D,Less_eq),F),X)) = comp(list(D),list(D),list(D),aa(D,fun(list(D),list(D)),aa(fun(D,C),fun(D,fun(list(D),list(D))),insort_key(C,D,Less_eq),F),X),aa(D,fun(list(D),list(D)),aa(fun(D,C),fun(D,fun(list(D),list(D))),insort_key(C,D,Less_eq),F),Y)) ) ) ) ) ).

% folding_insort_key.insort_key_commute
tff(fact_4112_set__oo__map__alt,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),X3: list(C)] : aa(list(C),set(D),comp(list(D),set(D),list(C),set2(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F)),X3) = aa(set(C),set(D),image2(C,D,F),aa(list(C),set(C),set2(C),X3)) ).

% set_oo_map_alt
tff(fact_4113_zip__takeWhile__fst,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)),Ys) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(fun(product_prod(C,D),$o),fun(list(product_prod(C,D)),list(product_prod(C,D))),takeWhile(product_prod(C,D)),comp(C,$o,product_prod(C,D),Pa,product_fst(C,D))),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) ).

% zip_takeWhile_fst
tff(fact_4114_zip__takeWhile__snd,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Pa: fun(D,$o),Ys: list(D)] : aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),takeWhile(D),Pa),Ys)) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(fun(product_prod(C,D),$o),fun(list(product_prod(C,D)),list(product_prod(C,D))),takeWhile(product_prod(C,D)),comp(D,$o,product_prod(C,D),Pa,product_snd(C,D))),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)) ).

% zip_takeWhile_snd
tff(fact_4115_prod_OUnion__comp,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [B3: set(set(C)),G: fun(C,D)] :
          ( ! [X2: set(C)] :
              ( member2(set(C),X2,B3)
             => aa(set(C),$o,finite_finite2(C),X2) )
         => ( ! [A13: set(C)] :
                ( member2(set(C),A13,B3)
               => ! [A23: set(C)] :
                    ( member2(set(C),A23,B3)
                   => ( ( A13 != A23 )
                     => ! [X2: C] :
                          ( member2(C,X2,A13)
                         => ( member2(C,X2,A23)
                           => ( aa(C,D,G,X2) = one_one(D) ) ) ) ) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),B3)) = aa(set(set(C)),D,aa(fun(C,D),fun(set(set(C)),D),comp(fun(set(C),D),fun(set(set(C)),D),fun(C,D),groups7121269368397514597t_prod(set(C),D),groups7121269368397514597t_prod(C,D)),G),B3) ) ) ) ) ).

% prod.Union_comp
tff(fact_4116_remove__rev__def,axiom,
    ! [C: $tType,X: C] : remove_rev(C,X) = aa(fun(C,$o),fun(list(C),list(C)),filter_rev(C),comp($o,$o,C,fNot,aa(C,fun(C,$o),fequal(C),X))) ).

% remove_rev_def
tff(fact_4117_prod_Oeq__fold,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),A4: set(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7121269368397514597t_prod(D,C),G),A4) = finite_fold(D,C,comp(C,fun(C,C),D,times_times(C),G),one_one(C),A4) ) ).

% prod.eq_fold
tff(fact_4118_remdup__sort__mergesort__remdups,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( comp(list(C),list(C),list(C),remdups(C),aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C))) = mergesort_remdups(C) ) ) ).

% remdup_sort_mergesort_remdups
tff(fact_4119_sum_OUnion__disjoint,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [C4: set(set(C)),G: fun(C,D)] :
          ( ! [X2: set(C)] :
              ( member2(set(C),X2,C4)
             => aa(set(C),$o,finite_finite2(C),X2) )
         => ( ! [X2: set(C)] :
                ( member2(set(C),X2,C4)
               => ! [Xa4: set(C)] :
                    ( member2(set(C),Xa4,C4)
                   => ( ( X2 != Xa4 )
                     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X2),Xa4) = bot_bot(set(C)) ) ) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4)) = aa(set(set(C)),D,aa(fun(C,D),fun(set(set(C)),D),comp(fun(set(C),D),fun(set(set(C)),D),fun(C,D),groups7311177749621191930dd_sum(set(C),D),groups7311177749621191930dd_sum(C,D)),G),C4) ) ) ) ) ).

% sum.Union_disjoint
tff(fact_4120_prod_OUnion__disjoint,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [C4: set(set(C)),G: fun(C,D)] :
          ( ! [X2: set(C)] :
              ( member2(set(C),X2,C4)
             => aa(set(C),$o,finite_finite2(C),X2) )
         => ( ! [X2: set(C)] :
                ( member2(set(C),X2,C4)
               => ! [Xa4: set(C)] :
                    ( member2(set(C),Xa4,C4)
                   => ( ( X2 != Xa4 )
                     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X2),Xa4) = bot_bot(set(C)) ) ) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),C4)) = aa(set(set(C)),D,aa(fun(C,D),fun(set(set(C)),D),comp(fun(set(C),D),fun(set(set(C)),D),fun(C,D),groups7121269368397514597t_prod(set(C),D),groups7121269368397514597t_prod(C,D)),G),C4) ) ) ) ) ).

% prod.Union_disjoint
tff(fact_4121_inf__INF__fold__inf,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),B3: D,F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(D,D,aa(D,fun(D,D),inf_inf(D),B3),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))) = finite_fold(C,D,comp(D,fun(D,D),C,inf_inf(D),F),B3,A4) ) ) ) ).

% inf_INF_fold_inf
tff(fact_4122_prod_OatLeast0__atMost__Suc__shift,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,zero_zero(nat))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),comp(nat,C,nat,G,suc)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) ) ).

% prod.atLeast0_atMost_Suc_shift
tff(fact_4123_prod_OatLeast0__lessThan__Suc__shift,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(nat,C),N: nat] : aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,G,zero_zero(nat))),aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),comp(nat,C,nat,G,suc)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))) ) ).

% prod.atLeast0_lessThan_Suc_shift
tff(fact_4124_SUP__fold__sup,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4)) = finite_fold(C,D,comp(D,fun(D,D),C,sup_sup(D),F),bot_bot(D),A4) ) ) ) ).

% SUP_fold_sup
tff(fact_4125_INF__fold__inf,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4)) = finite_fold(C,D,comp(D,fun(D,D),C,inf_inf(D),F),top_top(D),A4) ) ) ) ).

% INF_fold_inf
tff(fact_4126_remdups__adj_Opelims,axiom,
    ! [C: $tType,X: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),remdups_adj(C),X) = Y )
     => ( accp(list(C),remdups_adj_rel(C),X)
       => ( ( ( X = nil(C) )
           => ( ( Y = nil(C) )
             => ~ accp(list(C),remdups_adj_rel(C),nil(C)) ) )
         => ( ! [X2: C] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
               => ( ( Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
                 => ~ accp(list(C),remdups_adj_rel(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))) ) )
           => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                  ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
                 => ( ( Y = $ite(X2 = Y2,aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)))) )
                   => ~ accp(list(C),remdups_adj_rel(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2))) ) ) ) ) ) ) ).

% remdups_adj.pelims
tff(fact_4127_remdups__adj__altdef,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),remdups_adj(C),Xs) = Ys )
    <=> ? [F6: fun(nat,nat)] :
          ( order_mono(nat,nat,F6)
          & ( aa(set(nat),set(nat),image2(nat,nat,F6),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(C),nat,size_size(list(C)),Xs))) = set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(C),nat,size_size(list(C)),Ys)) )
          & ! [I2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
             => ( aa(nat,C,nth(C,Xs),I2) = aa(nat,C,nth(C,Ys),aa(nat,nat,F6,I2)) ) )
          & ! [I2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I2),one_one(nat))),aa(list(C),nat,size_size(list(C)),Xs))
             => ( ( aa(nat,C,nth(C,Xs),I2) = aa(nat,C,nth(C,Xs),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I2),one_one(nat))) )
              <=> ( aa(nat,nat,F6,I2) = aa(nat,nat,F6,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I2),one_one(nat))) ) ) ) ) ) ).

% remdups_adj_altdef
tff(fact_4128_range__prod,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(E2,product_prod(C,D))] : aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),ord_less_eq(set(product_prod(C,D))),aa(set(E2),set(product_prod(C,D)),image2(E2,product_prod(C,D),F),top_top(set(E2)))),product_Sigma(C,D,aa(set(E2),set(C),image2(E2,C,comp(product_prod(C,D),C,E2,product_fst(C,D),F)),top_top(set(E2))),aTP_Lamp_ma(fun(E2,product_prod(C,D)),fun(C,set(D)),F))) ).

% range_prod
tff(fact_4129_lists__empty,axiom,
    ! [C: $tType] : aa(set(C),set(list(C)),lists(C),bot_bot(set(C))) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),nil(C)),bot_bot(set(list(C)))) ).

% lists_empty
tff(fact_4130_Cons__in__lists__iff,axiom,
    ! [C: $tType,X: C,Xs: list(C),A4: set(C)] :
      ( member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aa(set(C),set(list(C)),lists(C),A4))
    <=> ( member2(C,X,A4)
        & member2(list(C),Xs,aa(set(C),set(list(C)),lists(C),A4)) ) ) ).

% Cons_in_lists_iff
tff(fact_4131_in__listsI,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => member2(C,X2,A4) )
     => member2(list(C),Xs,aa(set(C),set(list(C)),lists(C),A4)) ) ).

% in_listsI
tff(fact_4132_lists__Int__eq,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(set(C),set(list(C)),lists(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) = aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),inf_inf(set(list(C))),aa(set(C),set(list(C)),lists(C),A4)),aa(set(C),set(list(C)),lists(C),B3)) ).

% lists_Int_eq
tff(fact_4133_append__in__lists__conv,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),A4: set(C)] :
      ( member2(list(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys),aa(set(C),set(list(C)),lists(C),A4))
    <=> ( member2(list(C),Xs,aa(set(C),set(list(C)),lists(C),A4))
        & member2(list(C),Ys,aa(set(C),set(list(C)),lists(C),A4)) ) ) ).

% append_in_lists_conv
tff(fact_4134_Sigma__UNIV__cancel,axiom,
    ! [D: $tType,C: $tType,A4: set(C),X5: set(D)] : minus_minus(set(product_prod(C,D)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),X5)),product_Sigma(C,D,A4,aTP_Lamp_mc(C,set(D)))) = bot_bot(set(product_prod(C,D))) ).

% Sigma_UNIV_cancel
tff(fact_4135_lists__UNIV,axiom,
    ! [C: $tType] : aa(set(C),set(list(C)),lists(C),top_top(set(C))) = top_top(set(list(C))) ).

% lists_UNIV
tff(fact_4136_set__product,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D)] : aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),product(C,D),Xs),Ys)) = product_Sigma(C,D,aa(list(C),set(C),set2(C),Xs),aTP_Lamp_md(list(D),fun(C,set(D)),Ys)) ).

% set_product
tff(fact_4137_pairself__image__cart,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D),B3: set(D)] : aa(set(product_prod(D,D)),set(product_prod(C,C)),image2(product_prod(D,D),product_prod(C,C),pairself(D,C,F)),product_Sigma(D,D,A4,aTP_Lamp_me(set(D),fun(D,set(D)),B3))) = product_Sigma(C,C,aa(set(D),set(C),image2(D,C,F),A4),aa(set(D),fun(C,set(C)),aTP_Lamp_mf(fun(D,C),fun(set(D),fun(C,set(C))),F),B3)) ).

% pairself_image_cart
tff(fact_4138_lists_ONil,axiom,
    ! [C: $tType,A4: set(C)] : member2(list(C),nil(C),aa(set(C),set(list(C)),lists(C),A4)) ).

% lists.Nil
tff(fact_4139_mono__add,axiom,
    ! [C: $tType] :
      ( ordere6658533253407199908up_add(C)
     => ! [A3: C] : order_mono(C,C,aa(C,fun(C,C),plus_plus(C),A3)) ) ).

% mono_add
tff(fact_4140_min__of__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(D) )
     => ! [F: fun(C,D),M2: C,N: C] :
          ( order_mono(C,D,F)
         => ( aa(D,D,aa(D,fun(D,D),ord_min(D),aa(C,D,F,M2)),aa(C,D,F,N)) = aa(C,D,F,aa(C,C,aa(C,fun(C,C),ord_min(C),M2),N)) ) ) ) ).

% min_of_mono
tff(fact_4141_max__of__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(D) )
     => ! [F: fun(C,D),M2: C,N: C] :
          ( order_mono(C,D,F)
         => ( aa(D,D,aa(D,fun(D,D),ord_max(D),aa(C,D,F,M2)),aa(C,D,F,N)) = aa(C,D,F,aa(C,C,aa(C,fun(C,C),ord_max(C),M2),N)) ) ) ) ).

% max_of_mono
tff(fact_4142_mono__strict__invE,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & order(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_mono(C,D,F)
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X)),aa(C,D,F,Y))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),Y) ) ) ) ).

% mono_strict_invE
tff(fact_4143_monoD,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_mono(C,D,F)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X)),aa(C,D,F,Y)) ) ) ) ).

% monoD
tff(fact_4144_monoE,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_mono(C,D,F)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X)),aa(C,D,F,Y)) ) ) ) ).

% monoE
tff(fact_4145_monoI,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D)] :
          ( ! [X2: C,Y2: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y2)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,F,Y2)) )
         => order_mono(C,D,F) ) ) ).

% monoI
tff(fact_4146_mono__def,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D)] :
          ( order_mono(C,D,F)
        <=> ! [X4: C,Y3: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),Y3)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X4)),aa(C,D,F,Y3)) ) ) ) ).

% mono_def
tff(fact_4147_lists__IntI,axiom,
    ! [C: $tType,La: list(C),A4: set(C),B3: set(C)] :
      ( member2(list(C),La,aa(set(C),set(list(C)),lists(C),A4))
     => ( member2(list(C),La,aa(set(C),set(list(C)),lists(C),B3))
       => member2(list(C),La,aa(set(C),set(list(C)),lists(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ).

% lists_IntI
tff(fact_4148_listsE,axiom,
    ! [C: $tType,X: C,La: list(C),A4: set(C)] :
      ( member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),La),aa(set(C),set(list(C)),lists(C),A4))
     => ~ ( member2(C,X,A4)
         => ~ member2(list(C),La,aa(set(C),set(list(C)),lists(C),A4)) ) ) ).

% listsE
tff(fact_4149_lists_OCons,axiom,
    ! [C: $tType,A3: C,A4: set(C),La: list(C)] :
      ( member2(C,A3,A4)
     => ( member2(list(C),La,aa(set(C),set(list(C)),lists(C),A4))
       => member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),La),aa(set(C),set(list(C)),lists(C),A4)) ) ) ).

% lists.Cons
tff(fact_4150_listrel__subset,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))
     => aa(set(product_prod(list(C),list(C))),$o,aa(set(product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),$o),ord_less_eq(set(product_prod(list(C),list(C)))),listrel(C,C,R3)),product_Sigma(list(C),list(C),aa(set(C),set(list(C)),lists(C),A4),aTP_Lamp_mh(set(C),fun(list(C),set(list(C))),A4))) ) ).

% listrel_subset
tff(fact_4151_mono__funpow,axiom,
    ! [C: $tType] :
      ( ( lattice(C)
        & order_bot(C) )
     => ! [Q: fun(C,C)] :
          ( order_mono(C,C,Q)
         => order_mono(nat,C,aTP_Lamp_mi(fun(C,C),fun(nat,C),Q)) ) ) ).

% mono_funpow
tff(fact_4152_in__lists__conv__set,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] :
      ( member2(list(C),Xs,aa(set(C),set(list(C)),lists(C),A4))
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => member2(C,X4,A4) ) ) ).

% in_lists_conv_set
tff(fact_4153_in__listsD,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] :
      ( member2(list(C),Xs,aa(set(C),set(list(C)),lists(C),A4))
     => ! [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
         => member2(C,X3,A4) ) ) ).

% in_listsD
tff(fact_4154_mono__invE,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & order(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_mono(C,D,F)
         => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X)),aa(C,D,F,Y))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y) ) ) ) ).

% mono_invE
tff(fact_4155_mono__inf,axiom,
    ! [D: $tType,C: $tType] :
      ( ( semilattice_inf(C)
        & semilattice_inf(D) )
     => ! [F: fun(C,D),A4: C,B3: C] :
          ( order_mono(C,D,F)
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,aa(C,C,aa(C,fun(C,C),inf_inf(C),A4),B3))),aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(C,D,F,A4)),aa(C,D,F,B3))) ) ) ).

% mono_inf
tff(fact_4156_mono__sup,axiom,
    ! [D: $tType,C: $tType] :
      ( ( semilattice_sup(C)
        & semilattice_sup(D) )
     => ! [F: fun(C,D),A4: C,B3: C] :
          ( order_mono(C,D,F)
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(D,D,aa(D,fun(D,D),sup_sup(D),aa(C,D,F,A4)),aa(C,D,F,B3))),aa(C,D,F,aa(C,C,aa(C,fun(C,C),sup_sup(C),A4),B3))) ) ) ).

% mono_sup
tff(fact_4157_lists_Osimps,axiom,
    ! [C: $tType,A3: list(C),A4: set(C)] :
      ( member2(list(C),A3,aa(set(C),set(list(C)),lists(C),A4))
    <=> ( ( A3 = nil(C) )
        | ? [A6: C,L3: list(C)] :
            ( ( A3 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A6),L3) )
            & member2(C,A6,A4)
            & member2(list(C),L3,aa(set(C),set(list(C)),lists(C),A4)) ) ) ) ).

% lists.simps
tff(fact_4158_lists_Ocases,axiom,
    ! [C: $tType,A3: list(C),A4: set(C)] :
      ( member2(list(C),A3,aa(set(C),set(list(C)),lists(C),A4))
     => ( ( A3 != nil(C) )
       => ~ ! [A5: C,L: list(C)] :
              ( ( A3 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),L) )
             => ( member2(C,A5,A4)
               => ~ member2(list(C),L,aa(set(C),set(list(C)),lists(C),A4)) ) ) ) ) ).

% lists.cases
tff(fact_4159_lists__image__witness,axiom,
    ! [C: $tType,D: $tType,X: list(C),F: fun(D,C),Q: set(D)] :
      ( member2(list(C),X,aa(set(C),set(list(C)),lists(C),aa(set(D),set(C),image2(D,C,F),Q)))
     => ~ ! [Xo: list(D)] :
            ( member2(list(D),Xo,aa(set(D),set(list(D)),lists(D),Q))
           => ( X != aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xo) ) ) ) ).

% lists_image_witness
tff(fact_4160_in__prod__fst__sndI,axiom,
    ! [C: $tType,D: $tType,X: product_prod(C,D),A4: set(C),B3: set(D)] :
      ( member2(C,aa(product_prod(C,D),C,product_fst(C,D),X),A4)
     => ( member2(D,aa(product_prod(C,D),D,product_snd(C,D),X),B3)
       => member2(product_prod(C,D),X,product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3))) ) ) ).

% in_prod_fst_sndI
tff(fact_4161_R__subset__Field,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),product_Sigma(C,C,field2(C,R),aTP_Lamp_mj(set(product_prod(C,C)),fun(C,set(C)),R))) ).

% R_subset_Field
tff(fact_4162_listrel__refl__on,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] :
      ( refl_on(C,A4,R3)
     => refl_on(list(C),aa(set(C),set(list(C)),lists(C),A4),listrel(C,C,R3)) ) ).

% listrel_refl_on
tff(fact_4163_lists__eq__set,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),set(list(C)),lists(C),A4) = collect(list(C),aTP_Lamp_mk(set(C),fun(list(C),$o),A4)) ).

% lists_eq_set
tff(fact_4164_Rings_Omono__mult,axiom,
    ! [C: $tType] :
      ( ordered_semiring(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
         => order_mono(C,C,aa(C,fun(C,C),times_times(C),A3)) ) ) ).

% Rings.mono_mult
tff(fact_4165_Kleene__iter__lpfp,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [F: fun(C,C),P3: C,K: nat] :
          ( order_mono(C,C,F)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,F,P3)),P3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,compow(fun(C,C),K,F),bot_bot(C))),P3) ) ) ) ).

% Kleene_iter_lpfp
tff(fact_4166_lists__mono,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => aa(set(list(C)),$o,aa(set(list(C)),fun(set(list(C)),$o),ord_less_eq(set(list(C))),aa(set(C),set(list(C)),lists(C),A4)),aa(set(C),set(list(C)),lists(C),B3)) ) ).

% lists_mono
tff(fact_4167_finite__cartesian__product__iff,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( aa(set(product_prod(C,D)),$o,finite_finite2(product_prod(C,D)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))
    <=> ( ( A4 = bot_bot(set(C)) )
        | ( B3 = bot_bot(set(D)) )
        | ( aa(set(C),$o,finite_finite2(C),A4)
          & aa(set(D),$o,finite_finite2(D),B3) ) ) ) ).

% finite_cartesian_product_iff
tff(fact_4168_finite__cartesian__productD2,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( aa(set(product_prod(C,D)),$o,finite_finite2(product_prod(C,D)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))
     => ( ( A4 != bot_bot(set(C)) )
       => aa(set(D),$o,finite_finite2(D),B3) ) ) ).

% finite_cartesian_productD2
tff(fact_4169_finite__cartesian__productD1,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(D)] :
      ( aa(set(product_prod(C,D)),$o,finite_finite2(product_prod(C,D)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))
     => ( ( B3 != bot_bot(set(D)) )
       => aa(set(C),$o,finite_finite2(C),A4) ) ) ).

% finite_cartesian_productD1
tff(fact_4170_finite__SigmaI2,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: fun(C,set(D))] :
      ( aa(set(C),$o,finite_finite2(C),collect(C,aa(fun(C,set(D)),fun(C,$o),aTP_Lamp_ml(set(C),fun(fun(C,set(D)),fun(C,$o)),A4),B3)))
     => ( ! [A5: C] :
            ( member2(C,A5,A4)
           => aa(set(D),$o,finite_finite2(D),aa(C,set(D),B3,A5)) )
       => aa(set(product_prod(C,D)),$o,finite_finite2(product_prod(C,D)),product_Sigma(C,D,A4,B3)) ) ) ).

% finite_SigmaI2
tff(fact_4171_Restr__trancl__mono,axiom,
    ! [C: $tType,V: C,W: C,E5: set(product_prod(C,C)),U2: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),E5),product_Sigma(C,C,U2,aTP_Lamp_mg(set(C),fun(C,set(C)),U2)))))
     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),transitive_trancl(C,E5)) ) ).

% Restr_trancl_mono
tff(fact_4172_set__zip__cart,axiom,
    ! [C: $tType,D: $tType,X: product_prod(C,D),La: list(C),L_a: list(D)] :
      ( member2(product_prod(C,D),X,aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),La),L_a)))
     => member2(product_prod(C,D),X,product_Sigma(C,D,aa(list(C),set(C),set2(C),La),aTP_Lamp_md(list(D),fun(C,set(D)),L_a))) ) ).

% set_zip_cart
tff(fact_4173_Least__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D),S: set(C)] :
          ( order_mono(C,D,F)
         => ( ? [X3: C] :
                ( member2(C,X3,S)
                & ! [Xa4: C] :
                    ( member2(C,Xa4,S)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X3),Xa4) ) )
           => ( ord_Least(D,aa(set(C),fun(D,$o),aTP_Lamp_mm(fun(C,D),fun(set(C),fun(D,$o)),F),S)) = aa(C,D,F,ord_Least(C,aTP_Lamp_mn(set(C),fun(C,$o),S))) ) ) ) ) ).

% Least_mono
tff(fact_4174_lists__image,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] : aa(set(C),set(list(C)),lists(C),aa(set(D),set(C),image2(D,C,F),A4)) = aa(set(list(D)),set(list(C)),image2(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F)),aa(set(D),set(list(D)),lists(D),A4)) ).

% lists_image
tff(fact_4175_funpow__decreasing,axiom,
    ! [C: $tType] :
      ( ( lattice(C)
        & order_bot(C) )
     => ! [M2: nat,N: nat,F: fun(C,C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
         => ( order_mono(C,C,F)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,compow(fun(C,C),M2,F),bot_bot(C))),aa(C,C,compow(fun(C,C),N,F),bot_bot(C))) ) ) ) ).

% funpow_decreasing
tff(fact_4176_mono__Max__commute,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(D) )
     => ! [F: fun(C,D),A4: set(C)] :
          ( order_mono(C,D,F)
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( ( A4 != bot_bot(set(C)) )
             => ( aa(C,D,F,lattic643756798349783984er_Max(C,A4)) = lattic643756798349783984er_Max(D,aa(set(C),set(D),image2(C,D,F),A4)) ) ) ) ) ) ).

% mono_Max_commute
tff(fact_4177_mono__Min__commute,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(D) )
     => ! [F: fun(C,D),A4: set(C)] :
          ( order_mono(C,D,F)
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( ( A4 != bot_bot(set(C)) )
             => ( aa(C,D,F,lattic643756798350308766er_Min(C,A4)) = lattic643756798350308766er_Min(D,aa(set(C),set(D),image2(C,D,F),A4)) ) ) ) ) ) ).

% mono_Min_commute
tff(fact_4178_lfp__Kleene__iter,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(C,C),K: nat] :
          ( order_mono(C,C,F)
         => ( ( aa(C,C,compow(fun(C,C),aa(nat,nat,suc,K),F),bot_bot(C)) = aa(C,C,compow(fun(C,C),K,F),bot_bot(C)) )
           => ( complete_lattice_lfp(C,F) = aa(C,C,compow(fun(C,C),K,F),bot_bot(C)) ) ) ) ) ).

% lfp_Kleene_iter
tff(fact_4179_lists__of__len__fin2,axiom,
    ! [C: $tType,Pa: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),Pa)
     => aa(set(list(C)),$o,finite_finite2(list(C)),aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),inf_inf(set(list(C))),aa(set(C),set(list(C)),lists(C),Pa)),collect(list(C),aTP_Lamp_mo(nat,fun(list(C),$o),N)))) ) ).

% lists_of_len_fin2
tff(fact_4180_lists__of__len__fin1,axiom,
    ! [C: $tType,Pa: set(C),N: nat] :
      ( aa(set(C),$o,finite_finite2(C),Pa)
     => aa(set(list(C)),$o,finite_finite2(list(C)),aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),inf_inf(set(list(C))),aa(set(C),set(list(C)),lists(C),Pa)),collect(list(C),aTP_Lamp_mp(nat,fun(list(C),$o),N)))) ) ).

% lists_of_len_fin1
tff(fact_4181_card__cartesian__product__singleton,axiom,
    ! [C: $tType,D: $tType,X: C,A4: set(D)] : finite_card(product_prod(C,D),product_Sigma(C,D,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),aTP_Lamp_mb(set(D),fun(C,set(D)),A4))) = finite_card(D,A4) ).

% card_cartesian_product_singleton
tff(fact_4182_lists__length__Suc__eq,axiom,
    ! [C: $tType,A4: set(C),N: nat] : collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_mq(set(C),fun(nat,fun(list(C),$o)),A4),N)) = aa(set(product_prod(list(C),C)),set(list(C)),image2(product_prod(list(C),C),list(C),product_case_prod(list(C),C,list(C),aTP_Lamp_dm(list(C),fun(C,list(C))))),product_Sigma(list(C),C,collect(list(C),aa(nat,fun(list(C),$o),aTP_Lamp_dx(set(C),fun(nat,fun(list(C),$o)),A4),N)),aTP_Lamp_mr(set(C),fun(list(C),set(C)),A4))) ).

% lists_length_Suc_eq
tff(fact_4183_snd__image__times,axiom,
    ! [D: $tType,C: $tType,A4: set(D),B3: set(C)] :
      aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),product_Sigma(D,C,A4,aTP_Lamp_an(set(C),fun(D,set(C)),B3))) = $ite(A4 = bot_bot(set(D)),bot_bot(set(C)),B3) ).

% snd_image_times
tff(fact_4184_fst__image__times,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(D)] :
      aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3))) = $ite(B3 = bot_bot(set(D)),bot_bot(set(C)),A4) ).

% fst_image_times
tff(fact_4185_Sigma__empty2,axiom,
    ! [D: $tType,C: $tType,A4: set(C)] : product_Sigma(C,D,A4,aTP_Lamp_ms(C,set(D))) = bot_bot(set(product_prod(C,D))) ).

% Sigma_empty2
tff(fact_4186_Times__empty,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ( product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)) = bot_bot(set(product_prod(C,D))) )
    <=> ( ( A4 = bot_bot(set(C)) )
        | ( B3 = bot_bot(set(D)) ) ) ) ).

% Times_empty
tff(fact_4187_Sigma__empty1,axiom,
    ! [D: $tType,C: $tType,B3: fun(C,set(D))] : product_Sigma(C,D,bot_bot(set(C)),B3) = bot_bot(set(product_prod(C,D))) ).

% Sigma_empty1
tff(fact_4188_lfp__induct2,axiom,
    ! [C: $tType,D: $tType,A3: C,B2: D,F: fun(set(product_prod(C,D)),set(product_prod(C,D))),Pa: fun(C,fun(D,$o))] :
      ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2),complete_lattice_lfp(set(product_prod(C,D)),F))
     => ( order_mono(set(product_prod(C,D)),set(product_prod(C,D)),F)
       => ( ! [A5: C,B4: D] :
              ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A5),B4),aa(set(product_prod(C,D)),set(product_prod(C,D)),F,aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),complete_lattice_lfp(set(product_prod(C,D)),F)),collect(product_prod(C,D),product_case_prod(C,D,$o,Pa)))))
             => aa(D,$o,aa(C,fun(D,$o),Pa,A5),B4) )
         => aa(D,$o,aa(C,fun(D,$o),Pa,A3),B2) ) ) ) ).

% lfp_induct2
tff(fact_4189_mono__Int,axiom,
    ! [D: $tType,C: $tType,F: fun(set(C),set(D)),A4: set(C),B3: set(C)] :
      ( order_mono(set(C),set(D),F)
     => aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(C),set(D),F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),F,A4)),aa(set(C),set(D),F,B3))) ) ).

% mono_Int
tff(fact_4190_mono__Un,axiom,
    ! [D: $tType,C: $tType,F: fun(set(C),set(D)),A4: set(C),B3: set(C)] :
      ( order_mono(set(C),set(D),F)
     => aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),aa(set(C),set(D),F,A4)),aa(set(C),set(D),F,B3))),aa(set(C),set(D),F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))) ) ).

% mono_Un
tff(fact_4191_ord_Olexordp_Omono,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o))] : order_mono(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o)),aTP_Lamp_ka(fun(C,fun(C,$o)),fun(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o))),Less)) ).

% ord.lexordp.mono
tff(fact_4192_finite_Omono,axiom,
    ! [C: $tType] : order_mono(fun(set(C),$o),fun(set(C),$o),aTP_Lamp_ks(fun(set(C),$o),fun(set(C),$o))) ).

% finite.mono
tff(fact_4193_lexordp_Omono,axiom,
    ! [C: $tType] :
      ( ord(C)
     => order_mono(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o)),aTP_Lamp_jy(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o)))) ) ).

% lexordp.mono
tff(fact_4194_times__eq__iff,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D),C4: set(C),D2: set(D)] :
      ( ( product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)) = product_Sigma(C,D,C4,aTP_Lamp_mb(set(D),fun(C,set(D)),D2)) )
    <=> ( ( ( A4 = C4 )
          & ( B3 = D2 ) )
        | ( ( ( A4 = bot_bot(set(C)) )
            | ( B3 = bot_bot(set(D)) ) )
          & ( ( C4 = bot_bot(set(C)) )
            | ( D2 = bot_bot(set(D)) ) ) ) ) ) ).

% times_eq_iff
tff(fact_4195_Sigma__Int__distrib1,axiom,
    ! [D: $tType,C: $tType,I5: set(C),J4: set(C),C4: fun(C,set(D))] : product_Sigma(C,D,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),I5),J4),C4) = aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),product_Sigma(C,D,I5,C4)),product_Sigma(C,D,J4,C4)) ).

% Sigma_Int_distrib1
tff(fact_4196_Sigma__empty__iff,axiom,
    ! [C: $tType,D: $tType,I5: set(C),X5: fun(C,set(D))] :
      ( ( product_Sigma(C,D,I5,X5) = bot_bot(set(product_prod(C,D))) )
    <=> ! [X4: C] :
          ( member2(C,X4,I5)
         => ( aa(C,set(D),X5,X4) = bot_bot(set(D)) ) ) ) ).

% Sigma_empty_iff
tff(fact_4197_Times__Int__distrib1,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(C),C4: set(D)] : product_Sigma(C,D,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3),aTP_Lamp_mb(set(D),fun(C,set(D)),C4)) = aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),C4))),product_Sigma(C,D,B3,aTP_Lamp_mb(set(D),fun(C,set(D)),C4))) ).

% Times_Int_distrib1
tff(fact_4198_Sigma__Int__distrib2,axiom,
    ! [D: $tType,C: $tType,I5: set(C),A4: fun(C,set(D)),B3: fun(C,set(D))] : product_Sigma(C,D,I5,aa(fun(C,set(D)),fun(C,set(D)),aTP_Lamp_mt(fun(C,set(D)),fun(fun(C,set(D)),fun(C,set(D))),A4),B3)) = aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),product_Sigma(C,D,I5,A4)),product_Sigma(C,D,I5,B3)) ).

% Sigma_Int_distrib2
tff(fact_4199_Times__Int__Times,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D),C4: set(C),D2: set(D)] : aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3))),product_Sigma(C,D,C4,aTP_Lamp_mb(set(D),fun(C,set(D)),D2))) = product_Sigma(C,D,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4),aa(set(D),fun(C,set(D)),aTP_Lamp_mu(set(D),fun(set(D),fun(C,set(D))),B3),D2)) ).

% Times_Int_Times
tff(fact_4200_times__subset__iff,axiom,
    ! [C: $tType,D: $tType,A4: set(C),C4: set(D),B3: set(C),D2: set(D)] :
      ( aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),ord_less_eq(set(product_prod(C,D))),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),C4))),product_Sigma(C,D,B3,aTP_Lamp_mb(set(D),fun(C,set(D)),D2)))
    <=> ( ( A4 = bot_bot(set(C)) )
        | ( C4 = bot_bot(set(D)) )
        | ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
          & aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),C4),D2) ) ) ) ).

% times_subset_iff
tff(fact_4201_fst__image__Sigma,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: fun(C,set(D))] : aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),product_Sigma(C,D,A4,B3)) = collect(C,aa(fun(C,set(D)),fun(C,$o),aTP_Lamp_ml(set(C),fun(fun(C,set(D)),fun(C,$o)),A4),B3)) ).

% fst_image_Sigma
tff(fact_4202_Refl__Field__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( refl_on(C,field2(C,R3),R3)
     => ( field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),field2(C,R3)),A4) ) ) ).

% Refl_Field_Restr
tff(fact_4203_Refl__Field__Restr2,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( refl_on(C,field2(C,R3),R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),field2(C,R3))
       => ( field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) = A4 ) ) ) ).

% Refl_Field_Restr2
tff(fact_4204_Total__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( total_on(C,field2(C,R3),R3)
     => total_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% Total_Restr
tff(fact_4205_total__on__imp__Total__Restr,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] :
      ( total_on(C,A4,R3)
     => total_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% total_on_imp_Total_Restr
tff(fact_4206_mono__compose,axiom,
    ! [C: $tType,E2: $tType,D: $tType,F4: $tType] :
      ( ( order(E2)
        & order(C) )
     => ! [Q: fun(C,fun(D,E2)),F: fun(F4,D)] :
          ( order_mono(C,fun(D,E2),Q)
         => order_mono(C,fun(F4,E2),aa(fun(F4,D),fun(C,fun(F4,E2)),aTP_Lamp_mv(fun(C,fun(D,E2)),fun(fun(F4,D),fun(C,fun(F4,E2))),Q),F)) ) ) ).

% mono_compose
tff(fact_4207_Restr__subset,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),R3: set(product_prod(C,C))] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => ( aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3)))),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))) = aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))) ) ) ).

% Restr_subset
tff(fact_4208_Restr__Field,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,field2(C,R3),aTP_Lamp_mj(set(product_prod(C,C)),fun(C,set(C)),R3))) = R3 ).

% Restr_Field
tff(fact_4209_Field__Restr__subset,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))))),A4) ).

% Field_Restr_subset
tff(fact_4210_Refl__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( refl_on(C,field2(C,R3),R3)
     => refl_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% Refl_Restr
tff(fact_4211_def__lfp__induct,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: C,F: fun(C,C),Pa: C] :
          ( ( A4 = complete_lattice_lfp(C,F) )
         => ( order_mono(C,C,F)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,F,aa(C,C,aa(C,fun(C,C),inf_inf(C),A4),Pa))),Pa)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A4),Pa) ) ) ) ) ).

% def_lfp_induct
tff(fact_4212_lfp__induct,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(C,C),Pa: C] :
          ( order_mono(C,C,F)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,F,aa(C,C,aa(C,fun(C,C),inf_inf(C),complete_lattice_lfp(C,F)),Pa))),Pa)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),complete_lattice_lfp(C,F)),Pa) ) ) ) ).

% lfp_induct
tff(fact_4213_def__lfp__induct__set,axiom,
    ! [C: $tType,A4: set(C),F: fun(set(C),set(C)),A3: C,Pa: fun(C,$o)] :
      ( ( A4 = complete_lattice_lfp(set(C),F) )
     => ( order_mono(set(C),set(C),F)
       => ( member2(C,A3,A4)
         => ( ! [X2: C] :
                ( member2(C,X2,aa(set(C),set(C),F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),collect(C,Pa))))
               => aa(C,$o,Pa,X2) )
           => aa(C,$o,Pa,A3) ) ) ) ) ).

% def_lfp_induct_set
tff(fact_4214_lfp__induct__set,axiom,
    ! [C: $tType,A3: C,F: fun(set(C),set(C)),Pa: fun(C,$o)] :
      ( member2(C,A3,complete_lattice_lfp(set(C),F))
     => ( order_mono(set(C),set(C),F)
       => ( ! [X2: C] :
              ( member2(C,X2,aa(set(C),set(C),F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),complete_lattice_lfp(set(C),F)),collect(C,Pa))))
             => aa(C,$o,Pa,X2) )
         => aa(C,$o,Pa,A3) ) ) ) ).

% lfp_induct_set
tff(fact_4215_partition__filter__conv,axiom,
    ! [C: $tType,F: fun(C,$o),Xs: list(C)] : aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),F),Xs) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),F),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),comp($o,$o,C,fNot,F)),Xs)) ).

% partition_filter_conv
tff(fact_4216_partition__rev__filter__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Yes2: list(C),No2: list(C),Xs: list(C)] : partition_rev(C,Pa,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),No2),Xs) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs))),Yes2)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),comp($o,$o,C,fNot,Pa)),Xs))),No2)) ).

% partition_rev_filter_conv
tff(fact_4217_rtrancl__last__visit__node,axiom,
    ! [C: $tType,S4: C,S5: C,R: set(product_prod(C,C)),Sh: C] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),S4),S5),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
     => ( ( ( S4 != Sh )
          & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),S4),S5),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R),product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mw(C,fun(C,set(C)),Sh))))) )
        | ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),S4),Sh),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
          & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Sh),S5),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R),product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mw(C,fun(C,set(C)),Sh))))) ) ) ) ).

% rtrancl_last_visit_node
tff(fact_4218_image__split__eq__Sigma,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(E2,C),G: fun(E2,D),A4: set(E2)] : aa(set(E2),set(product_prod(C,D)),image2(E2,product_prod(C,D),aa(fun(E2,D),fun(E2,product_prod(C,D)),aTP_Lamp_mx(fun(E2,C),fun(fun(E2,D),fun(E2,product_prod(C,D))),F),G)),A4) = product_Sigma(C,D,aa(set(E2),set(C),image2(E2,C,F),A4),aa(set(E2),fun(C,set(D)),aa(fun(E2,D),fun(set(E2),fun(C,set(D))),aTP_Lamp_my(fun(E2,C),fun(fun(E2,D),fun(set(E2),fun(C,set(D)))),F),G),A4)) ).

% image_split_eq_Sigma
tff(fact_4219_vimageI,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A3: D,B2: C,B3: set(C)] :
      ( ( aa(D,C,F,A3) = B2 )
     => ( member2(C,B2,B3)
       => member2(D,A3,aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),B3)) ) ) ).

% vimageI
tff(fact_4220_vimage__eq,axiom,
    ! [C: $tType,D: $tType,A3: C,F: fun(C,D),B3: set(D)] :
      ( member2(C,A3,aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3))
    <=> member2(D,aa(C,D,F,A3),B3) ) ).

% vimage_eq
tff(fact_4221_vimage__ident,axiom,
    ! [C: $tType,Y5: set(C)] : aa(set(C),set(C),aa(fun(C,C),fun(set(C),set(C)),vimage(C,C),aTP_Lamp_ab(C,C)),Y5) = Y5 ).

% vimage_ident
tff(fact_4222_vimage__Collect__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),Pa: fun(D,$o)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),collect(D,Pa)) = collect(C,aa(fun(D,$o),fun(C,$o),aTP_Lamp_mz(fun(C,D),fun(fun(D,$o),fun(C,$o)),F),Pa)) ).

% vimage_Collect_eq
tff(fact_4223_vimage__empty,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),bot_bot(set(D))) = bot_bot(set(C)) ).

% vimage_empty
tff(fact_4224_vimage__UNIV,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),top_top(set(D))) = top_top(set(C)) ).

% vimage_UNIV
tff(fact_4225_vimage__Int,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(D),B3: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),A4)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3)) ).

% vimage_Int
tff(fact_4226_vimage__Un,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(D),B3: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),A4)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3)) ).

% vimage_Un
tff(fact_4227_listrel__rtrancl__refl,axiom,
    ! [C: $tType,Xs: list(C),R3: set(product_prod(C,C))] : member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Xs),listrel(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))) ).

% listrel_rtrancl_refl
tff(fact_4228_vimage__const,axiom,
    ! [D: $tType,C: $tType,C3: D,A4: set(D)] :
      aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),aTP_Lamp_ck(D,fun(C,D),C3)),A4) = $ite(member2(D,C3,A4),top_top(set(C)),bot_bot(set(C))) ).

% vimage_const
tff(fact_4229_image__vimage__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(C)] : aa(set(D),set(C),image2(D,C,F),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),A4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),aa(set(D),set(C),image2(D,C,F),top_top(set(D)))) ).

% image_vimage_eq
tff(fact_4230_vimage__if,axiom,
    ! [D: $tType,C: $tType,B3: set(C),C3: D,D3: D,A4: set(D)] :
      aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),aa(D,fun(C,D),aa(D,fun(D,fun(C,D)),aTP_Lamp_na(set(C),fun(D,fun(D,fun(C,D))),B3),C3),D3)),A4) = $ite(
        member2(D,C3,A4),
        $ite(member2(D,D3,A4),top_top(set(C)),B3),
        $ite(member2(D,D3,A4),aa(set(C),set(C),uminus_uminus(set(C)),B3),bot_bot(set(C))) ) ).

% vimage_if
tff(fact_4231_vimage__inter__cong,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,D),G: fun(C,D),Y: set(D)] :
      ( ! [W3: C] :
          ( member2(C,W3,S)
         => ( aa(C,D,F,W3) = aa(C,D,G,W3) ) )
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),Y)),S) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),G),Y)),S) ) ) ).

% vimage_inter_cong
tff(fact_4232_vimage__Diff,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(D),B3: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),minus_minus(set(D),A4,B3)) = minus_minus(set(C),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),A4),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3)) ).

% vimage_Diff
tff(fact_4233_converse__rtranclE_H,axiom,
    ! [C: $tType,U: C,V: C,R: set(product_prod(C,C))] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
     => ( ( U != V )
       => ~ ! [Vh: C] :
              ( ( U != Vh )
             => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),Vh),R)
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Vh),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R)) ) ) ) ) ).

% converse_rtranclE'
tff(fact_4234_listrel1__rtrancl__subset__rtrancl__listrel1,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : aa(set(product_prod(list(C),list(C))),$o,aa(set(product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),$o),ord_less_eq(set(product_prod(list(C),list(C)))),listrel1(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3))) ).

% listrel1_rtrancl_subset_rtrancl_listrel1
tff(fact_4235_vimageD,axiom,
    ! [C: $tType,D: $tType,A3: C,F: fun(C,D),A4: set(D)] :
      ( member2(C,A3,aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),A4))
     => member2(D,aa(C,D,F,A3),A4) ) ).

% vimageD
tff(fact_4236_vimageE,axiom,
    ! [C: $tType,D: $tType,A3: C,F: fun(C,D),B3: set(D)] :
      ( member2(C,A3,aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3))
     => member2(D,aa(C,D,F,A3),B3) ) ).

% vimageE
tff(fact_4237_vimageI2,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A3: D,A4: set(C)] :
      ( member2(C,aa(D,C,F,A3),A4)
     => member2(D,A3,aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),A4)) ) ).

% vimageI2
tff(fact_4238_vimage__Collect,axiom,
    ! [D: $tType,C: $tType,Pa: fun(D,$o),F: fun(C,D),Q: fun(C,$o)] :
      ( ! [X2: C] :
          ( aa(D,$o,Pa,aa(C,D,F,X2))
        <=> aa(C,$o,Q,X2) )
     => ( aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),collect(D,Pa)) = collect(C,Q) ) ) ).

% vimage_Collect
tff(fact_4239_listrel__rtrancl__eq__rtrancl__listrel1,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : listrel(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)) = aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3)) ).

% listrel_rtrancl_eq_rtrancl_listrel1
tff(fact_4240_vimage__Compl,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),uminus_uminus(set(D)),A4)) = aa(set(C),set(C),uminus_uminus(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),A4)) ).

% vimage_Compl
tff(fact_4241_rtrancl__mono__rightI,axiom,
    ! [C: $tType,S: set(product_prod(C,C)),S3: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),S),S3)
     => aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),S),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),S3)) ) ).

% rtrancl_mono_rightI
tff(fact_4242_rtrancl__mono__mp,axiom,
    ! [C: $tType,U2: set(product_prod(C,C)),V3: set(product_prod(C,C)),X: product_prod(C,C)] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),U2),V3)
     => ( member2(product_prod(C,C),X,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),U2))
       => member2(product_prod(C,C),X,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),V3)) ) ) ).

% rtrancl_mono_mp
tff(fact_4243_r__le__rtrancl,axiom,
    ! [C: $tType,S: set(product_prod(C,C))] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),S),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),S)) ).

% r_le_rtrancl
tff(fact_4244_subset__vimage__iff,axiom,
    ! [C: $tType,D: $tType,A4: set(C),F: fun(C,D),B3: set(D)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3))
    <=> ! [X4: C] :
          ( member2(C,X4,A4)
         => member2(D,aa(C,D,F,X4),B3) ) ) ).

% subset_vimage_iff
tff(fact_4245_vimage__mono,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(C),F: fun(D,C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
     => aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),A4)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),B3)) ) ).

% vimage_mono
tff(fact_4246_vimage__def,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),B3: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3) = collect(C,aa(set(D),fun(C,$o),aTP_Lamp_nb(fun(C,D),fun(set(D),fun(C,$o)),F),B3)) ).

% vimage_def
tff(fact_4247_in__rtrancl__insert,axiom,
    ! [C: $tType,X: product_prod(C,C),R: set(product_prod(C,C)),R3: product_prod(C,C)] :
      ( member2(product_prod(C,C),X,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
     => member2(product_prod(C,C),X,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),R3),R))) ) ).

% in_rtrancl_insert
tff(fact_4248_image__subset__iff__subset__vimage,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),image2(D,C,F),A4)),B3)
    <=> aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),A4),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),B3)) ) ).

% image_subset_iff_subset_vimage
tff(fact_4249_image__vimage__subset,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),image2(D,C,F),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),A4))),A4) ).

% image_vimage_subset
tff(fact_4250_vimage__singleton__eq,axiom,
    ! [C: $tType,D: $tType,A3: C,F: fun(C,D),B2: D] :
      ( member2(C,A3,aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),B2),bot_bot(set(D)))))
    <=> ( aa(C,D,F,A3) = B2 ) ) ).

% vimage_singleton_eq
tff(fact_4251_rtrancl__listrel1__ConsI2,axiom,
    ! [C: $tType,X: C,Y: C,R3: set(product_prod(C,C)),Xs: list(C),Ys: list(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3)))
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3))) ) ) ).

% rtrancl_listrel1_ConsI2
tff(fact_4252_rtrancl__sub__insert__rtrancl,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),X: product_prod(C,C)] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R)),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),X),R))) ).

% rtrancl_sub_insert_rtrancl
tff(fact_4253_listrel__rtrancl__trans,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C)),Zs: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)))
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Ys),Zs),listrel(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)))
       => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Zs),listrel(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))) ) ) ).

% listrel_rtrancl_trans
tff(fact_4254_vimage__Times,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F: fun(C,product_prod(D,E2)),A4: set(D),B3: set(E2)] : aa(set(product_prod(D,E2)),set(C),aa(fun(C,product_prod(D,E2)),fun(set(product_prod(D,E2)),set(C)),vimage(C,product_prod(D,E2)),F),product_Sigma(D,E2,A4,aTP_Lamp_nc(set(E2),fun(D,set(E2)),B3))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),comp(product_prod(D,E2),D,C,product_fst(D,E2),F)),A4)),aa(set(E2),set(C),aa(fun(C,E2),fun(set(E2),set(C)),vimage(C,E2),comp(product_prod(D,E2),E2,C,product_snd(D,E2),F)),B3)) ).

% vimage_Times
tff(fact_4255_Pair__vimage__Sigma,axiom,
    ! [D: $tType,C: $tType,X: D,A4: set(D),F: fun(D,set(C))] :
      aa(set(product_prod(D,C)),set(C),aa(fun(C,product_prod(D,C)),fun(set(product_prod(D,C)),set(C)),vimage(C,product_prod(D,C)),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),X)),product_Sigma(D,C,A4,F)) = $ite(member2(D,X,A4),aa(D,set(C),F,X),bot_bot(set(C))) ).

% Pair_vimage_Sigma
tff(fact_4256_surj__vimage__empty,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(C)] :
      ( ( aa(set(D),set(C),image2(D,C,F),top_top(set(D))) = top_top(set(C)) )
     => ( ( aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),A4) = bot_bot(set(D)) )
      <=> ( A4 = bot_bot(set(C)) ) ) ) ).

% surj_vimage_empty
tff(fact_4257_vimage__insert,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A3: D,B3: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D))))),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3)) ).

% vimage_insert
tff(fact_4258_finite__vimage__IntI,axiom,
    ! [C: $tType,D: $tType,F2: set(C),H: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,finite_finite2(C),F2)
     => ( inj_on(D,C,H,A4)
       => aa(set(D),$o,finite_finite2(D),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),H),F2)),A4)) ) ) ).

% finite_vimage_IntI
tff(fact_4259_inv__image__partition,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X2) )
     => ( ! [Y2: C] :
            ( member2(C,Y2,aa(list(C),set(C),set2(C),Ys))
           => ~ aa(C,$o,Pa,Y2) )
       => ( aa(set(product_prod(list(C),list(C))),set(list(C)),aa(fun(list(C),product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),set(list(C))),vimage(list(C),product_prod(list(C),list(C))),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa)),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),aa(product_prod(list(C),list(C)),fun(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C)))),insert2(product_prod(list(C),list(C))),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys)),bot_bot(set(product_prod(list(C),list(C)))))) = aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys) ) ) ) ).

% inv_image_partition
tff(fact_4260_trancl__union__outside,axiom,
    ! [C: $tType,V: C,W: C,E5: set(product_prod(C,C)),U2: set(product_prod(C,C))] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),E5),U2)))
     => ( ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),transitive_trancl(C,E5))
       => ? [X2: C,Y2: C] :
            ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),X2),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),E5),U2)))
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),Y2),U2)
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y2),W),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),E5),U2))) ) ) ) ).

% trancl_union_outside
tff(fact_4261_partition__rev_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),Yes2: list(C),No2: list(C),X: C,Xs: list(C)] :
      partition_rev(C,Pa,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),No2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = partition_rev(C,Pa,
        $ite(aa(C,$o,Pa,X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Yes2)),No2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),No2))),
        Xs) ).

% partition_rev.simps(2)
tff(fact_4262_partition__rev_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),Yes2: list(C),No2: list(C)] : partition_rev(C,Pa,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),No2),nil(C)) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),No2) ).

% partition_rev.simps(1)
tff(fact_4263_rtrancl__listrel1__ConsI1,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C)),X: C] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3)))
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Ys)),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3))) ) ).

% rtrancl_listrel1_ConsI1
tff(fact_4264_trancl__over__edgeE,axiom,
    ! [C: $tType,U: C,W: C,V1: C,V22: C,E5: set(product_prod(C,C))] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),W),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V1),V22)),E5)))
     => ( ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),W),transitive_trancl(C,E5))
       => ~ ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V1),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5))
           => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V22),W),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5)) ) ) ) ).

% trancl_over_edgeE
tff(fact_4265_rtrancl__listrel1__eq__len,axiom,
    ! [C: $tType,X: list(C),Y: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3)))
     => ( aa(list(C),nat,size_size(list(C)),X) = aa(list(C),nat,size_size(list(C)),Y) ) ) ).

% rtrancl_listrel1_eq_len
tff(fact_4266_listrel__reflcl__if__listrel1,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel1(C,R3))
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))) ) ).

% listrel_reflcl_if_listrel1
tff(fact_4267_rtrancl__listrel1__if__listrel,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),listrel(C,C,R3))
     => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),Ys),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3))) ) ).

% rtrancl_listrel1_if_listrel
tff(fact_4268_Restr__rtrancl__mono,axiom,
    ! [C: $tType,V: C,W: C,E5: set(product_prod(C,C)),U2: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),E5),product_Sigma(C,C,U2,aTP_Lamp_mg(set(C),fun(C,set(C)),U2)))))
     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5)) ) ).

% Restr_rtrancl_mono
tff(fact_4269_inf__img__fin__dom,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(D),set(C),image2(D,C,F),A4))
     => ( ~ aa(set(D),$o,finite_finite2(D),A4)
       => ? [X2: C] :
            ( member2(C,X2,aa(set(D),set(C),image2(D,C,F),A4))
            & ~ aa(set(D),$o,finite_finite2(D),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C))))) ) ) ) ).

% inf_img_fin_dom
tff(fact_4270_inf__img__fin__domE,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(D),set(C),image2(D,C,F),A4))
     => ( ~ aa(set(D),$o,finite_finite2(D),A4)
       => ~ ! [Y2: C] :
              ( member2(C,Y2,aa(set(D),set(C),image2(D,C,F),A4))
             => aa(set(D),$o,finite_finite2(D),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C))))) ) ) ) ).

% inf_img_fin_domE
tff(fact_4271_partition_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),nil(C)) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)) ).

% partition.simps(1)
tff(fact_4272_finite__finite__vimage__IntI,axiom,
    ! [C: $tType,D: $tType,F2: set(C),H: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,finite_finite2(C),F2)
     => ( ! [Y2: C] :
            ( member2(C,Y2,F2)
           => aa(set(D),$o,finite_finite2(D),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),H),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C))))),A4)) )
       => aa(set(D),$o,finite_finite2(D),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),H),F2)),A4)) ) ) ).

% finite_finite_vimage_IntI
tff(fact_4273_partition__P,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Yes2: list(C),No2: list(C)] :
      ( ( aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),Xs) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),No2) )
     => ( ! [X3: C] :
            ( member2(C,X3,aa(list(C),set(C),set2(C),Yes2))
           => aa(C,$o,Pa,X3) )
        & ! [X3: C] :
            ( member2(C,X3,aa(list(C),set(C),set2(C),No2))
           => ~ aa(C,$o,Pa,X3) ) ) ) ).

% partition_P
tff(fact_4274_rtrancl__mapI,axiom,
    ! [D: $tType,C: $tType,A3: C,B2: C,E5: set(product_prod(C,C)),F: fun(C,D)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5))
     => member2(product_prod(D,D),aa(D,product_prod(D,D),aa(D,fun(D,product_prod(D,D)),product_Pair(D,D),aa(C,D,F,A3)),aa(C,D,F,B2)),aa(set(product_prod(D,D)),set(product_prod(D,D)),transitive_rtrancl(D),aa(set(product_prod(C,C)),set(product_prod(D,D)),image2(product_prod(C,C),product_prod(D,D),pairself(C,D,F)),E5))) ) ).

% rtrancl_mapI
tff(fact_4275_listrel__subset__rtrancl__listrel1,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : aa(set(product_prod(list(C),list(C))),$o,aa(set(product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),$o),ord_less_eq(set(product_prod(list(C),list(C)))),listrel(C,C,R3)),aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),transitive_rtrancl(list(C)),listrel1(C,R3))) ).

% listrel_subset_rtrancl_listrel1
tff(fact_4276_vimage__eq__UN,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),B3: set(D)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),B3) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_nd(fun(C,D),fun(D,set(C)),F)),B3)) ).

% vimage_eq_UN
tff(fact_4277_partition_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] : aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(product_prod(list(C),list(C)),product_prod(list(C),list(C)),product_case_prod(list(C),list(C),product_prod(list(C),list(C)),aa(C,fun(list(C),fun(list(C),product_prod(list(C),list(C)))),aTP_Lamp_ne(fun(C,$o),fun(C,fun(list(C),fun(list(C),product_prod(list(C),list(C))))),Pa),X)),aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),Xs)) ).

% partition.simps(2)
tff(fact_4278_partition__filter1,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) ).

% partition_filter1
tff(fact_4279_rtrancl__last__touch,axiom,
    ! [C: $tType,Q2: C,Q4: C,R: set(product_prod(C,C)),S: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
     => ( member2(C,Q2,S)
       => ~ ! [Qt: C] :
              ( member2(C,Qt,S)
             => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Qt),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Qt),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),minus_minus(set(product_prod(C,C)),R,product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mg(set(C),fun(C,set(C)),S))))) ) ) ) ) ).

% rtrancl_last_touch
tff(fact_4280_rtrancl__last__visit_H,axiom,
    ! [C: $tType,Q2: C,Q4: C,R: set(product_prod(C,C)),S: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
     => ( ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),minus_minus(set(product_prod(C,C)),R,product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mg(set(C),fun(C,set(C)),S)))))
       => ~ ! [Qt: C] :
              ( member2(C,Qt,S)
             => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Qt),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Qt),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),minus_minus(set(product_prod(C,C)),R,product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mg(set(C),fun(C,set(C)),S))))) ) ) ) ) ).

% rtrancl_last_visit'
tff(fact_4281_inf__img__fin__dom_H,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(D),set(C),image2(D,C,F),A4))
     => ( ~ aa(set(D),$o,finite_finite2(D),A4)
       => ? [X2: C] :
            ( member2(C,X2,aa(set(D),set(C),image2(D,C,F),A4))
            & ~ aa(set(D),$o,finite_finite2(D),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C))))),A4)) ) ) ) ).

% inf_img_fin_dom'
tff(fact_4282_inf__img__fin__domE_H,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] :
      ( aa(set(C),$o,finite_finite2(C),aa(set(D),set(C),image2(D,C,F),A4))
     => ( ~ aa(set(D),$o,finite_finite2(D),A4)
       => ~ ! [Y2: C] :
              ( member2(C,Y2,aa(set(D),set(C),image2(D,C,F),A4))
             => aa(set(D),$o,finite_finite2(D),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C))))),A4)) ) ) ) ).

% inf_img_fin_domE'
tff(fact_4283_partition__rev_Oelims,axiom,
    ! [C: $tType,X: fun(C,$o),Xa: product_prod(list(C),list(C)),Xb: list(C),Y: product_prod(list(C),list(C))] :
      ( ( partition_rev(C,X,Xa,Xb) = Y )
     => ( ! [Yes: list(C),No: list(C)] :
            ( ( Xa = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No) )
           => ( ( Xb = nil(C) )
             => ( Y != aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No) ) ) )
       => ~ ! [Yes: list(C),No: list(C)] :
              ( ( Xa = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No) )
             => ! [X2: C,Xs2: list(C)] :
                  ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                 => ( Y != partition_rev(C,X,
                        $ite(aa(C,$o,X,X2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Yes)),No),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),No))),
                        Xs2) ) ) ) ) ) ).

% partition_rev.elims
tff(fact_4284_card__vimage__inj__on__le,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),D2: set(C),A4: set(D)] :
      ( inj_on(C,D,F,D2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),A4)),D2))),finite_card(D,A4)) ) ) ).

% card_vimage_inj_on_le
tff(fact_4285_partition__set,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Yes2: list(C),No2: list(C)] :
      ( ( aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),Xs) = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes2),No2) )
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Yes2)),aa(list(C),set(C),set2(C),No2)) = aa(list(C),set(C),set2(C),Xs) ) ) ).

% partition_set
tff(fact_4286_rtrancl__last__visit,axiom,
    ! [C: $tType,Q2: C,Q4: C,R: set(product_prod(C,C)),S: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
     => ( ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),minus_minus(set(product_prod(C,C)),R,product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mg(set(C),fun(C,set(C)),S)))))
       => ~ ! [Qt: C] :
              ( member2(C,Qt,S)
             => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),Qt),transitive_trancl(C,R))
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Qt),Q4),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),minus_minus(set(product_prod(C,C)),R,product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mg(set(C),fun(C,set(C)),S))))) ) ) ) ) ).

% rtrancl_last_visit
tff(fact_4287_trancl__multi__insert2,axiom,
    ! [C: $tType,A3: C,B2: C,R3: set(product_prod(C,C)),M2: C,X5: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),R3),product_Sigma(C,C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),M2),bot_bot(set(C))),aTP_Lamp_mg(set(C),fun(C,set(C)),X5)))))
     => ( ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),transitive_trancl(C,R3))
       => ~ ! [X2: C] :
              ( member2(C,X2,X5)
             => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),M2),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),B2),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)) ) ) ) ) ).

% trancl_multi_insert2
tff(fact_4288_trancl__multi__insert,axiom,
    ! [C: $tType,A3: C,B2: C,R3: set(product_prod(C,C)),X5: set(C),M2: C] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),R3),product_Sigma(C,C,X5,aTP_Lamp_nf(C,fun(C,set(C)),M2)))))
     => ( ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),transitive_trancl(C,R3))
       => ~ ! [X2: C] :
              ( member2(C,X2,X5)
             => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),X2),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3))
               => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),M2),B2),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)) ) ) ) ) ).

% trancl_multi_insert
tff(fact_4289_partition__filter2,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(fun(C,$o),fun(list(C),product_prod(list(C),list(C))),partition(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),comp($o,$o,C,fNot,Pa)),Xs) ).

% partition_filter2
tff(fact_4290_partition__rev_Opelims,axiom,
    ! [C: $tType,X: fun(C,$o),Xa: product_prod(list(C),list(C)),Xb: list(C),Y: product_prod(list(C),list(C))] :
      ( ( partition_rev(C,X,Xa,Xb) = Y )
     => ( accp(product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),partition_rev_rel(C),aa(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),aa(fun(C,$o),fun(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C)))),product_Pair(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),X),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),Xa),Xb)))
       => ( ! [Yes: list(C),No: list(C)] :
              ( ( Xa = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No) )
             => ( ( Xb = nil(C) )
               => ( ( Y = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No) )
                 => ~ accp(product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),partition_rev_rel(C),aa(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),aa(fun(C,$o),fun(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C)))),product_Pair(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),X),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No)),nil(C)))) ) ) )
         => ~ ! [Yes: list(C),No: list(C)] :
                ( ( Xa = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No) )
               => ! [X2: C,Xs2: list(C)] :
                    ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                   => ( ( Y = partition_rev(C,X,
                            $ite(aa(C,$o,X,X2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Yes)),No),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),No))),
                            Xs2) )
                     => ~ accp(product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),partition_rev_rel(C),aa(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),aa(fun(C,$o),fun(product_prod(product_prod(list(C),list(C)),list(C)),product_prod(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C)))),product_Pair(fun(C,$o),product_prod(product_prod(list(C),list(C)),list(C))),X),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Yes),No)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)))) ) ) ) ) ) ) ).

% partition_rev.pelims
tff(fact_4291_quicksort__by__rel_Osimps_I2_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C),X: C,Xs: list(C)] : aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(product_prod(list(C),list(C)),list(C),product_case_prod(list(C),list(C),list(C),aa(C,fun(list(C),fun(list(C),list(C))),aa(list(C),fun(C,fun(list(C),fun(list(C),list(C)))),aTP_Lamp_ng(fun(C,fun(C,$o)),fun(list(C),fun(C,fun(list(C),fun(list(C),list(C))))),R),Sl2),X)),partition_rev(C,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),R),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs)) ).

% quicksort_by_rel.simps(2)
tff(fact_4292_quicksort__by__rel_Oelims,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Xb: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),quicksort_by_rel(C,X,Xa),Xb) = Y )
     => ( ( ( Xb = nil(C) )
         => ( Y != Xa ) )
       => ~ ! [X2: C,Xs2: list(C)] :
              ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
             => ( Y != aa(product_prod(list(C),list(C)),list(C),product_case_prod(list(C),list(C),list(C),aa(C,fun(list(C),fun(list(C),list(C))),aa(list(C),fun(C,fun(list(C),fun(list(C),list(C)))),aTP_Lamp_ng(fun(C,fun(C,$o)),fun(list(C),fun(C,fun(list(C),fun(list(C),list(C))))),X),Xa),X2)),partition_rev(C,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),X),X2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs2)) ) ) ) ) ).

% quicksort_by_rel.elims
tff(fact_4293_inj__on__vimage__singleton,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C),A3: D] :
      ( inj_on(C,D,F,A4)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D))))),A4)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),the(C,aa(D,fun(C,$o),aa(set(C),fun(D,fun(C,$o)),aTP_Lamp_nh(fun(C,D),fun(set(C),fun(D,fun(C,$o))),F),A4),A3))),bot_bot(set(C)))) ) ).

% inj_on_vimage_singleton
tff(fact_4294_set__quicksort__by__rel,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C),Xs: list(C)] : aa(list(C),set(C),set2(C),aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),Xs)) = aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Sl2)) ).

% set_quicksort_by_rel
tff(fact_4295_quicksort__by__rel_Osimps_I1_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C)] : aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),nil(C)) = Sl2 ).

% quicksort_by_rel.simps(1)
tff(fact_4296_quicksort__by__rel__remove__acc__guared,axiom,
    ! [C: $tType,Sl2: list(C),R: fun(C,fun(C,$o)),Xs: list(C)] :
      ( ( Sl2 != nil(C) )
     => ( aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),quicksort_by_rel(C,R,nil(C)),Xs)),Sl2) ) ) ).

% quicksort_by_rel_remove_acc_guared
tff(fact_4297_quicksort__by__rel__remove__acc,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C),Xs: list(C)] : aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),quicksort_by_rel(C,R,nil(C)),Xs)),Sl2) ).

% quicksort_by_rel_remove_acc
tff(fact_4298_sorted__wrt__quicksort__by__rel,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] :
      ( ! [X2: C,Y2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
          | aa(C,$o,aa(C,fun(C,$o),R,Y2),X2) )
     => ( ! [X2: C,Y2: C,Z4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),R,X2),Y2)
           => ( aa(C,$o,aa(C,fun(C,$o),R,Y2),Z4)
             => aa(C,$o,aa(C,fun(C,$o),R,X2),Z4) ) )
       => sorted_wrt(C,R,aa(list(C),list(C),quicksort_by_rel(C,R,nil(C)),Xs)) ) ) ).

% sorted_wrt_quicksort_by_rel
tff(fact_4299_sorted__quicksort__by__rel,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),quicksort_by_rel(C,ord_less_eq(C),nil(C)),Xs)) ) ).

% sorted_quicksort_by_rel
tff(fact_4300_the__elem__def,axiom,
    ! [C: $tType,X5: set(C)] : the_elem(C,X5) = the(C,aTP_Lamp_ni(set(C),fun(C,$o),X5)) ).

% the_elem_def
tff(fact_4301_sort__quicksort__by__rel,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)) = quicksort_by_rel(C,ord_less_eq(C),nil(C)) ) ) ).

% sort_quicksort_by_rel
tff(fact_4302_inj__vimage__singleton,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A3: D] :
      ( inj_on(C,D,F,top_top(set(C)))
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D))))),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),the(C,aa(D,fun(C,$o),aTP_Lamp_nj(fun(C,D),fun(D,fun(C,$o)),F),A3))),bot_bot(set(C)))) ) ).

% inj_vimage_singleton
tff(fact_4303_quicksort__by__rel_Opsimps_I2_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C),X: C,Xs: list(C)] :
      ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Sl2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))))
     => ( aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(product_prod(list(C),list(C)),list(C),product_case_prod(list(C),list(C),list(C),aa(C,fun(list(C),fun(list(C),list(C))),aa(list(C),fun(C,fun(list(C),fun(list(C),list(C)))),aTP_Lamp_ng(fun(C,fun(C,$o)),fun(list(C),fun(C,fun(list(C),fun(list(C),list(C))))),R),Sl2),X)),partition_rev(C,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),R),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs)) ) ) ).

% quicksort_by_rel.psimps(2)
tff(fact_4304_quicksort__by__rel_Opelims,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Xb: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),quicksort_by_rel(C,X,Xa),Xb) = Y )
     => ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xa),Xb)))
       => ( ( ( Xb = nil(C) )
           => ( ( Y = Xa )
             => ~ accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xa),nil(C)))) ) )
         => ~ ! [X2: C,Xs2: list(C)] :
                ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ( ( Y = aa(product_prod(list(C),list(C)),list(C),product_case_prod(list(C),list(C),list(C),aa(C,fun(list(C),fun(list(C),list(C))),aa(list(C),fun(C,fun(list(C),fun(list(C),list(C)))),aTP_Lamp_ng(fun(C,fun(C,$o)),fun(list(C),fun(C,fun(list(C),fun(list(C),list(C))))),X),Xa),X2)),partition_rev(C,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),X),X2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs2)) )
                 => ~ accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),X),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)))) ) ) ) ) ) ).

% quicksort_by_rel.pelims
tff(fact_4305_quicksort__by__rel_Opinduct,axiom,
    ! [C: $tType,A0: fun(C,fun(C,$o)),A1: list(C),A22: list(C),Pa: fun(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)))] :
      ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),A0),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),A1),A22)))
     => ( ! [R4: fun(C,fun(C,$o)),Sl: list(C)] :
            ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Sl),nil(C))))
           => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),Pa,R4),Sl),nil(C)) )
       => ( ! [R4: fun(C,fun(C,$o)),Sl: list(C),X2: C,Xs2: list(C)] :
              ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R4),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Sl),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2))))
             => ( ! [Xa3: product_prod(list(C),list(C)),Xb2: list(C),Y4: list(C)] :
                    ( ( Xa3 = partition_rev(C,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),R4),X2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs2) )
                   => ( ( aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xb2),Y4) = Xa3 )
                     => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),Pa,R4),Sl),Y4) ) )
               => ( ! [Xa3: product_prod(list(C),list(C)),Xb2: list(C),Y4: list(C)] :
                      ( ( Xa3 = partition_rev(C,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),R4),X2),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),nil(C)),Xs2) )
                     => ( ( aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xb2),Y4) = Xa3 )
                       => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),Pa,R4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),quicksort_by_rel(C,R4,Sl),Y4))),Xb2) ) )
                 => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),Pa,R4),Sl),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)) ) ) )
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),Pa,A0),A1),A22) ) ) ) ).

% quicksort_by_rel.pinduct
tff(fact_4306_quicksort__by__rel_Opsimps_I1_J,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C)] :
      ( accp(product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),quicksort_by_rel_rel(C),aa(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C))),aa(fun(C,fun(C,$o)),fun(product_prod(list(C),list(C)),product_prod(fun(C,fun(C,$o)),product_prod(list(C),list(C)))),product_Pair(fun(C,fun(C,$o)),product_prod(list(C),list(C))),R),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Sl2),nil(C))))
     => ( aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),nil(C)) = Sl2 ) ) ).

% quicksort_by_rel.psimps(1)
tff(fact_4307_rtrancl__restrictI,axiom,
    ! [C: $tType,U: C,V: C,E5: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),minus_minus(set(product_prod(C,C)),E5,product_Sigma(C,C,top_top(set(C)),aTP_Lamp_mg(set(C),fun(C,set(C)),R)))))
     => ( ~ member2(C,U,R)
       => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),rel_restrict(C,E5,R))) ) ) ).

% rtrancl_restrictI
tff(fact_4308_Preorder__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_preorder_on(C,field2(C,R3),R3)
     => order_preorder_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% Preorder_Restr
tff(fact_4309_sum__mult__sum__if__inj,axiom,
    ! [C: $tType,E2: $tType,D: $tType] :
      ( semiring_0(E2)
     => ! [F: fun(C,E2),G: fun(D,E2),A4: set(C),B3: set(D)] :
          ( inj_on(product_prod(C,D),E2,product_case_prod(C,D,E2,aa(fun(D,E2),fun(C,fun(D,E2)),aTP_Lamp_nk(fun(C,E2),fun(fun(D,E2),fun(C,fun(D,E2))),F),G)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))
         => ( aa(E2,E2,aa(E2,fun(E2,E2),times_times(E2),aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7311177749621191930dd_sum(C,E2),F),A4)),aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7311177749621191930dd_sum(D,E2),G),B3)) = aa(set(E2),E2,aa(fun(E2,E2),fun(set(E2),E2),groups7311177749621191930dd_sum(E2,E2),id(E2)),collect(E2,aa(set(D),fun(E2,$o),aa(set(C),fun(set(D),fun(E2,$o)),aa(fun(D,E2),fun(set(C),fun(set(D),fun(E2,$o))),aTP_Lamp_nl(fun(C,E2),fun(fun(D,E2),fun(set(C),fun(set(D),fun(E2,$o)))),F),G),A4),B3))) ) ) ) ).

% sum_mult_sum_if_inj
tff(fact_4310_comp__fun__commute__on_Ofold__graph__insertE__aux,axiom,
    ! [C: $tType,D: $tType,S: set(C),F: fun(C,fun(D,D)),A4: set(C),Z2: D,Y: D,A3: C] :
      ( finite4664212375090638736ute_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),S)
       => ( finite_fold_graph(C,D,F,Z2,A4,Y)
         => ( member2(C,A3,A4)
           => ? [Y6: D] :
                ( ( Y = aa(D,D,aa(C,fun(D,D),F,A3),Y6) )
                & finite_fold_graph(C,D,F,Z2,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))),Y6) ) ) ) ) ) ).

% comp_fun_commute_on.fold_graph_insertE_aux
tff(fact_4311_list_Omap__id0,axiom,
    ! [C: $tType] : aa(fun(C,C),fun(list(C),list(C)),map(C,C),id(C)) = id(list(C)) ).

% list.map_id0
tff(fact_4312_rel__restrict__empty,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] : rel_restrict(C,R,bot_bot(set(C))) = R ).

% rel_restrict_empty
tff(fact_4313_rotate0,axiom,
    ! [C: $tType] : aa(nat,fun(list(C),list(C)),rotate(C),zero_zero(nat)) = id(list(C)) ).

% rotate0
tff(fact_4314_fold__graph_OemptyI,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,D)),Z2: D] : finite_fold_graph(C,D,F,Z2,bot_bot(set(C)),Z2) ).

% fold_graph.emptyI
tff(fact_4315_empty__fold__graphE,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,D)),Z2: D,X: D] :
      ( finite_fold_graph(C,D,F,Z2,bot_bot(set(C)),X)
     => ( X = Z2 ) ) ).

% empty_fold_graphE
tff(fact_4316_rel__restrict__notR_I2_J,axiom,
    ! [C: $tType,X: C,Y: C,A4: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),rel_restrict(C,A4,R))
     => ~ member2(C,Y,R) ) ).

% rel_restrict_notR(2)
tff(fact_4317_rel__restrict__notR_I1_J,axiom,
    ! [C: $tType,X: C,Y: C,A4: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),rel_restrict(C,A4,R))
     => ~ member2(C,X,R) ) ).

% rel_restrict_notR(1)
tff(fact_4318_rel__restrictI,axiom,
    ! [C: $tType,X: C,R: set(C),Y: C,E5: set(product_prod(C,C))] :
      ( ~ member2(C,X,R)
     => ( ~ member2(C,Y,R)
       => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),E5)
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),rel_restrict(C,E5,R)) ) ) ) ).

% rel_restrictI
tff(fact_4319_rel__restrict__lift,axiom,
    ! [C: $tType,X: C,Y: C,E5: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),rel_restrict(C,E5,R))
     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),E5) ) ).

% rel_restrict_lift
tff(fact_4320_List_Omap_Oidentity,axiom,
    ! [C: $tType] : aa(fun(C,C),fun(list(C),list(C)),map(C,C),aTP_Lamp_ab(C,C)) = id(list(C)) ).

% List.map.identity
tff(fact_4321_list_Omap__id,axiom,
    ! [C: $tType,T4: list(C)] : aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),map(C,C),id(C)),T4) = T4 ).

% list.map_id
tff(fact_4322_rel__restrict__mono,axiom,
    ! [C: $tType,A4: set(product_prod(C,C)),B3: set(product_prod(C,C)),R: set(C)] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),A4),B3)
     => aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),rel_restrict(C,A4,R)),rel_restrict(C,B3,R)) ) ).

% rel_restrict_mono
tff(fact_4323_rel__restrict__sub,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),rel_restrict(C,R,A4)),R) ).

% rel_restrict_sub
tff(fact_4324_rel__restrict__union,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C),B3: set(C)] : rel_restrict(C,R,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = rel_restrict(C,rel_restrict(C,R,A4),B3) ).

% rel_restrict_union
tff(fact_4325_finite__rel__restrict,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] :
      ( aa(set(product_prod(C,C)),$o,finite_finite2(product_prod(C,C)),R)
     => aa(set(product_prod(C,C)),$o,finite_finite2(product_prod(C,C)),rel_restrict(C,R,A4)) ) ).

% finite_rel_restrict
tff(fact_4326_foldr__Nil,axiom,
    ! [D: $tType,C: $tType,F: fun(D,fun(C,C))] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),nil(D)) = id(C) ).

% foldr_Nil
tff(fact_4327_fold__graph_Ocases,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,D)),Z2: D,A1: set(C),A22: D] :
      ( finite_fold_graph(C,D,F,Z2,A1,A22)
     => ( ( ( A1 = bot_bot(set(C)) )
         => ( A22 != Z2 ) )
       => ~ ! [X2: C,A8: set(C)] :
              ( ( A1 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),A8) )
             => ! [Y2: D] :
                  ( ( A22 = aa(D,D,aa(C,fun(D,D),F,X2),Y2) )
                 => ( ~ member2(C,X2,A8)
                   => ~ finite_fold_graph(C,D,F,Z2,A8,Y2) ) ) ) ) ) ).

% fold_graph.cases
tff(fact_4328_fold__graph_Osimps,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(D,D)),Z2: D,A1: set(C),A22: D] :
      ( finite_fold_graph(C,D,F,Z2,A1,A22)
    <=> ( ( ( A1 = bot_bot(set(C)) )
          & ( A22 = Z2 ) )
        | ? [X4: C,A9: set(C),Y3: D] :
            ( ( A1 = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),A9) )
            & ( A22 = aa(D,D,aa(C,fun(D,D),F,X4),Y3) )
            & ~ member2(C,X4,A9)
            & finite_fold_graph(C,D,F,Z2,A9,Y3) ) ) ) ).

% fold_graph.simps
tff(fact_4329_foldr__filter,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),Pa: fun(D,$o),Xs: list(D)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs)) = aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),aa(fun(D,$o),fun(D,fun(C,C)),aTP_Lamp_nm(fun(D,fun(C,C)),fun(fun(D,$o),fun(D,fun(C,C))),F),Pa)),Xs) ).

% foldr_filter
tff(fact_4330_rel__restrict__trancl__mem,axiom,
    ! [C: $tType,A3: C,B2: C,A4: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),transitive_trancl(C,rel_restrict(C,A4,R)))
     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),rel_restrict(C,transitive_trancl(C,A4),R)) ) ).

% rel_restrict_trancl_mem
tff(fact_4331_rel__restrict__trancl__notR_I1_J,axiom,
    ! [C: $tType,V: C,W: C,E5: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),transitive_trancl(C,rel_restrict(C,E5,R)))
     => ~ member2(C,V,R) ) ).

% rel_restrict_trancl_notR(1)
tff(fact_4332_rel__restrict__trancl__notR_I2_J,axiom,
    ! [C: $tType,V: C,W: C,E5: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V),W),transitive_trancl(C,rel_restrict(C,E5,R)))
     => ~ member2(C,W,R) ) ).

% rel_restrict_trancl_notR(2)
tff(fact_4333_rel__restrict__mono2,axiom,
    ! [C: $tType,R: set(C),S: set(C),A4: set(product_prod(C,C))] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),R),S)
     => aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),rel_restrict(C,A4,S)),rel_restrict(C,A4,R)) ) ).

% rel_restrict_mono2
tff(fact_4334_rel__restrict__trancl__sub,axiom,
    ! [C: $tType,A4: set(product_prod(C,C)),R: set(C)] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),transitive_trancl(C,rel_restrict(C,A4,R))),rel_restrict(C,transitive_trancl(C,A4),R)) ).

% rel_restrict_trancl_sub
tff(fact_4335_rel__restrict__def,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : rel_restrict(C,R,A4) = collect(product_prod(C,C),product_case_prod(C,C,$o,aa(set(C),fun(C,fun(C,$o)),aTP_Lamp_nn(set(product_prod(C,C)),fun(set(C),fun(C,fun(C,$o))),R),A4))) ).

% rel_restrict_def
tff(fact_4336_rel__restrict__Int__empty,axiom,
    ! [C: $tType,A4: set(C),R: set(product_prod(C,C))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),field2(C,R)) = bot_bot(set(C)) )
     => ( rel_restrict(C,R,A4) = R ) ) ).

% rel_restrict_Int_empty
tff(fact_4337_Field__rel__restrict,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),field2(C,rel_restrict(C,R,A4))),minus_minus(set(C),field2(C,R),A4)) ).

% Field_rel_restrict
tff(fact_4338_rel__restrict__compl,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),rel_restrict(C,R,A4)),rel_restrict(C,R,aa(set(C),set(C),uminus_uminus(set(C)),A4))) = bot_bot(set(product_prod(C,C))) ).

% rel_restrict_compl
tff(fact_4339_homo__rel__restrict__mono,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),B3: set(C),A4: set(C)] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3)))
     => aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),rel_restrict(C,R,A4)),product_Sigma(C,C,minus_minus(set(C),B3,A4),aa(set(C),fun(C,set(C)),aTP_Lamp_no(set(C),fun(set(C),fun(C,set(C))),B3),A4))) ) ).

% homo_rel_restrict_mono
tff(fact_4340_rel__restrict__alt__def,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : rel_restrict(C,R,A4) = aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R),product_Sigma(C,C,aa(set(C),set(C),uminus_uminus(set(C)),A4),aTP_Lamp_np(set(C),fun(C,set(C)),A4))) ).

% rel_restrict_alt_def
tff(fact_4341_rel__restrict__Sigma__sub,axiom,
    ! [C: $tType,A4: set(C),R: set(C)] : aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),rel_restrict(C,transitive_trancl(C,product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),R)),transitive_trancl(C,product_Sigma(C,C,minus_minus(set(C),A4,R),aa(set(C),fun(C,set(C)),aTP_Lamp_no(set(C),fun(set(C),fun(C,set(C))),A4),R)))) ).

% rel_restrict_Sigma_sub
tff(fact_4342_preorder__on__empty,axiom,
    ! [C: $tType] : order_preorder_on(C,bot_bot(set(C)),bot_bot(set(product_prod(C,C)))) ).

% preorder_on_empty
tff(fact_4343_INF__set__fold,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(D,C),Xs: list(D)] : aa(set(C),C,complete_Inf_Inf(C),aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),Xs))) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),comp(C,fun(C,C),D,inf_inf(C),F)),Xs),top_top(C)) ) ).

% INF_set_fold
tff(fact_4344_same__fst__trancl,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,$o),R: fun(C,set(product_prod(D,D)))] : transitive_trancl(product_prod(C,D),same_fst(C,D,Pa,R)) = same_fst(C,D,Pa,aTP_Lamp_nq(fun(C,set(product_prod(D,D))),fun(C,set(product_prod(D,D))),R)) ).

% same_fst_trancl
tff(fact_4345_SUP__set__fold,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [F: fun(D,C),Xs: list(D)] : aa(set(C),C,complete_Sup_Sup(C),aa(set(D),set(C),image2(D,C,F),aa(list(D),set(D),set2(D),Xs))) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),comp(C,fun(C,C),D,sup_sup(C),F)),Xs),bot_bot(C)) ) ).

% SUP_set_fold
tff(fact_4346_fold__append,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),Xs: list(D),Ys: list(D)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Xs),Ys)) = comp(C,C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),Ys),aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),Xs)) ).

% fold_append
tff(fact_4347_fold__replicate,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),N: nat,X: D] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),aa(D,list(D),aa(nat,fun(D,list(D)),replicate(D),N),X)) = compow(fun(C,C),N,aa(D,fun(C,C),F,X)) ).

% fold_replicate
tff(fact_4348_fold__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,fun(C,C)),S4: C] : aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),nil(D)),S4) = S4 ).

% fold_simps(1)
tff(fact_4349_fold__simps_I2_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,fun(C,C)),X: D,Xs: list(D),S4: C] : aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)),S4) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),Xs),aa(C,C,aa(D,fun(C,C),F,X),S4)) ).

% fold_simps(2)
tff(fact_4350_fold__invariant,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Q: fun(C,$o),Pa: fun(D,$o),S4: D,F: fun(C,fun(D,D))] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Q,X2) )
     => ( aa(D,$o,Pa,S4)
       => ( ! [X2: C,S6: D] :
              ( aa(C,$o,Q,X2)
             => ( aa(D,$o,Pa,S6)
               => aa(D,$o,Pa,aa(D,D,aa(C,fun(D,D),F,X2),S6)) ) )
         => aa(D,$o,Pa,aa(D,D,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),Xs),S4)) ) ) ) ).

% fold_invariant
tff(fact_4351_List_Ofold__cong,axiom,
    ! [D: $tType,C: $tType,A3: C,B2: C,Xs: list(D),Ys: list(D),F: fun(D,fun(C,C)),G: fun(D,fun(C,C))] :
      ( ( A3 = B2 )
     => ( ( Xs = Ys )
       => ( ! [X2: D] :
              ( member2(D,X2,aa(list(D),set(D),set2(D),Xs))
             => ( aa(D,fun(C,C),F,X2) = aa(D,fun(C,C),G,X2) ) )
         => ( aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),Xs),A3) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),G),Ys),B2) ) ) ) ) ).

% List.fold_cong
tff(fact_4352_foldl__conv__fold,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(D,C)),S4: C,Xs: list(D)] : aa(list(D),C,aa(C,fun(list(D),C),aa(fun(C,fun(D,C)),fun(C,fun(list(D),C)),foldl(C,D),F),S4),Xs) = aa(C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),aTP_Lamp_dc(fun(C,fun(D,C)),fun(D,fun(C,C)),F)),Xs),S4) ).

% foldl_conv_fold
tff(fact_4353_fold__Cons,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),X: D,Xs: list(D)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)) = comp(C,C,C,aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),Xs),aa(D,fun(C,C),F,X)) ).

% fold_Cons
tff(fact_4354_fold__commute,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Xs: list(C),H: fun(D,E2),G: fun(C,fun(D,D)),F: fun(C,fun(E2,E2))] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( comp(D,E2,D,H,aa(C,fun(D,D),G,X2)) = comp(E2,E2,D,aa(C,fun(E2,E2),F,X2),H) ) )
     => ( comp(D,E2,D,H,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),G),Xs)) = comp(E2,E2,D,aa(list(C),fun(E2,E2),aa(fun(C,fun(E2,E2)),fun(list(C),fun(E2,E2)),fold(C,E2),F),Xs),H) ) ) ).

% fold_commute
tff(fact_4355_fold__commute__apply,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Xs: list(C),H: fun(D,E2),G: fun(C,fun(D,D)),F: fun(C,fun(E2,E2)),S4: D] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( comp(D,E2,D,H,aa(C,fun(D,D),G,X2)) = comp(E2,E2,D,aa(C,fun(E2,E2),F,X2),H) ) )
     => ( aa(D,E2,H,aa(D,D,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),G),Xs),S4)) = aa(E2,E2,aa(list(C),fun(E2,E2),aa(fun(C,fun(E2,E2)),fun(list(C),fun(E2,E2)),fold(C,E2),F),Xs),aa(D,E2,H,S4)) ) ) ).

% fold_commute_apply
tff(fact_4356_fold__Nil,axiom,
    ! [D: $tType,C: $tType,F: fun(D,fun(C,C))] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),nil(D)) = id(C) ).

% fold_Nil
tff(fact_4357_fold__id,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),F: fun(C,fun(D,D))] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( aa(C,fun(D,D),F,X2) = id(D) ) )
     => ( aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),Xs) = id(D) ) ) ).

% fold_id
tff(fact_4358_fold__map,axiom,
    ! [D: $tType,C: $tType,E2: $tType,G: fun(D,fun(C,C)),F: fun(E2,D),Xs: list(E2)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),G),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),Xs)) = aa(list(E2),fun(C,C),aa(fun(E2,fun(C,C)),fun(list(E2),fun(C,C)),fold(E2,C),comp(D,fun(C,C),E2,G,F)),Xs) ).

% fold_map
tff(fact_4359_foldr__conv__fold,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),Xs: list(D)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),foldr(D,C),F),Xs) = aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),aa(list(D),list(D),rev(D),Xs)) ).

% foldr_conv_fold
tff(fact_4360_fold__filter,axiom,
    ! [C: $tType,D: $tType,F: fun(D,fun(C,C)),Pa: fun(D,$o),Xs: list(D)] : aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs)) = aa(list(D),fun(C,C),aa(fun(D,fun(C,C)),fun(list(D),fun(C,C)),fold(D,C),aa(fun(D,$o),fun(D,fun(C,C)),aTP_Lamp_nm(fun(D,fun(C,C)),fun(fun(D,$o),fun(D,fun(C,C))),F),Pa)),Xs) ).

% fold_filter
tff(fact_4361_union__set__fold,axiom,
    ! [C: $tType,Xs: list(C),A4: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(list(C),set(C),set2(C),Xs)),A4) = aa(set(C),set(C),aa(list(C),fun(set(C),set(C)),aa(fun(C,fun(set(C),set(C))),fun(list(C),fun(set(C),set(C))),fold(C,set(C)),insert2(C)),Xs),A4) ).

% union_set_fold
tff(fact_4362_rev__conv__fold,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),rev(C),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),fold(C,list(C)),cons(C)),Xs),nil(C)) ).

% rev_conv_fold
tff(fact_4363_fold__Cons__rev,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),fold(C,list(C)),cons(C)),Xs) = aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),rev(C),Xs)) ).

% fold_Cons_rev
tff(fact_4364_fold__rev,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,fun(D,D))] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( comp(D,D,D,aa(C,fun(D,D),F,Y2),aa(C,fun(D,D),F,X2)) = comp(D,D,D,aa(C,fun(D,D),F,X2),aa(C,fun(D,D),F,Y2)) ) ) )
     => ( aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),Xs) ) ) ).

% fold_rev
tff(fact_4365_List_Ounion__def,axiom,
    ! [C: $tType] : union(C) = aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),fold(C,list(C)),insert(C)) ).

% List.union_def
tff(fact_4366_foldr__fold,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,fun(D,D))] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( comp(D,D,D,aa(C,fun(D,D),F,Y2),aa(C,fun(D,D),F,X2)) = comp(D,D,D,aa(C,fun(D,D),F,X2),aa(C,fun(D,D),F,Y2)) ) ) )
     => ( aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),foldr(C,D),F),Xs) = aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),Xs) ) ) ).

% foldr_fold
tff(fact_4367_fold__remove1__split,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),F: fun(C,fun(D,D)),X: C] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( comp(D,D,D,aa(C,fun(D,D),F,X2),aa(C,fun(D,D),F,Y2)) = comp(D,D,D,aa(C,fun(D,D),F,Y2),aa(C,fun(D,D),F,X2)) ) ) )
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => ( aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),Xs) = comp(D,D,D,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)),aa(C,fun(D,D),F,X)) ) ) ) ).

% fold_remove1_split
tff(fact_4368_minus__set__fold,axiom,
    ! [C: $tType,A4: set(C),Xs: list(C)] : minus_minus(set(C),A4,aa(list(C),set(C),set2(C),Xs)) = aa(set(C),set(C),aa(list(C),fun(set(C),set(C)),aa(fun(C,fun(set(C),set(C))),fun(list(C),fun(set(C),set(C))),fold(C,set(C)),remove(C)),Xs),A4) ).

% minus_set_fold
tff(fact_4369_sort__conv__fold,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),linorder_sort_key(C,C),aTP_Lamp_az(C,C)),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),fold(C,list(C)),linorder_insort_key(C,C,aTP_Lamp_az(C,C))),Xs),nil(C)) ) ).

% sort_conv_fold
tff(fact_4370_inter__coset__fold,axiom,
    ! [C: $tType,A4: set(C),Xs: list(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),coset(C,Xs)) = aa(set(C),set(C),aa(list(C),fun(set(C),set(C)),aa(fun(C,fun(set(C),set(C))),fun(list(C),fun(set(C),set(C))),fold(C,set(C)),remove(C)),Xs),A4) ).

% inter_coset_fold
tff(fact_4371_fold__append__concat__rev,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(list(C)),fun(list(C),list(C)),aa(fun(list(C),fun(list(C),list(C))),fun(list(list(C)),fun(list(C),list(C))),fold(list(C),list(C)),append(C)),Xss2) = aa(list(C),fun(list(C),list(C)),append(C),aa(list(list(C)),list(C),concat(C),aa(list(list(C)),list(list(C)),rev(list(C)),Xss2))) ).

% fold_append_concat_rev
tff(fact_4372_Sup__set__fold,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [Xs: list(C)] : aa(set(C),C,complete_Sup_Sup(C),aa(list(C),set(C),set2(C),Xs)) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),sup_sup(C)),Xs),bot_bot(C)) ) ).

% Sup_set_fold
tff(fact_4373_Inf__set__fold,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [Xs: list(C)] : aa(set(C),C,complete_Inf_Inf(C),aa(list(C),set(C),set2(C),Xs)) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),inf_inf(C)),Xs),top_top(C)) ) ).

% Inf_set_fold
tff(fact_4374_Inf__fin_Oset__eq__fold,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [X: C,Xs: list(C)] : aa(set(C),C,lattic7752659483105999362nf_fin(C),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),inf_inf(C)),Xs),X) ) ).

% Inf_fin.set_eq_fold
tff(fact_4375_Sup__fin_Oset__eq__fold,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [X: C,Xs: list(C)] : lattic5882676163264333800up_fin(C,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),sup_sup(C)),Xs),X) ) ).

% Sup_fin.set_eq_fold
tff(fact_4376_Max_Oset__eq__fold,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] : lattic643756798349783984er_Max(C,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),ord_max(C)),Xs),X) ) ).

% Max.set_eq_fold
tff(fact_4377_Min_Oset__eq__fold,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C,Xs: list(C)] : lattic643756798350308766er_Min(C,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),ord_min(C)),Xs),X) ) ).

% Min.set_eq_fold
tff(fact_4378_semilattice__set_Oset__eq__fold,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),X: C,Xs: list(C)] :
      ( lattic149705377957585745ce_set(C,F)
     => ( aa(set(C),C,lattic1715443433743089157tice_F(C,F),aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),F),Xs),X) ) ) ).

% semilattice_set.set_eq_fold
tff(fact_4379_sort__key__conv__fold,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [F: fun(C,D),Xs: list(C)] :
          ( inj_on(C,D,F,aa(list(C),set(C),set2(C),Xs))
         => ( aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(fun(C,fun(list(C),list(C))),fun(list(C),fun(list(C),list(C))),fold(C,list(C)),linorder_insort_key(C,D,F)),Xs),nil(C)) ) ) ) ).

% sort_key_conv_fold
tff(fact_4380_comp__fun__commute__on_Ofold__set__fold__remdups,axiom,
    ! [C: $tType,D: $tType,S: set(C),F: fun(C,fun(D,D)),Xs: list(C),Y: D] :
      ( finite4664212375090638736ute_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),S)
       => ( finite_fold(C,D,F,Y,aa(list(C),set(C),set2(C),Xs)) = aa(D,D,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),aa(list(C),list(C),remdups(C),Xs)),Y) ) ) ) ).

% comp_fun_commute_on.fold_set_fold_remdups
tff(fact_4381_linear__order__on__singleton,axiom,
    ! [C: $tType,X: C] : order_679001287576687338der_on(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),X)),bot_bot(set(product_prod(C,C))))) ).

% linear_order_on_singleton
tff(fact_4382_comp__fun__idem__on_Ofold__set__fold,axiom,
    ! [C: $tType,D: $tType,S: set(C),F: fun(C,fun(D,D)),Xs: list(C),Y: D] :
      ( finite673082921795544331dem_on(C,D,S,F)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Xs)),S)
       => ( finite_fold(C,D,F,Y,aa(list(C),set(C),set2(C),Xs)) = aa(D,D,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),fold(C,D),F),Xs),Y) ) ) ) ).

% comp_fun_idem_on.fold_set_fold
tff(fact_4383_list_Oin__rel,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),A3: list(C),B2: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),A3),B2)
    <=> ? [Z3: list(product_prod(C,D))] :
          ( member2(list(product_prod(C,D)),Z3,collect(list(product_prod(C,D)),aTP_Lamp_nr(fun(C,fun(D,$o)),fun(list(product_prod(C,D)),$o),R)))
          & ( aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Z3) = A3 )
          & ( aa(list(product_prod(C,D)),list(D),aa(fun(product_prod(C,D),D),fun(list(product_prod(C,D)),list(D)),map(product_prod(C,D),D),product_snd(C,D)),Z3) = B2 ) ) ) ).

% list.in_rel
tff(fact_4384_properties__for__sort__key,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Ys: list(C),Xs: list(C),F: fun(C,D)] :
          ( ( mset(C,Ys) = mset(C,Xs) )
         => ( ! [K2: C] :
                ( member2(C,K2,aa(list(C),set(C),set2(C),Ys))
               => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),aTP_Lamp_ns(fun(C,D),fun(C,fun(C,$o)),F),K2)),Ys) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(C,fun(C,$o),aTP_Lamp_ns(fun(C,D),fun(C,fun(C,$o)),F),K2)),Xs) ) )
           => ( sorted_wrt(D,ord_less_eq(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Ys))
             => ( aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs) = Ys ) ) ) ) ) ).

% properties_for_sort_key
tff(fact_4385_list__all2__Nil2,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),nil(D))
    <=> ( Xs = nil(C) ) ) ).

% list_all2_Nil2
tff(fact_4386_list__all2__Nil,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),nil(C)),Ys)
    <=> ( Ys = nil(D) ) ) ).

% list_all2_Nil
tff(fact_4387_mset__zero__iff,axiom,
    ! [C: $tType,X: list(C)] :
      ( ( mset(C,X) = zero_zero(multiset(C)) )
    <=> ( X = nil(C) ) ) ).

% mset_zero_iff
tff(fact_4388_mset__zero__iff__right,axiom,
    ! [C: $tType,X: list(C)] :
      ( ( zero_zero(multiset(C)) = mset(C,X) )
    <=> ( X = nil(C) ) ) ).

% mset_zero_iff_right
tff(fact_4389_list__all2__rev,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),rev(C),Xs)),aa(list(D),list(D),rev(D),Ys))
    <=> aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys) ) ).

% list_all2_rev
tff(fact_4390_mergesort__by__rel__permutes,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C)] : mset(C,aa(list(C),list(C),mergesort_by_rel(C,R),Xs)) = mset(C,Xs) ).

% mergesort_by_rel_permutes
tff(fact_4391_mset__mergesort__by__rel__merge,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] : mset(C,merges9089515139780605204_merge(C,R,Xs,Ys)) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),mset(C,Xs)),mset(C,Ys)) ).

% mset_mergesort_by_rel_merge
tff(fact_4392_quicksort__permutes,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C)] : mset(C,aa(list(C),list(C),linorder_quicksort(C),Xs)) = mset(C,Xs) ) ).

% quicksort_permutes
tff(fact_4393_quicksort__by__rel__permutes,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),Sl2: list(C),Xs: list(C)] : mset(C,aa(list(C),list(C),quicksort_by_rel(C,R,Sl2),Xs)) = mset(C,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Sl2)) ).

% quicksort_by_rel_permutes
tff(fact_4394_mset__mergesort__by__rel__split,axiom,
    ! [C: $tType,Xs1: list(C),Xs23: list(C),Xs: list(C)] : aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),mset(C,aa(product_prod(list(C),list(C)),list(C),product_fst(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),Xs)))),mset(C,aa(product_prod(list(C),list(C)),list(C),product_snd(list(C),list(C)),merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs1),Xs23),Xs)))) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),mset(C,Xs)),mset(C,Xs1))),mset(C,Xs23)) ).

% mset_mergesort_by_rel_split
tff(fact_4395_list_Orel__cong,axiom,
    ! [C: $tType,D: $tType,X: list(C),Ya: list(C),Y: list(D),Xa: list(D),R: fun(C,fun(D,$o)),Ra: fun(C,fun(D,$o))] :
      ( ( X = Ya )
     => ( ( Y = Xa )
       => ( ! [Z4: C,Yb: D] :
              ( member2(C,Z4,aa(list(C),set(C),set2(C),Ya))
             => ( member2(D,Yb,aa(list(D),set(D),set2(D),Xa))
               => ( aa(D,$o,aa(C,fun(D,$o),R,Z4),Yb)
                <=> aa(D,$o,aa(C,fun(D,$o),Ra,Z4),Yb) ) ) )
         => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),X),Y)
          <=> aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Ra),Ya),Xa) ) ) ) ) ).

% list.rel_cong
tff(fact_4396_list_Orel__mono__strong,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),X: list(C),Y: list(D),Ra: fun(C,fun(D,$o))] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),X),Y)
     => ( ! [Z4: C,Yb: D] :
            ( member2(C,Z4,aa(list(C),set(C),set2(C),X))
           => ( member2(D,Yb,aa(list(D),set(D),set2(D),Y))
             => ( aa(D,$o,aa(C,fun(D,$o),R,Z4),Yb)
               => aa(D,$o,aa(C,fun(D,$o),Ra,Z4),Yb) ) ) )
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Ra),X),Y) ) ) ).

% list.rel_mono_strong
tff(fact_4397_list_Orel__refl__strong,axiom,
    ! [C: $tType,X: list(C),Ra: fun(C,fun(C,$o))] :
      ( ! [Z4: C] :
          ( member2(C,Z4,aa(list(C),set(C),set2(C),X))
         => aa(C,$o,aa(C,fun(C,$o),Ra,Z4),Z4) )
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),Ra),X),X) ) ).

% list.rel_refl_strong
tff(fact_4398_list__all2__same,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),Pa),Xs),Xs)
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,aa(C,fun(C,$o),Pa,X4),X4) ) ) ).

% list_all2_same
tff(fact_4399_list_Orel__inject_I2_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),X21: C,X22: list(C),Y21: D,Y22: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y21),Y22))
    <=> ( aa(D,$o,aa(C,fun(D,$o),R,X21),Y21)
        & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),X22),Y22) ) ) ).

% list.rel_inject(2)
tff(fact_4400_list_Orel__intros_I2_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),X21: C,Y21: D,X22: list(C),Y22: list(D)] :
      ( aa(D,$o,aa(C,fun(D,$o),R,X21),Y21)
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),X22),Y22)
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X21),X22)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y21),Y22)) ) ) ).

% list.rel_intros(2)
tff(fact_4401_list__all2__Cons,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),X: C,Xs: list(C),Y: D,Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys))
    <=> ( aa(D,$o,aa(C,fun(D,$o),Pa,X),Y)
        & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys) ) ) ).

% list_all2_Cons
tff(fact_4402_list__all2__Cons1,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),X: C,Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys)
    <=> ? [Z3: D,Zs2: list(D)] :
          ( ( Ys = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Z3),Zs2) )
          & aa(D,$o,aa(C,fun(D,$o),Pa,X),Z3)
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Zs2) ) ) ).

% list_all2_Cons1
tff(fact_4403_list__all2__Cons2,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Y: D,Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),Ys))
    <=> ? [Z3: C,Zs2: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z3),Zs2) )
          & aa(D,$o,aa(C,fun(D,$o),Pa,Z3),Y)
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Zs2),Ys) ) ) ).

% list_all2_Cons2
tff(fact_4404_list_Orel__mono,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,$o)),Ra: fun(C,fun(D,$o))] :
      ( aa(fun(C,fun(D,$o)),$o,aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),$o),ord_less_eq(fun(C,fun(D,$o))),R),Ra)
     => aa(fun(list(C),fun(list(D),$o)),$o,aa(fun(list(C),fun(list(D),$o)),fun(fun(list(C),fun(list(D),$o)),$o),ord_less_eq(fun(list(C),fun(list(D),$o))),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Ra)) ) ).

% list.rel_mono
tff(fact_4405_list__all2__appendI,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),A3: list(C),B2: list(D),C3: list(C),D3: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),A3),B2)
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),C3),D3)
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),A3),C3)),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),B2),D3)) ) ) ).

% list_all2_appendI
tff(fact_4406_list__all2__dropI,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),N: nat] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),Xs)),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),drop(D),N),Ys)) ) ).

% list_all2_dropI
tff(fact_4407_list__all2__update__cong,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),X: C,Y: D,I: nat] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => ( aa(D,$o,aa(C,fun(D,$o),Pa,X),Y)
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Xs),I),X)),aa(D,list(D),aa(nat,fun(D,list(D)),aa(list(D),fun(nat,fun(D,list(D))),list_update(D),Ys),I),Y)) ) ) ).

% list_all2_update_cong
tff(fact_4408_list__all2__lengthD,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) ) ) ).

% list_all2_lengthD
tff(fact_4409_list__all2__antisym,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Q: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( ! [X2: C,Y2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Pa,X2),Y2)
         => ( aa(C,$o,aa(C,fun(C,$o),Q,Y2),X2)
           => ( X2 = Y2 ) ) )
     => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),Pa),Xs),Ys)
       => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),Q),Ys),Xs)
         => ( Xs = Ys ) ) ) ) ).

% list_all2_antisym
tff(fact_4410_list__all2__trans,axiom,
    ! [D: $tType,C: $tType,E2: $tType,P1: fun(C,fun(D,$o)),P22: fun(D,fun(E2,$o)),P32: fun(C,fun(E2,$o)),As2: list(C),Bs: list(D),Cs2: list(E2)] :
      ( ! [A5: C,B4: D,C2: E2] :
          ( aa(D,$o,aa(C,fun(D,$o),P1,A5),B4)
         => ( aa(E2,$o,aa(D,fun(E2,$o),P22,B4),C2)
           => aa(E2,$o,aa(C,fun(E2,$o),P32,A5),C2) ) )
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),P1),As2),Bs)
       => ( aa(list(E2),$o,aa(list(D),fun(list(E2),$o),aa(fun(D,fun(E2,$o)),fun(list(D),fun(list(E2),$o)),list_all2(D,E2),P22),Bs),Cs2)
         => aa(list(E2),$o,aa(list(C),fun(list(E2),$o),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),P32),As2),Cs2) ) ) ) ).

% list_all2_trans
tff(fact_4411_list__all2__refl,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( ! [X2: C] : aa(C,$o,aa(C,fun(C,$o),Pa,X2),X2)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),Pa),Xs),Xs) ) ).

% list_all2_refl
tff(fact_4412_list__all2__mono,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),Q: fun(C,fun(D,$o))] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => ( ! [Xs2: C,Ys2: D] :
            ( aa(D,$o,aa(C,fun(D,$o),Pa,Xs2),Ys2)
           => aa(D,$o,aa(C,fun(D,$o),Q,Xs2),Ys2) )
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Q),Xs),Ys) ) ) ).

% list_all2_mono
tff(fact_4413_list__all2__eq,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs = Ys )
    <=> aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),fequal(C)),Xs),Ys) ) ).

% list_all2_eq
tff(fact_4414_list_Orel__refl,axiom,
    ! [C: $tType,Ra: fun(C,fun(C,$o)),X: list(C)] :
      ( ! [X2: C] : aa(C,$o,aa(C,fun(C,$o),Ra,X2),X2)
     => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),Ra),X),X) ) ).

% list.rel_refl
tff(fact_4415_list_Orel__eq,axiom,
    ! [C: $tType] : aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),fequal(C)) = fequal(list(C)) ).

% list.rel_eq
tff(fact_4416_list__all2__rev1,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),rev(C),Xs)),Ys)
    <=> aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),aa(list(D),list(D),rev(D),Ys)) ) ).

% list_all2_rev1
tff(fact_4417_list__all2__takeI,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),N: nat] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),Xs)),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),N),Ys)) ) ).

% list_all2_takeI
tff(fact_4418_mset_Osimps_I1_J,axiom,
    ! [C: $tType] : mset(C,nil(C)) = zero_zero(multiset(C)) ).

% mset.simps(1)
tff(fact_4419_list_Octr__transfer_I1_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o))] : aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),nil(C)),nil(D)) ).

% list.ctr_transfer(1)
tff(fact_4420_list__all2__map2,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Pa: fun(C,fun(D,$o)),As2: list(C),F: fun(E2,D),Bs: list(E2)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),As2),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),Bs))
    <=> aa(list(E2),$o,aa(list(C),fun(list(E2),$o),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),aa(fun(E2,D),fun(C,fun(E2,$o)),aTP_Lamp_nt(fun(C,fun(D,$o)),fun(fun(E2,D),fun(C,fun(E2,$o))),Pa),F)),As2),Bs) ) ).

% list_all2_map2
tff(fact_4421_list__all2__map1,axiom,
    ! [E2: $tType,C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),F: fun(E2,C),As2: list(E2),Bs: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),F),As2)),Bs)
    <=> aa(list(D),$o,aa(list(E2),fun(list(D),$o),aa(fun(E2,fun(D,$o)),fun(list(E2),fun(list(D),$o)),list_all2(E2,D),aa(fun(E2,C),fun(E2,fun(D,$o)),aTP_Lamp_nu(fun(C,fun(D,$o)),fun(fun(E2,C),fun(E2,fun(D,$o))),Pa),F)),As2),Bs) ) ).

% list_all2_map1
tff(fact_4422_list_Orel__map_I1_J,axiom,
    ! [E2: $tType,C: $tType,D: $tType,Sb: fun(C,fun(D,$o)),I: fun(E2,C),X: list(E2),Y: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Sb),aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),I),X)),Y)
    <=> aa(list(D),$o,aa(list(E2),fun(list(D),$o),aa(fun(E2,fun(D,$o)),fun(list(E2),fun(list(D),$o)),list_all2(E2,D),aa(fun(E2,C),fun(E2,fun(D,$o)),aTP_Lamp_nu(fun(C,fun(D,$o)),fun(fun(E2,C),fun(E2,fun(D,$o))),Sb),I)),X),Y) ) ).

% list.rel_map(1)
tff(fact_4423_list_Orel__map_I2_J,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Sa: fun(C,fun(D,$o)),X: list(C),G: fun(E2,D),Y: list(E2)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Sa),X),aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),G),Y))
    <=> aa(list(E2),$o,aa(list(C),fun(list(E2),$o),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),aa(fun(E2,D),fun(C,fun(E2,$o)),aTP_Lamp_nt(fun(C,fun(D,$o)),fun(fun(E2,D),fun(C,fun(E2,$o))),Sa),G)),X),Y) ) ).

% list.rel_map(2)
tff(fact_4424_list_Orel__distinct_I2_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),Y21: C,Y22: list(C)] : ~ aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y21),Y22)),nil(D)) ).

% list.rel_distinct(2)
tff(fact_4425_list_Orel__distinct_I1_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),Y21: D,Y22: list(D)] : ~ aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y21),Y22)) ).

% list.rel_distinct(1)
tff(fact_4426_list_Orel__cases,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),A3: list(C),B2: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),A3),B2)
     => ( ( ( A3 = nil(C) )
         => ( B2 != nil(D) ) )
       => ~ ! [X1: C,X23: list(C)] :
              ( ( A3 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),X23) )
             => ! [Y1: D,Y23: list(D)] :
                  ( ( B2 = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y1),Y23) )
                 => ( aa(D,$o,aa(C,fun(D,$o),R,X1),Y1)
                   => ~ aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),X23),Y23) ) ) ) ) ) ).

% list.rel_cases
tff(fact_4427_list_Orel__induct,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),X: list(C),Y: list(D),Q: fun(list(C),fun(list(D),$o))] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),X),Y)
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,nil(C)),nil(D))
       => ( ! [A21: C,A222: list(C),B21: D,B222: list(D)] :
              ( aa(D,$o,aa(C,fun(D,$o),R,A21),B21)
             => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,A222),B222)
               => aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A21),A222)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B21),B222)) ) )
         => aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,X),Y) ) ) ) ).

% list.rel_induct
tff(fact_4428_List_Olist__all2__induct,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),R: fun(list(C),fun(list(D),$o))] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),R,nil(C)),nil(D))
       => ( ! [X2: C,Xs2: list(C),Y2: D,Ys2: list(D)] :
              ( aa(D,$o,aa(C,fun(D,$o),Pa,X2),Y2)
             => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs2),Ys2)
               => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),R,Xs2),Ys2)
                 => aa(list(D),$o,aa(list(C),fun(list(D),$o),R,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y2),Ys2)) ) ) )
         => aa(list(D),$o,aa(list(C),fun(list(D),$o),R,Xs),Ys) ) ) ) ).

% List.list_all2_induct
tff(fact_4429_Misc_Olist__all2__induct,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),La: list(C),L_a: list(D),Q: fun(list(C),fun(list(D),$o))] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),La),L_a)
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,nil(C)),nil(D))
       => ( ! [X2: C,X7: D,Ls2: list(C),Ls4: list(D)] :
              ( aa(D,$o,aa(C,fun(D,$o),Pa,X2),X7)
             => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Ls2),Ls4)
               => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,Ls2),Ls4)
                 => aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Ls2)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X7),Ls4)) ) ) )
         => aa(list(D),$o,aa(list(C),fun(list(D),$o),Q,La),L_a) ) ) ) ).

% Misc.list_all2_induct
tff(fact_4430_list__all2__append,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),Pa: fun(C,fun(D,$o)),Us2: list(C),Vs: list(D)] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Us2)),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys),Vs))
      <=> ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Us2),Vs) ) ) ) ).

% list_all2_append
tff(fact_4431_list__all2__append1,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(C),Zs: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)),Zs)
    <=> ? [Us: list(D),Vs2: list(D)] :
          ( ( Zs = aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Us),Vs2) )
          & ( aa(list(D),nat,size_size(list(D)),Us) = aa(list(C),nat,size_size(list(C)),Xs) )
          & ( aa(list(D),nat,size_size(list(D)),Vs2) = aa(list(C),nat,size_size(list(C)),Ys) )
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Us)
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Ys),Vs2) ) ) ).

% list_all2_append1
tff(fact_4432_list__all2__append2,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),Zs: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),Ys),Zs))
    <=> ? [Us: list(C),Vs2: list(C)] :
          ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),Vs2) )
          & ( aa(list(C),nat,size_size(list(C)),Us) = aa(list(D),nat,size_size(list(D)),Ys) )
          & ( aa(list(C),nat,size_size(list(C)),Vs2) = aa(list(D),nat,size_size(list(D)),Zs) )
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Us),Ys)
          & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Vs2),Zs) ) ) ).

% list_all2_append2
tff(fact_4433_list__all2__conv__all__nth,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
        & ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
           => aa(D,$o,aa(C,fun(D,$o),Pa,aa(nat,C,nth(C,Xs),I2)),aa(nat,D,nth(D,Ys),I2)) ) ) ) ).

% list_all2_conv_all_nth
tff(fact_4434_list__all2__all__nthI,axiom,
    ! [C: $tType,D: $tType,A3: list(C),B2: list(D),Pa: fun(C,fun(D,$o))] :
      ( ( aa(list(C),nat,size_size(list(C)),A3) = aa(list(D),nat,size_size(list(D)),B2) )
     => ( ! [N7: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N7),aa(list(C),nat,size_size(list(C)),A3))
           => aa(D,$o,aa(C,fun(D,$o),Pa,aa(nat,C,nth(C,A3),N7)),aa(nat,D,nth(D,B2),N7)) )
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),A3),B2) ) ) ).

% list_all2_all_nthI
tff(fact_4435_list__all2__nthD2,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),P3: nat] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),P3),aa(list(D),nat,size_size(list(D)),Ys))
       => aa(D,$o,aa(C,fun(D,$o),Pa,aa(nat,C,nth(C,Xs),P3)),aa(nat,D,nth(D,Ys),P3)) ) ) ).

% list_all2_nthD2
tff(fact_4436_list__all2__nthD,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D),P3: nat] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),P3),aa(list(C),nat,size_size(list(C)),Xs))
       => aa(D,$o,aa(C,fun(D,$o),Pa,aa(nat,C,nth(C,Xs),P3)),aa(nat,D,nth(D,Ys),P3)) ) ) ).

% list_all2_nthD
tff(fact_4437_list_Orel__sel,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),A3: list(C),B2: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),A3),B2)
    <=> ( ( ( A3 = nil(C) )
        <=> ( B2 = nil(D) ) )
        & ( ( A3 != nil(C) )
         => ( ( B2 != nil(D) )
           => ( aa(D,$o,aa(C,fun(D,$o),R,aa(list(C),C,hd(C),A3)),aa(list(D),D,hd(D),B2))
              & aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),aa(list(C),list(C),tl(C),A3)),aa(list(D),list(D),tl(D),B2)) ) ) ) ) ) ).

% list.rel_sel
tff(fact_4438_lnear__order__on__empty,axiom,
    ! [C: $tType] : order_679001287576687338der_on(C,bot_bot(set(C)),bot_bot(set(product_prod(C,C)))) ).

% lnear_order_on_empty
tff(fact_4439_product__lists__set,axiom,
    ! [C: $tType,Xss2: list(list(C))] : aa(list(list(C)),set(list(C)),set2(list(C)),aa(list(list(C)),list(list(C)),product_lists(C),Xss2)) = collect(list(C),aTP_Lamp_nw(list(list(C)),fun(list(C),$o),Xss2)) ).

% product_lists_set
tff(fact_4440_list__all2I,axiom,
    ! [C: $tType,D: $tType,A3: list(C),B2: list(D),Pa: fun(C,fun(D,$o))] :
      ( ! [X2: product_prod(C,D)] :
          ( member2(product_prod(C,D),X2,aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),A3),B2)))
         => aa(product_prod(C,D),$o,product_case_prod(C,D,$o,Pa),X2) )
     => ( ( aa(list(C),nat,size_size(list(C)),A3) = aa(list(D),nat,size_size(list(D)),B2) )
       => aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),A3),B2) ) ) ).

% list_all2I
tff(fact_4441_Linear__order__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_679001287576687338der_on(C,field2(C,R3),R3)
     => order_679001287576687338der_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% Linear_order_Restr
tff(fact_4442_list__all2__iff,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,$o)),Xs: list(C),Ys: list(D)] :
      ( aa(list(D),$o,aa(list(C),fun(list(D),$o),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa),Xs),Ys)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
        & ! [X4: product_prod(C,D)] :
            ( member2(product_prod(C,D),X4,aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys)))
           => aa(product_prod(C,D),$o,product_case_prod(C,D,$o,Pa),X4) ) ) ) ).

% list_all2_iff
tff(fact_4443_sort__key__inj__key__eq,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Xs: list(C),Ys: list(C),F: fun(C,D)] :
          ( ( mset(C,Xs) = mset(C,Ys) )
         => ( inj_on(C,D,F,aa(list(C),set(C),set2(C),Xs))
           => ( sorted_wrt(D,ord_less_eq(D),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Ys))
             => ( aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),F),Xs) = Ys ) ) ) ) ) ).

% sort_key_inj_key_eq
tff(fact_4444_linear__order__on__Restr,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X: C] :
      ( order_679001287576687338der_on(C,A4,R3)
     => order_679001287576687338der_on(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),order_above(C,R3,X)),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,order_above(C,R3,X),aa(C,fun(C,set(C)),aTP_Lamp_nx(set(product_prod(C,C)),fun(C,fun(C,set(C))),R3),X)))) ) ).

% linear_order_on_Restr
tff(fact_4445_mset__zip__take__Cons__drop__twice,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),Ys: list(D),J: nat,X: C,Y: D] :
      ( ( aa(list(C),nat,size_size(list(C)),Xs) = aa(list(D),nat,size_size(list(D)),Ys) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),aa(list(C),nat,size_size(list(C)),Xs))
       => ( mset(product_prod(C,D),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),J),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),J),Xs)))),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),take(D),J),Ys)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),Y),aa(list(D),list(D),aa(nat,fun(list(D),list(D)),drop(D),J),Ys))))) = add_mset(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y),mset(product_prod(C,D),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),Ys))) ) ) ) ).

% mset_zip_take_Cons_drop_twice
tff(fact_4446_takeWhile__neq__rev,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),X)),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),rev(C),aa(list(C),list(C),tl(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),X)),Xs))) ) ) ) ).

% takeWhile_neq_rev
tff(fact_4447_stable__sort__key__def,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Sk: fun(fun(C,D),fun(list(C),list(C)))] :
          ( linord3483353639454293061rt_key(C,D,Sk)
        <=> ! [F6: fun(C,D),Xs3: list(C),K4: D] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(D,fun(C,$o),aTP_Lamp_iv(fun(C,D),fun(D,fun(C,$o)),F6),K4)),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),Sk,F6),Xs3)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),aa(D,fun(C,$o),aTP_Lamp_iv(fun(C,D),fun(D,fun(C,$o)),F6),K4)),Xs3) ) ) ).

% stable_sort_key_def
tff(fact_4448_predicate2I,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,$o)),Q: fun(C,fun(D,$o))] :
      ( ! [X2: C,Y2: D] :
          ( aa(D,$o,aa(C,fun(D,$o),Pa,X2),Y2)
         => aa(D,$o,aa(C,fun(D,$o),Q,X2),Y2) )
     => aa(fun(C,fun(D,$o)),$o,aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),$o),ord_less_eq(fun(C,fun(D,$o))),Pa),Q) ) ).

% predicate2I
tff(fact_4449_dropWhile__idem,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs) ).

% dropWhile_idem
tff(fact_4450_dropWhile__eq__Nil__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs) = nil(C) )
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) ) ) ).

% dropWhile_eq_Nil_conv
tff(fact_4451_dropWhile__append2,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X2) )
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Ys) ) ) ).

% dropWhile_append2
tff(fact_4452_dropWhile__append1,axiom,
    ! [C: $tType,X: C,Xs: list(C),Pa: fun(C,$o),Ys: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( ~ aa(C,$o,Pa,X)
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)),Ys) ) ) ) ).

% dropWhile_append1
tff(fact_4453_dropWhile__replicate,axiom,
    ! [C: $tType,Pa: fun(C,$o),N: nat,X: C] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = $ite(aa(C,$o,Pa,X),nil(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) ).

% dropWhile_replicate
tff(fact_4454_takeWhile__dropWhile__id,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)) = Xs ).

% takeWhile_dropWhile_id
tff(fact_4455_mset__single__iff__right,axiom,
    ! [C: $tType,X: C,Xs: list(C)] :
      ( ( add_mset(C,X,zero_zero(multiset(C))) = mset(C,Xs) )
    <=> ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ) ) ).

% mset_single_iff_right
tff(fact_4456_mset__single__iff,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( ( mset(C,Xs) = add_mset(C,X,zero_zero(multiset(C))) )
    <=> ( Xs = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ) ) ).

% mset_single_iff
tff(fact_4457_union__diff__assoc,axiom,
    ! [C: $tType,C4: multiset(C),B3: multiset(C),A4: multiset(C)] :
      ( ( minus_minus(multiset(C),C4,B3) = zero_zero(multiset(C)) )
     => ( minus_minus(multiset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3),C4) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),minus_minus(multiset(C),B3,C4)) ) ) ).

% union_diff_assoc
tff(fact_4458_mset__single__cases,axiom,
    ! [C: $tType,S4: C,C3: multiset(C),R6: C,C9: multiset(C)] :
      ( ( add_mset(C,S4,C3) = add_mset(C,R6,C9) )
     => ( ( ( S4 = R6 )
         => ( C3 != C9 ) )
       => ~ ( ( C9 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),minus_minus(multiset(C),C9,add_mset(C,S4,zero_zero(multiset(C))))) )
           => ( ( C3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,R6,zero_zero(multiset(C)))),minus_minus(multiset(C),C3,add_mset(C,R6,zero_zero(multiset(C))))) )
             => ( minus_minus(multiset(C),C3,add_mset(C,R6,zero_zero(multiset(C)))) != minus_minus(multiset(C),C9,add_mset(C,S4,zero_zero(multiset(C)))) ) ) ) ) ) ).

% mset_single_cases
tff(fact_4459_mset__single__cases_H,axiom,
    ! [C: $tType,S4: C,C3: multiset(C),R6: C,C9: multiset(C)] :
      ( ( add_mset(C,S4,C3) = add_mset(C,R6,C9) )
     => ( ( ( S4 = R6 )
         => ( C3 != C9 ) )
       => ~ ! [Cc: multiset(C)] :
              ( ( C9 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),Cc) )
             => ( ( C3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,R6,zero_zero(multiset(C)))),Cc) )
               => ( ( minus_minus(multiset(C),C9,add_mset(C,S4,zero_zero(multiset(C)))) = Cc )
                 => ( minus_minus(multiset(C),C3,add_mset(C,R6,zero_zero(multiset(C)))) != Cc ) ) ) ) ) ) ).

% mset_single_cases'
tff(fact_4460_mset__single__cases2,axiom,
    ! [C: $tType,S4: C,C3: multiset(C),R6: C,C9: multiset(C)] :
      ( ( add_mset(C,S4,C3) = add_mset(C,R6,C9) )
     => ( ( ( S4 = R6 )
         => ( C3 != C9 ) )
       => ~ ( ( C9 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),minus_minus(multiset(C),C9,add_mset(C,S4,zero_zero(multiset(C))))),add_mset(C,S4,zero_zero(multiset(C)))) )
           => ( ( C3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),minus_minus(multiset(C),C3,add_mset(C,R6,zero_zero(multiset(C))))),add_mset(C,R6,zero_zero(multiset(C)))) )
             => ( minus_minus(multiset(C),C3,add_mset(C,R6,zero_zero(multiset(C)))) != minus_minus(multiset(C),C9,add_mset(C,S4,zero_zero(multiset(C)))) ) ) ) ) ) ).

% mset_single_cases2
tff(fact_4461_mset__single__cases2_H,axiom,
    ! [C: $tType,S4: C,C3: multiset(C),R6: C,C9: multiset(C)] :
      ( ( add_mset(C,S4,C3) = add_mset(C,R6,C9) )
     => ( ( ( S4 = R6 )
         => ( C3 != C9 ) )
       => ~ ! [Cc: multiset(C)] :
              ( ( C9 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Cc),add_mset(C,S4,zero_zero(multiset(C)))) )
             => ( ( C3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Cc),add_mset(C,R6,zero_zero(multiset(C)))) )
               => ( ( minus_minus(multiset(C),C9,add_mset(C,S4,zero_zero(multiset(C)))) = Cc )
                 => ( minus_minus(multiset(C),C3,add_mset(C,R6,zero_zero(multiset(C)))) != Cc ) ) ) ) ) ) ).

% mset_single_cases2'
tff(fact_4462_mset__unplusm__dist__cases,axiom,
    ! [C: $tType,S4: C,A4: multiset(C),B3: multiset(C),C4: multiset(C)] :
      ( ( aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),A4) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B3),C4) )
     => ( ( ( B3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),minus_minus(multiset(C),B3,add_mset(C,S4,zero_zero(multiset(C))))) )
         => ( A4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),minus_minus(multiset(C),B3,add_mset(C,S4,zero_zero(multiset(C))))),C4) ) )
       => ~ ( ( C4 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),minus_minus(multiset(C),C4,add_mset(C,S4,zero_zero(multiset(C))))) )
           => ( A4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B3),minus_minus(multiset(C),C4,add_mset(C,S4,zero_zero(multiset(C))))) ) ) ) ) ).

% mset_unplusm_dist_cases
tff(fact_4463_mset__unplusm__dist__cases2,axiom,
    ! [C: $tType,B3: multiset(C),C4: multiset(C),S4: C,A4: multiset(C)] :
      ( ( aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B3),C4) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),A4) )
     => ( ( ( B3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),minus_minus(multiset(C),B3,add_mset(C,S4,zero_zero(multiset(C))))) )
         => ( A4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),minus_minus(multiset(C),B3,add_mset(C,S4,zero_zero(multiset(C))))),C4) ) )
       => ~ ( ( C4 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,S4,zero_zero(multiset(C)))),minus_minus(multiset(C),C4,add_mset(C,S4,zero_zero(multiset(C))))) )
           => ( A4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B3),minus_minus(multiset(C),C4,add_mset(C,S4,zero_zero(multiset(C))))) ) ) ) ) ).

% mset_unplusm_dist_cases2
tff(fact_4464_dropWhile_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),nil(C)) = nil(C) ).

% dropWhile.simps(1)
tff(fact_4465_mset__union__2__elem,axiom,
    ! [C: $tType,A3: C,B2: C,C3: C,M: multiset(C)] :
      ( ( add_mset(C,A3,add_mset(C,B2,zero_zero(multiset(C)))) = add_mset(C,C3,M) )
     => ( ( ( add_mset(C,A3,zero_zero(multiset(C))) = M )
          & ( B2 = C3 ) )
        | ( ( A3 = C3 )
          & ( add_mset(C,B2,zero_zero(multiset(C))) = M ) ) ) ) ).

% mset_union_2_elem
tff(fact_4466_mset__distrib,axiom,
    ! [C: $tType,A4: multiset(C),B3: multiset(C),M: multiset(C),N4: multiset(C)] :
      ( ( aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),M),N4) )
     => ~ ! [Am: multiset(C),An: multiset(C)] :
            ( ( A4 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Am),An) )
           => ! [Bm: multiset(C),Bn: multiset(C)] :
                ( ( B3 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Bm),Bn) )
               => ( ( M = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Am),Bm) )
                 => ( N4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),An),Bn) ) ) ) ) ) ).

% mset_distrib
tff(fact_4467_rev__predicate2D,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),X: C,Y: D,Q: fun(C,fun(D,$o))] :
      ( aa(D,$o,aa(C,fun(D,$o),Pa,X),Y)
     => ( aa(fun(C,fun(D,$o)),$o,aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),$o),ord_less_eq(fun(C,fun(D,$o))),Pa),Q)
       => aa(D,$o,aa(C,fun(D,$o),Q,X),Y) ) ) ).

% rev_predicate2D
tff(fact_4468_predicate2D,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Q: fun(C,fun(D,$o)),X: C,Y: D] :
      ( aa(fun(C,fun(D,$o)),$o,aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),$o),ord_less_eq(fun(C,fun(D,$o))),Pa),Q)
     => ( aa(D,$o,aa(C,fun(D,$o),Pa,X),Y)
       => aa(D,$o,aa(C,fun(D,$o),Q,X),Y) ) ) ).

% predicate2D
tff(fact_4469_distinct__dropWhile,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => aa(list(C),$o,distinct(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)) ) ).

% distinct_dropWhile
tff(fact_4470_dropWhile_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(aa(C,$o,Pa,X),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) ).

% dropWhile.simps(2)
tff(fact_4471_set__dropWhileD,axiom,
    ! [C: $tType,X: C,Pa: fun(C,$o),Xs: list(C)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)))
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% set_dropWhileD
tff(fact_4472_dropWhile__cong,axiom,
    ! [C: $tType,La: list(C),K: list(C),Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ( La = K )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),La))
           => ( aa(C,$o,Pa,X2)
            <=> aa(C,$o,Q,X2) ) )
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),La) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Q),K) ) ) ) ).

% dropWhile_cong
tff(fact_4473_mset_Osimps_I2_J,axiom,
    ! [C: $tType,A3: C,X: list(C)] : mset(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),X)) = add_mset(C,A3,mset(C,X)) ).

% mset.simps(2)
tff(fact_4474_dropWhile__append3,axiom,
    ! [C: $tType,Pa: fun(C,$o),Y: C,Xs: list(C),Ys: list(C)] :
      ( ~ aa(C,$o,Pa,Y)
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) ) ) ).

% dropWhile_append3
tff(fact_4475_length__dropWhile__le,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs))),aa(list(C),nat,size_size(list(C)),Xs)) ).

% length_dropWhile_le
tff(fact_4476_sorted__dropWhile,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Pa: fun(C,$o)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => sorted_wrt(C,ord_less_eq(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)) ) ) ).

% sorted_dropWhile
tff(fact_4477_hd__dropWhile,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs) != nil(C) )
     => ~ aa(C,$o,Pa,aa(list(C),C,hd(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs))) ) ).

% hd_dropWhile
tff(fact_4478_dropWhile__eq__self__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs) = Xs )
    <=> ( ( Xs = nil(C) )
        | ~ aa(C,$o,Pa,aa(list(C),C,hd(C),Xs)) ) ) ).

% dropWhile_eq_self_iff
tff(fact_4479_dropWhile__last,axiom,
    ! [C: $tType,X: C,Xs: list(C),Pa: fun(C,$o)] :
      ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
     => ( ~ aa(C,$o,Pa,X)
       => ( last(C,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)) = last(C,Xs) ) ) ) ).

% dropWhile_last
tff(fact_4480_dropWhile__map,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,$o),F: fun(D,C),Xs: list(D)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),dropWhile(D),comp(C,$o,D,Pa,F)),Xs)) ).

% dropWhile_map
tff(fact_4481_remdups__adj__Cons_H,axiom,
    ! [C: $tType,X: C,Xs: list(C)] : aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),aTP_Lamp_ad(C,fun(C,$o),X)),Xs))) ).

% remdups_adj_Cons'
tff(fact_4482_dropWhile__eq__Cons__conv,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Y: C,Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys) )
    <=> ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) )
        & ~ aa(C,$o,Pa,Y) ) ) ).

% dropWhile_eq_Cons_conv
tff(fact_4483_takeWhile__eq__filter,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)))
         => ~ aa(C,$o,Pa,X2) )
     => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs) = aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs) ) ) ).

% takeWhile_eq_filter
tff(fact_4484_dropWhile__eq__drop,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs))),Xs) ).

% dropWhile_eq_drop
tff(fact_4485_dropWhile__append,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C)] :
      aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = $ite(
        ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) ),
        aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Ys),
        aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)),Ys) ) ).

% dropWhile_append
tff(fact_4486_length__dropWhile__takeWhile,axiom,
    ! [C: $tType,X: nat,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)))),aa(list(C),nat,size_size(list(C)),Xs)) ) ).

% length_dropWhile_takeWhile
tff(fact_4487_remdups__adj__append__dropWhile,axiom,
    ! [C: $tType,Xs: list(C),Y: C,Ys: list(C)] : aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys))) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),nil(C))))),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),aTP_Lamp_ad(C,fun(C,$o),Y)),Ys))) ).

% remdups_adj_append_dropWhile
tff(fact_4488_remdups__adj__append_H_H,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( Xs != nil(C) )
     => ( aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),remdups_adj(C),Xs)),aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),aTP_Lamp_ny(list(C),fun(C,$o),Xs)),Ys))) ) ) ).

% remdups_adj_append''
tff(fact_4489_tl__remdups__adj,axiom,
    ! [C: $tType,Ys: list(C)] :
      ( ( Ys != nil(C) )
     => ( aa(list(C),list(C),tl(C),aa(list(C),list(C),remdups_adj(C),Ys)) = aa(list(C),list(C),remdups_adj(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),aTP_Lamp_nz(list(C),fun(C,$o),Ys)),aa(list(C),list(C),tl(C),Ys))) ) ) ).

% tl_remdups_adj
tff(fact_4490_stable__sort__key__sort__key,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => linord3483353639454293061rt_key(C,D,linorder_sort_key(C,D)) ) ).

% stable_sort_key_sort_key
tff(fact_4491_dropWhile__nth,axiom,
    ! [C: $tType,J: nat,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)))
     => ( aa(nat,C,nth(C,aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),Pa),Xs)),J) = aa(nat,C,nth(C,Xs),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),Pa),Xs)))) ) ) ).

% dropWhile_nth
tff(fact_4492_dropWhile__neq__rev,axiom,
    ! [C: $tType,Xs: list(C),X: C] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
       => ( aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),X)),aa(list(C),list(C),rev(C),Xs)) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),rev(C),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),X)),Xs))) ) ) ) ).

% dropWhile_neq_rev
tff(fact_4493_sorted__list__of__multiset__singleton,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: C] : linord6283353356039996273ltiset(C,add_mset(C,X,zero_zero(multiset(C)))) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C)) ) ).

% sorted_list_of_multiset_singleton
tff(fact_4494_shuffles_Opelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: set(list(C))] :
      ( ( aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),X),Xa) = Y )
     => ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Xa))
       => ( ( ( X = nil(C) )
           => ( ( Y = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),Xa),bot_bot(set(list(C)))) )
             => ~ accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Xa)) ) )
         => ( ( ( Xa = nil(C) )
             => ( ( Y = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),X),bot_bot(set(list(C)))) )
               => ~ accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),nil(C))) ) )
           => ~ ! [X2: C,Xs2: list(C)] :
                  ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
                 => ! [Y2: C,Ys2: list(C)] :
                      ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2) )
                     => ( ( Y = aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),sup_sup(set(list(C))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2))) )
                       => ~ accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2))) ) ) ) ) ) ) ) ).

% shuffles.pelims
tff(fact_4495_map__rec,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs) = aa(list(D),list(C),aa(fun(D,fun(list(D),fun(list(C),list(C)))),fun(list(D),list(C)),aa(list(C),fun(fun(D,fun(list(D),fun(list(C),list(C)))),fun(list(D),list(C))),rec_list(list(C),D),nil(C)),aTP_Lamp_oa(fun(D,C),fun(D,fun(list(D),fun(list(C),list(C)))),F)),Xs) ).

% map_rec
tff(fact_4496_set__rec,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),set(C),set2(C),Xs) = aa(list(C),set(C),aa(fun(C,fun(list(C),fun(set(C),set(C)))),fun(list(C),set(C)),aa(set(C),fun(fun(C,fun(list(C),fun(set(C),set(C)))),fun(list(C),set(C))),rec_list(set(C),C),bot_bot(set(C))),aTP_Lamp_ob(C,fun(list(C),fun(set(C),set(C))))),Xs) ).

% set_rec
tff(fact_4497_sorted__list__of__multiset__empty,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( linord6283353356039996273ltiset(C,zero_zero(multiset(C))) = nil(C) ) ) ).

% sorted_list_of_multiset_empty
tff(fact_4498_shuffles_Opinduct,axiom,
    ! [C: $tType,A0: list(C),A1: list(C),Pa: fun(list(C),fun(list(C),$o))] :
      ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),A0),A1))
     => ( ! [Ys2: list(C)] :
            ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys2))
           => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,nil(C)),Ys2) )
       => ( ! [Xs2: list(C)] :
              ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs2),nil(C)))
             => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,Xs2),nil(C)) )
         => ( ! [X2: C,Xs2: list(C),Y2: C,Ys2: list(C)] :
                ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)))
               => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,Xs2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2))
                 => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2)
                   => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Ys2)) ) ) )
           => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,A0),A1) ) ) ) ) ).

% shuffles.pinduct
tff(fact_4499_list_Osimps_I7_J,axiom,
    ! [C: $tType,D: $tType,F1: C,F22: fun(D,fun(list(D),fun(C,C))),X21: D,X22: list(D)] : aa(list(D),C,aa(fun(D,fun(list(D),fun(C,C))),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),fun(C,C))),fun(list(D),C)),rec_list(C,D),F1),F22),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X21),X22)) = aa(C,C,aa(list(D),fun(C,C),aa(D,fun(list(D),fun(C,C)),F22,X21),X22),aa(list(D),C,aa(fun(D,fun(list(D),fun(C,C))),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),fun(C,C))),fun(list(D),C)),rec_list(C,D),F1),F22),X22)) ).

% list.simps(7)
tff(fact_4500_list_Osimps_I6_J,axiom,
    ! [D: $tType,C: $tType,F1: C,F22: fun(D,fun(list(D),fun(C,C)))] : aa(list(D),C,aa(fun(D,fun(list(D),fun(C,C))),fun(list(D),C),aa(C,fun(fun(D,fun(list(D),fun(C,C))),fun(list(D),C)),rec_list(C,D),F1),F22),nil(D)) = F1 ).

% list.simps(6)
tff(fact_4501_rec__list__Cons__imp,axiom,
    ! [D: $tType,C: $tType,F: fun(list(C),D),F1: D,F22: fun(C,fun(list(C),fun(D,D))),X: C,Xs: list(C)] :
      ( ( F = aa(fun(C,fun(list(C),fun(D,D))),fun(list(C),D),aa(D,fun(fun(C,fun(list(C),fun(D,D))),fun(list(C),D)),rec_list(D,C),F1),F22) )
     => ( aa(list(C),D,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(D,D,aa(list(C),fun(D,D),aa(C,fun(list(C),fun(D,D)),F22,X),Xs),aa(list(C),D,F,Xs)) ) ) ).

% rec_list_Cons_imp
tff(fact_4502_rec__list__Nil__imp,axiom,
    ! [C: $tType,D: $tType,F: fun(list(C),D),F1: D,F22: fun(C,fun(list(C),fun(D,D)))] :
      ( ( F = aa(fun(C,fun(list(C),fun(D,D))),fun(list(C),D),aa(D,fun(fun(C,fun(list(C),fun(D,D))),fun(list(C),D)),rec_list(D,C),F1),F22) )
     => ( aa(list(C),D,F,nil(C)) = F1 ) ) ).

% rec_list_Nil_imp
tff(fact_4503_shuffles_Opsimps_I1_J,axiom,
    ! [C: $tType,Ys: list(C)] :
      ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys))
     => ( aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),nil(C)),Ys) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),Ys),bot_bot(set(list(C)))) ) ) ).

% shuffles.psimps(1)
tff(fact_4504_shuffles_Opsimps_I2_J,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs),nil(C)))
     => ( aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),nil(C)) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),Xs),bot_bot(set(list(C)))) ) ) ).

% shuffles.psimps(2)
tff(fact_4505_shuffles_Opsimps_I3_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Y: C,Ys: list(C)] :
      ( accp(product_prod(list(C),list(C)),shuffles_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)))
     => ( aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) = aa(set(list(C)),set(list(C)),aa(set(list(C)),fun(set(list(C)),set(list(C))),sup_sup(set(list(C))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)))),aa(set(list(C)),set(list(C)),image2(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y)),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys))) ) ) ).

% shuffles.psimps(3)
tff(fact_4506_list_Orec__o__map,axiom,
    ! [D: $tType,E2: $tType,C: $tType,G: D,Ga: fun(E2,fun(list(E2),fun(D,D))),F: fun(C,E2)] : comp(list(E2),D,list(C),aa(fun(E2,fun(list(E2),fun(D,D))),fun(list(E2),D),aa(D,fun(fun(E2,fun(list(E2),fun(D,D))),fun(list(E2),D)),rec_list(D,E2),G),Ga),aa(fun(C,E2),fun(list(C),list(E2)),map(C,E2),F)) = aa(fun(C,fun(list(C),fun(D,D))),fun(list(C),D),aa(D,fun(fun(C,fun(list(C),fun(D,D))),fun(list(C),D)),rec_list(D,C),G),aa(fun(C,E2),fun(C,fun(list(C),fun(D,D))),aTP_Lamp_oc(fun(E2,fun(list(E2),fun(D,D))),fun(fun(C,E2),fun(C,fun(list(C),fun(D,D)))),Ga),F)) ).

% list.rec_o_map
tff(fact_4507_revg_Opelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: list(C)] :
      ( ( revg(C,X,Xa) = Y )
     => ( accp(product_prod(list(C),list(C)),revg_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Xa))
       => ( ( ( X = nil(C) )
           => ( ( Y = Xa )
             => ~ accp(product_prod(list(C),list(C)),revg_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Xa)) ) )
         => ~ ! [A5: C,As: list(C)] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
               => ( ( Y = revg(C,As,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),Xa)) )
                 => ~ accp(product_prod(list(C),list(C)),revg_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),Xa)) ) ) ) ) ) ).

% revg.pelims
tff(fact_4508_merge_Opelims,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(C),Xa: list(C),Y: list(C)] :
          ( ( merge(C,X,Xa) = Y )
         => ( accp(product_prod(list(C),list(C)),merge_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Xa))
           => ( ( ( X = nil(C) )
               => ( ( Y = Xa )
                 => ~ accp(product_prod(list(C),list(C)),merge_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Xa)) ) )
             => ( ! [V2: C,Va2: list(C)] :
                    ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                   => ( ( Xa = nil(C) )
                     => ( ( Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                       => ~ accp(product_prod(list(C),list(C)),merge_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(C))) ) ) )
               => ~ ! [X1: C,L1: list(C)] :
                      ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),L1) )
                     => ! [X23: C,L2: list(C)] :
                          ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),L2) )
                         => ( ( Y = $ite(
                                  aa(C,$o,aa(C,fun(C,$o),ord_less(C),X1),X23),
                                  aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),merge(C,L1,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),L2))),
                                  $ite(X1 = X23,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),merge(C,L1,L2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),merge(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),L1),L2))) ) )
                           => ~ accp(product_prod(list(C),list(C)),merge_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),L1)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),L2))) ) ) ) ) ) ) ) ) ).

% merge.pelims
tff(fact_4509_merge__list_Opelims,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [X: list(list(C)),Xa: list(list(C)),Y: list(C)] :
          ( ( merge_list(C,X,Xa) = Y )
         => ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),X),Xa))
           => ( ( ( X = nil(list(C)) )
               => ( ( Xa = nil(list(C)) )
                 => ( ( Y = nil(C) )
                   => ~ accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),nil(list(C)))) ) ) )
             => ( ( ( X = nil(list(C)) )
                 => ! [L: list(C)] :
                      ( ( Xa = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))) )
                     => ( ( Y = L )
                       => ~ accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))))) ) ) )
               => ( ! [La2: list(C),Acc2: list(list(C))] :
                      ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2) )
                     => ( ( Xa = nil(list(C)) )
                       => ( ( Y = merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)) )
                         => ~ accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),nil(list(C)))) ) ) )
                 => ( ! [La2: list(C),Acc2: list(list(C))] :
                        ( ( X = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2) )
                       => ! [L: list(C)] :
                            ( ( Xa = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))) )
                           => ( ( Y = merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2))) )
                             => ~ accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C))))) ) ) )
                   => ~ ! [L1: list(C),L2: list(C),Ls2: list(list(C))] :
                          ( ( Xa = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L2),Ls2)) )
                         => ( ( Y = merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),merge(C,L1,L2)),X),Ls2) )
                           => ~ accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),X),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L2),Ls2)))) ) ) ) ) ) ) ) ) ) ).

% merge_list.pelims
tff(fact_4510_splice_Opinduct,axiom,
    ! [C: $tType,A0: list(C),A1: list(C),Pa: fun(list(C),fun(list(C),$o))] :
      ( accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),A0),A1))
     => ( ! [Ys2: list(C)] :
            ( accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys2))
           => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,nil(C)),Ys2) )
       => ( ! [X2: C,Xs2: list(C),Ys2: list(C)] :
              ( accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2))
             => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,Ys2),Xs2)
               => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Ys2) ) )
         => aa(list(C),$o,aa(list(C),fun(list(C),$o),Pa,A0),A1) ) ) ) ).

% splice.pinduct
tff(fact_4511_merge__list_Opsimps_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),nil(list(C))))
       => ( merge_list(C,nil(list(C)),nil(list(C))) = nil(C) ) ) ) ).

% merge_list.psimps(1)
tff(fact_4512_merge__list_Opsimps_I4_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),Acc22: list(list(C)),Lb: list(C)] :
          ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Lb),nil(list(C)))))
         => ( merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Lb),nil(list(C)))) = merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Lb),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22))) ) ) ) ).

% merge_list.psimps(4)
tff(fact_4513_merge__list_Opsimps_I3_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C),Acc22: list(list(C))] :
          ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22)),nil(list(C))))
         => ( merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22),nil(list(C))) = merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),Acc22)) ) ) ) ).

% merge_list.psimps(3)
tff(fact_4514_merge__list_Opsimps_I2_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: list(C)] :
          ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),nil(list(C)))))
         => ( merge_list(C,nil(list(C)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La),nil(list(C)))) = La ) ) ) ).

% merge_list.psimps(2)
tff(fact_4515_merge__list_Opinduct,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A0: list(list(C)),A1: list(list(C)),Pa: fun(list(list(C)),fun(list(list(C)),$o))] :
          ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),A0),A1))
         => ( ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),nil(list(C))))
             => aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,nil(list(C))),nil(list(C))) )
           => ( ! [L: list(C)] :
                  ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C)))))
                 => aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C)))) )
             => ( ! [La2: list(C),Acc2: list(list(C))] :
                    ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),nil(list(C))))
                   => ( aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2))
                     => aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),nil(list(C))) ) )
               => ( ! [La2: list(C),Acc2: list(list(C)),L: list(C)] :
                      ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C)))))
                     => ( aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,nil(list(C))),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)))
                       => aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),La2),Acc2)),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L),nil(list(C)))) ) )
                 => ( ! [Acc2: list(list(C)),L1: list(C),L2: list(C),Ls2: list(list(C))] :
                        ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),Acc2),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L2),Ls2))))
                       => ( aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),merge(C,L1,L2)),Acc2)),Ls2)
                         => aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,Acc2),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L1),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L2),Ls2))) ) )
                   => aa(list(list(C)),$o,aa(list(list(C)),fun(list(list(C)),$o),Pa,A0),A1) ) ) ) ) ) ) ) ).

% merge_list.pinduct
tff(fact_4516_merge__list_Opsimps_I5_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Acc22: list(list(C)),L12: list(C),L22: list(C),Ls: list(list(C))] :
          ( accp(product_prod(list(list(C)),list(list(C))),merge_list_rel(C),aa(list(list(C)),product_prod(list(list(C)),list(list(C))),aa(list(list(C)),fun(list(list(C)),product_prod(list(list(C)),list(list(C)))),product_Pair(list(list(C)),list(list(C))),Acc22),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L12),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L22),Ls))))
         => ( merge_list(C,Acc22,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L12),aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),L22),Ls))) = merge_list(C,aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),merge(C,L12,L22)),Acc22),Ls) ) ) ) ).

% merge_list.psimps(5)
tff(fact_4517_splice_Opelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),X),Xa) = Y )
     => ( accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Xa))
       => ( ( ( X = nil(C) )
           => ( ( Y = Xa )
             => ~ accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Xa)) ) )
         => ~ ! [X2: C,Xs2: list(C)] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ( ( Y = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Xa),Xs2)) )
                 => ~ accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xa)) ) ) ) ) ) ).

% splice.pelims
tff(fact_4518_splice_Opsimps_I1_J,axiom,
    ! [C: $tType,Ys: list(C)] :
      ( accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Ys))
     => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),nil(C)),Ys) = Ys ) ) ).

% splice.psimps(1)
tff(fact_4519_splice_Opsimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] :
      ( accp(product_prod(list(C),list(C)),splice_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys))
     => ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Ys),Xs)) ) ) ).

% splice.psimps(2)
tff(fact_4520_map__of__rev__distinct,axiom,
    ! [D: $tType,C: $tType,M2: list(product_prod(C,D))] :
      ( aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),M2))
     => ( map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),rev(product_prod(C,D)),M2)) = map_of(C,D,M2) ) ) ).

% map_of_rev_distinct
tff(fact_4521_split__Nil__iff,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Xs),Ys) = nil(C) )
    <=> ( ( Xs = nil(C) )
        & ( Ys = nil(C) ) ) ) ).

% split_Nil_iff
tff(fact_4522_splice__Nil2,axiom,
    ! [C: $tType,Xs: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Xs),nil(C)) = Xs ).

% splice_Nil2
tff(fact_4523_splice__in__shuffles,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : member2(list(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Xs),Ys),aa(list(C),set(list(C)),aa(list(C),fun(list(C),set(list(C))),shuffles(C),Xs),Ys)) ).

% splice_in_shuffles
tff(fact_4524_length__splice,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C)] : aa(list(C),nat,size_size(list(C)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Xs),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(C),nat,size_size(list(C)),Ys)) ).

% length_splice
tff(fact_4525_splice__replicate,axiom,
    ! [C: $tType,M2: nat,X: C,N: nat] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),M2),X)),aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),X)) = aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M2),N)),X) ).

% splice_replicate
tff(fact_4526_splice_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),Ys) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Ys),Xs)) ).

% splice.simps(2)
tff(fact_4527_splice_Osimps_I1_J,axiom,
    ! [C: $tType,Ys: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),nil(C)),Ys) = Ys ).

% splice.simps(1)
tff(fact_4528_splice_Oelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: list(C)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),X),Xa) = Y )
     => ( ( ( X = nil(C) )
         => ( Y != Xa ) )
       => ~ ! [X2: C,Xs2: list(C)] :
              ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
             => ( Y != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),splice(C),Xa),Xs2)) ) ) ) ) ).

% splice.elims
tff(fact_4529_Misc_Oran__distinct,axiom,
    ! [D: $tType,C: $tType,Al: list(product_prod(C,D))] :
      ( aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Al))
     => ( ran(C,D,map_of(C,D,Al)) = aa(set(product_prod(C,D)),set(D),image2(product_prod(C,D),D,product_snd(C,D)),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),Al)) ) ) ).

% Misc.ran_distinct
tff(fact_4530_map__of__map__to__set,axiom,
    ! [D: $tType,C: $tType,La: list(product_prod(C,D)),M2: fun(C,option(D))] :
      ( aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),La))
     => ( ( map_of(C,D,La) = M2 )
      <=> ( aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),La) = map_to_set(C,D,M2) ) ) ) ).

% map_of_map_to_set
tff(fact_4531_map__to__set__map__of,axiom,
    ! [D: $tType,C: $tType,La: list(product_prod(C,D))] :
      ( aa(list(C),$o,distinct(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),La))
     => ( map_to_set(C,D,map_of(C,D,La)) = aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),La) ) ) ).

% map_to_set_map_of
tff(fact_4532_map__of__distinct__upd4,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(product_prod(C,D)),Ys: list(product_prod(C,D)),Y: D] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs)))
     => ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Ys)))
       => ( map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),Ys)) = fun_upd(C,option(D),map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)),Ys))),X,none(D)) ) ) ) ).

% map_of_distinct_upd4
tff(fact_4533_map__to__set__empty,axiom,
    ! [D: $tType,C: $tType] : map_to_set(C,D,aTP_Lamp_od(C,option(D))) = bot_bot(set(product_prod(C,D))) ).

% map_to_set_empty
tff(fact_4534_map__to__set__ran,axiom,
    ! [C: $tType,D: $tType,M2: fun(D,option(C))] : ran(D,C,M2) = aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),map_to_set(D,C,M2)) ).

% map_to_set_ran
tff(fact_4535_map__to__set__empty__iff_I1_J,axiom,
    ! [C: $tType,D: $tType,M2: fun(C,option(D))] :
      ( ( map_to_set(C,D,M2) = bot_bot(set(product_prod(C,D))) )
    <=> ! [X4: C] : aa(C,option(D),M2,X4) = none(D) ) ).

% map_to_set_empty_iff(1)
tff(fact_4536_map__to__set__empty__iff_I2_J,axiom,
    ! [C: $tType,D: $tType,M2: fun(C,option(D))] :
      ( ( bot_bot(set(product_prod(C,D))) = map_to_set(C,D,M2) )
    <=> ! [X4: C] : aa(C,option(D),M2,X4) = none(D) ) ).

% map_to_set_empty_iff(2)
tff(fact_4537_map__of__None__filterD,axiom,
    ! [D: $tType,C: $tType,Xs: list(product_prod(D,C)),X: D,Pa: fun(product_prod(D,C),$o)] :
      ( ( aa(D,option(C),map_of(D,C,Xs),X) = none(C) )
     => ( aa(D,option(C),map_of(D,C,aa(list(product_prod(D,C)),list(product_prod(D,C)),aa(fun(product_prod(D,C),$o),fun(list(product_prod(D,C)),list(product_prod(D,C))),filter2(product_prod(D,C)),Pa),Xs)),X) = none(C) ) ) ).

% map_of_None_filterD
tff(fact_4538_inj__on__fst__map__to__set,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] : inj_on(product_prod(C,D),C,product_fst(C,D),map_to_set(C,D,M2)) ).

% inj_on_fst_map_to_set
tff(fact_4539_ran__map__of,axiom,
    ! [C: $tType,D: $tType,Xs: list(product_prod(D,C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),ran(D,C,map_of(D,C,Xs))),aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),aa(list(product_prod(D,C)),set(product_prod(D,C)),set2(product_prod(D,C)),Xs))) ).

% ran_map_of
tff(fact_4540_ran__empty,axiom,
    ! [D: $tType,C: $tType] : ran(D,C,aTP_Lamp_oe(D,option(C))) = bot_bot(set(C)) ).

% ran_empty
tff(fact_4541_rel__of__empty,axiom,
    ! [D: $tType,C: $tType,Pa: fun(product_prod(C,D),$o)] : rel_of(C,D,aTP_Lamp_od(C,option(D)),Pa) = bot_bot(set(product_prod(C,D))) ).

% rel_of_empty
tff(fact_4542_inf__None__2,axiom,
    ! [C: $tType] :
      ( inf(C)
     => ! [X: option(C)] : aa(option(C),option(C),aa(option(C),fun(option(C),option(C)),inf_inf(option(C)),X),none(C)) = none(C) ) ).

% inf_None_2
tff(fact_4543_inf__None__1,axiom,
    ! [C: $tType] :
      ( inf(C)
     => ! [Y: option(C)] : aa(option(C),option(C),aa(option(C),fun(option(C),option(C)),inf_inf(option(C)),none(C)),Y) = none(C) ) ).

% inf_None_1
tff(fact_4544_map__of__distinct__upd3,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(product_prod(C,D)),Ys: list(product_prod(C,D)),Y: D,Y7: D] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs)))
     => ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Ys)))
       => ( map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)),Ys))) = fun_upd(C,option(D),map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y7)),Ys))),X,aa(D,option(D),some(D),Y)) ) ) ) ).

% map_of_distinct_upd3
tff(fact_4545_map__of__distinct__upd2,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(product_prod(C,D)),Ys: list(product_prod(C,D)),Y: D] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs)))
     => ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Ys)))
       => ( map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)),Ys))) = fun_upd(C,option(D),map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),Ys)),X,aa(D,option(D),some(D),Y)) ) ) ) ).

% map_of_distinct_upd2
tff(fact_4546_map__to__set__upd,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),K: C,V: D] : map_to_set(C,D,fun_upd(C,option(D),M2,K,aa(D,option(D),some(D),V))) = aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(product_prod(C,D),fun(set(product_prod(C,D)),set(product_prod(C,D))),insert2(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),K),V)),minus_minus(set(product_prod(C,D)),map_to_set(C,D,M2),collect(product_prod(C,D),aTP_Lamp_of(C,fun(product_prod(C,D),$o),K)))) ).

% map_to_set_upd
tff(fact_4547_set__to__map__ran,axiom,
    ! [C: $tType,D: $tType,S: set(product_prod(D,C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),ran(D,C,set_to_map(D,C,S))),aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),S)) ).

% set_to_map_ran
tff(fact_4548_not__Some__eq2,axiom,
    ! [D: $tType,C: $tType,V: option(product_prod(C,D))] :
      ( ! [X4: C,Y3: D] : V != aa(product_prod(C,D),option(product_prod(C,D)),some(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X4),Y3))
    <=> ( V = none(product_prod(C,D)) ) ) ).

% not_Some_eq2
tff(fact_4549_set__to__map__empty,axiom,
    ! [C: $tType,D: $tType,X3: C] : aa(C,option(D),set_to_map(C,D,bot_bot(set(product_prod(C,D)))),X3) = none(D) ).

% set_to_map_empty
tff(fact_4550_inf__Some,axiom,
    ! [C: $tType] :
      ( inf(C)
     => ! [X: C,Y: C] : aa(option(C),option(C),aa(option(C),fun(option(C),option(C)),inf_inf(option(C)),aa(C,option(C),some(C),X)),aa(C,option(C),some(C),Y)) = aa(C,option(C),some(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),X),Y)) ) ).

% inf_Some
tff(fact_4551_map__update__eta__repair_I2_J,axiom,
    ! [C: $tType,D: $tType,M2: fun(D,option(C)),K: D,V: C] :
      ( ( aa(D,option(C),M2,K) = none(C) )
     => ( ran(D,C,aa(C,fun(D,option(C)),aa(D,fun(C,fun(D,option(C))),aTP_Lamp_og(fun(D,option(C)),fun(D,fun(C,fun(D,option(C)))),M2),K),V)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),ran(D,C,M2)) ) ) ).

% map_update_eta_repair(2)
tff(fact_4552_ran__nth__set__encoding__conv,axiom,
    ! [C: $tType,La: list(C)] : ran(nat,C,aTP_Lamp_oh(list(C),fun(nat,option(C)),La)) = aa(list(C),set(C),set2(C),La) ).

% ran_nth_set_encoding_conv
tff(fact_4553_le__some__optE,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [M2: C,X: option(C)] :
          ( aa(option(C),$o,aa(option(C),fun(option(C),$o),ord_less_eq(option(C)),aa(C,option(C),some(C),M2)),X)
         => ~ ! [M5: C] :
                ( ( X = aa(C,option(C),some(C),M5) )
               => ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),M2),M5) ) ) ) ).

% le_some_optE
tff(fact_4554_set__to__map__simp,axiom,
    ! [D: $tType,C: $tType,S: set(product_prod(C,D)),K: C,V: D] :
      ( inj_on(product_prod(C,D),C,product_fst(C,D),S)
     => ( ( aa(C,option(D),set_to_map(C,D,S),K) = aa(D,option(D),some(D),V) )
      <=> member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),K),V),S) ) ) ).

% set_to_map_simp
tff(fact_4555_Some__Sup,axiom,
    ! [C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(C,option(C),some(C),aa(set(C),C,complete_Sup_Sup(C),A4)) = aa(set(option(C)),option(C),complete_Sup_Sup(option(C)),aa(set(C),set(option(C)),image2(C,option(C),some(C)),A4)) ) ) ) ).

% Some_Sup
tff(fact_4556_map__to__set__inverse,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] : set_to_map(C,D,map_to_set(C,D,M2)) = M2 ).

% map_to_set_inverse
tff(fact_4557_map__to__set__def,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] : map_to_set(C,D,M2) = collect(product_prod(C,D),product_case_prod(C,D,$o,aTP_Lamp_oi(fun(C,option(D)),fun(C,fun(D,$o)),M2))) ).

% map_to_set_def
tff(fact_4558_Some__SUP,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [A4: set(C),F: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(D,option(D),some(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))) = aa(set(option(D)),option(D),complete_Sup_Sup(option(D)),aa(set(C),set(option(D)),image2(C,option(D),aTP_Lamp_oj(fun(C,D),fun(C,option(D)),F)),A4)) ) ) ) ).

% Some_SUP
tff(fact_4559_set__to__map__insert,axiom,
    ! [D: $tType,C: $tType,Kv: product_prod(C,D),S: set(product_prod(C,D))] :
      ( ~ member2(C,aa(product_prod(C,D),C,product_fst(C,D),Kv),aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),S))
     => ( set_to_map(C,D,aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(product_prod(C,D),fun(set(product_prod(C,D)),set(product_prod(C,D))),insert2(product_prod(C,D)),Kv),S)) = fun_upd(C,option(D),set_to_map(C,D,S),aa(product_prod(C,D),C,product_fst(C,D),Kv),aa(D,option(D),some(D),aa(product_prod(C,D),D,product_snd(C,D),Kv))) ) ) ).

% set_to_map_insert
tff(fact_4560_set__to__map__empty__iff_I1_J,axiom,
    ! [D: $tType,C: $tType,S: set(product_prod(C,D))] :
      ( ! [X4: C] : aa(C,option(D),set_to_map(C,D,S),X4) = none(D)
    <=> ( S = bot_bot(set(product_prod(C,D))) ) ) ).

% set_to_map_empty_iff(1)
tff(fact_4561_rel__of__def,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),Pa: fun(product_prod(C,D),$o)] : rel_of(C,D,M2,Pa) = collect(product_prod(C,D),product_case_prod(C,D,$o,aa(fun(product_prod(C,D),$o),fun(C,fun(D,$o)),aTP_Lamp_ok(fun(C,option(D)),fun(fun(product_prod(C,D),$o),fun(C,fun(D,$o))),M2),Pa))) ).

% rel_of_def
tff(fact_4562_set__to__map__empty__iff_I2_J,axiom,
    ! [D: $tType,C: $tType,S: set(product_prod(C,D))] :
      ( ( aTP_Lamp_od(C,option(D)) = set_to_map(C,D,S) )
    <=> ( S = bot_bot(set(product_prod(C,D))) ) ) ).

% set_to_map_empty_iff(2)
tff(fact_4563_map__of__zip__map,axiom,
    ! [C: $tType,D: $tType,Xs: list(C),F: fun(C,D),X3: C] :
      aa(C,option(D),map_of(C,D,aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Xs),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))),X3) = $ite(member2(C,X3,aa(list(C),set(C),set2(C),Xs)),aa(D,option(D),some(D),aa(C,D,F,X3)),none(D)) ).

% map_of_zip_map
tff(fact_4564_map__of__Some__split,axiom,
    ! [D: $tType,C: $tType,Xs: list(product_prod(D,C)),K: D,V: C] :
      ( ( aa(D,option(C),map_of(D,C,Xs),K) = aa(C,option(C),some(C),V) )
     => ? [Ys2: list(product_prod(D,C)),Zs3: list(product_prod(D,C))] :
          ( ( Xs = aa(list(product_prod(D,C)),list(product_prod(D,C)),aa(list(product_prod(D,C)),fun(list(product_prod(D,C)),list(product_prod(D,C))),append(product_prod(D,C)),Ys2),aa(list(product_prod(D,C)),list(product_prod(D,C)),aa(product_prod(D,C),fun(list(product_prod(D,C)),list(product_prod(D,C))),cons(product_prod(D,C)),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),K),V)),Zs3)) )
          & ( aa(D,option(C),map_of(D,C,Ys2),K) = none(C) ) ) ) ).

% map_of_Some_split
tff(fact_4565_set__to__map__inverse,axiom,
    ! [D: $tType,C: $tType,S: set(product_prod(C,D))] :
      ( inj_on(product_prod(C,D),C,product_fst(C,D),S)
     => ( map_to_set(C,D,set_to_map(C,D,S)) = S ) ) ).

% set_to_map_inverse
tff(fact_4566_map__of__Some__filter__not__in,axiom,
    ! [D: $tType,C: $tType,Xs: list(product_prod(D,C)),K: D,V: C,Pa: fun(product_prod(D,C),$o)] :
      ( ( aa(D,option(C),map_of(D,C,Xs),K) = aa(C,option(C),some(C),V) )
     => ( ~ aa(product_prod(D,C),$o,Pa,aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),K),V))
       => ( aa(list(D),$o,distinct(D),aa(list(product_prod(D,C)),list(D),aa(fun(product_prod(D,C),D),fun(list(product_prod(D,C)),list(D)),map(product_prod(D,C),D),product_fst(D,C)),Xs))
         => ( aa(D,option(C),map_of(D,C,aa(list(product_prod(D,C)),list(product_prod(D,C)),aa(fun(product_prod(D,C),$o),fun(list(product_prod(D,C)),list(product_prod(D,C))),filter2(product_prod(D,C)),Pa),Xs)),K) = none(C) ) ) ) ) ).

% map_of_Some_filter_not_in
tff(fact_4567_map__of__distinct__lookup,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(product_prod(C,D)),Ys: list(product_prod(C,D)),Y: D] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs)))
     => ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Ys)))
       => ( aa(C,option(D),map_of(C,D,aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(list(product_prod(C,D)),fun(list(product_prod(C,D)),list(product_prod(C,D))),append(product_prod(C,D)),Xs),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)),Ys))),X) = aa(D,option(D),some(D),Y) ) ) ) ).

% map_of_distinct_lookup
tff(fact_4568_map__upds__append1,axiom,
    ! [D: $tType,C: $tType,Xs: list(C),Ys: list(D),M2: fun(C,option(D)),X: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Xs)),aa(list(D),nat,size_size(list(D)),Ys))
     => ( map_upds(C,D,M2,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))),Ys) = fun_upd(C,option(D),map_upds(C,D,M2,Xs,Ys),X,aa(D,option(D),some(D),aa(nat,D,nth(D,Ys),aa(list(C),nat,size_size(list(C)),Xs)))) ) ) ).

% map_upds_append1
tff(fact_4569_extract__def,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : extract(C,Pa,Xs) = aa(list(C),option(product_prod(list(C),product_prod(C,list(C)))),aa(fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))),aa(option(product_prod(list(C),product_prod(C,list(C)))),fun(fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),case_list(option(product_prod(list(C),product_prod(C,list(C)))),C),none(product_prod(list(C),product_prod(C,list(C))))),aa(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),aTP_Lamp_ol(fun(C,$o),fun(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))))),Pa),Xs)),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),comp($o,$o,C,fNot,Pa)),Xs)) ).

% extract_def
tff(fact_4570_map__filter__map__filter,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Pa: fun(D,$o),Xs: list(D)] : aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs)) = map_filter(D,C,aa(fun(D,$o),fun(D,option(C)),aTP_Lamp_om(fun(D,C),fun(fun(D,$o),fun(D,option(C))),F),Pa),Xs) ).

% map_filter_map_filter
tff(fact_4571_extract__Some__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C),Y: C,Zs: list(C)] :
      ( ( extract(C,Pa,Xs) = aa(product_prod(list(C),product_prod(C,list(C))),option(product_prod(list(C),product_prod(C,list(C)))),some(product_prod(list(C),product_prod(C,list(C)))),aa(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C))),aa(list(C),fun(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C)))),product_Pair(list(C),product_prod(C,list(C))),Ys),aa(list(C),product_prod(C,list(C)),aa(C,fun(list(C),product_prod(C,list(C))),product_Pair(C,list(C)),Y),Zs))) )
    <=> ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)) )
        & aa(C,$o,Pa,Y)
        & ~ ? [X4: C] :
              ( member2(C,X4,aa(list(C),set(C),set2(C),Ys))
              & aa(C,$o,Pa,X4) ) ) ) ).

% extract_Some_iff
tff(fact_4572_map__upds__Nil1,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),Bs: list(D)] : map_upds(C,D,M2,nil(C),Bs) = M2 ).

% map_upds_Nil1
tff(fact_4573_map__upds__Nil2,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),As2: list(C)] : map_upds(C,D,M2,As2,nil(D)) = M2 ).

% map_upds_Nil2
tff(fact_4574_map__upds__Cons,axiom,
    ! [C: $tType,D: $tType,M2: fun(C,option(D)),A3: C,As2: list(C),B2: D,Bs: list(D)] : map_upds(C,D,M2,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),As2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B2),Bs)) = map_upds(C,D,fun_upd(C,option(D),M2,A3,aa(D,option(D),some(D),B2)),As2,Bs) ).

% map_upds_Cons
tff(fact_4575_extract__Nil__code,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : extract(C,Pa,nil(C)) = none(product_prod(list(C),product_prod(C,list(C)))) ).

% extract_Nil_code
tff(fact_4576_extract__None__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( extract(C,Pa,Xs) = none(product_prod(list(C),product_prod(C,list(C)))) )
    <=> ~ ? [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
            & aa(C,$o,Pa,X4) ) ) ).

% extract_None_iff
tff(fact_4577_map__filter__simps_I2_J,axiom,
    ! [D: $tType,C: $tType,F: fun(D,option(C))] : map_filter(D,C,F,nil(D)) = nil(C) ).

% map_filter_simps(2)
tff(fact_4578_set__map__filter,axiom,
    ! [C: $tType,D: $tType,G: fun(D,option(C)),Xs: list(D)] : aa(list(C),set(C),set2(C),map_filter(D,C,G,Xs)) = collect(C,aa(list(D),fun(C,$o),aTP_Lamp_on(fun(D,option(C)),fun(list(D),fun(C,$o)),G),Xs)) ).

% set_map_filter
tff(fact_4579_extract__SomeE,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C),Y: C,Zs: list(C)] :
      ( ( extract(C,Pa,Xs) = aa(product_prod(list(C),product_prod(C,list(C))),option(product_prod(list(C),product_prod(C,list(C)))),some(product_prod(list(C),product_prod(C,list(C)))),aa(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C))),aa(list(C),fun(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C)))),product_Pair(list(C),product_prod(C,list(C))),Ys),aa(list(C),product_prod(C,list(C)),aa(C,fun(list(C),product_prod(C,list(C))),product_Pair(C,list(C)),Y),Zs))) )
     => ( ( Xs = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Ys),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)) )
        & aa(C,$o,Pa,Y)
        & ~ ? [X3: C] :
              ( member2(C,X3,aa(list(C),set(C),set2(C),Ys))
              & aa(C,$o,Pa,X3) ) ) ) ).

% extract_SomeE
tff(fact_4580_extract__Cons__code,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      extract(C,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(aa(C,$o,Pa,X),aa(product_prod(list(C),product_prod(C,list(C))),option(product_prod(list(C),product_prod(C,list(C)))),some(product_prod(list(C),product_prod(C,list(C)))),aa(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C))),aa(list(C),fun(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C)))),product_Pair(list(C),product_prod(C,list(C))),nil(C)),aa(list(C),product_prod(C,list(C)),aa(C,fun(list(C),product_prod(C,list(C))),product_Pair(C,list(C)),X),Xs))),case_option(option(product_prod(list(C),product_prod(C,list(C)))),product_prod(list(C),product_prod(C,list(C))),none(product_prod(list(C),product_prod(C,list(C)))),product_case_prod(list(C),product_prod(C,list(C)),option(product_prod(list(C),product_prod(C,list(C)))),aTP_Lamp_op(C,fun(list(C),fun(product_prod(C,list(C)),option(product_prod(list(C),product_prod(C,list(C)))))),X)),extract(C,Pa,Xs))) ).

% extract_Cons_code
tff(fact_4581_find__dropWhile,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] : aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = aa(list(C),option(C),aa(fun(C,fun(list(C),option(C))),fun(list(C),option(C)),aa(option(C),fun(fun(C,fun(list(C),option(C))),fun(list(C),option(C))),case_list(option(C),C),none(C)),aTP_Lamp_oq(C,fun(list(C),option(C)))),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),dropWhile(C),comp($o,$o,C,fNot,Pa)),Xs)) ).

% find_dropWhile
tff(fact_4582_sorted__find__Min,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Xs: list(C),Pa: fun(C,$o)] :
          ( sorted_wrt(C,ord_less_eq(C),Xs)
         => ( ? [X3: C] :
                ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
                & aa(C,$o,Pa,X3) )
           => ( aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = aa(C,option(C),some(C),lattic643756798350308766er_Min(C,collect(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_or(list(C),fun(fun(C,$o),fun(C,$o)),Xs),Pa)))) ) ) ) ) ).

% sorted_find_Min
tff(fact_4583_find__cong,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),Pa: fun(C,$o),Q: fun(C,$o)] :
      ( ( Xs = Ys )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Ys))
           => ( aa(C,$o,Pa,X2)
            <=> aa(C,$o,Q,X2) ) )
       => ( aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Q),Ys) ) ) ) ).

% find_cong
tff(fact_4584_find__SomeD_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),X: C] :
      ( ( aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = aa(C,option(C),some(C),X) )
     => aa(C,$o,Pa,X) ) ).

% find_SomeD(1)
tff(fact_4585_find_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = $ite(aa(C,$o,Pa,X),aa(C,option(C),some(C),X),aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs)) ).

% find.simps(2)
tff(fact_4586_find_Osimps_I1_J,axiom,
    ! [C: $tType,Uu: fun(C,$o)] : aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Uu),nil(C)) = none(C) ).

% find.simps(1)
tff(fact_4587_find__SomeD_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),X: C] :
      ( ( aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = aa(C,option(C),some(C),X) )
     => member2(C,X,aa(list(C),set(C),set2(C),Xs)) ) ).

% find_SomeD(2)
tff(fact_4588_find__None__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = none(C) )
    <=> ~ ? [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
            & aa(C,$o,Pa,X4) ) ) ).

% find_None_iff
tff(fact_4589_find__None__iff2,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( ( none(C) = aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) )
    <=> ~ ? [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
            & aa(C,$o,Pa,X4) ) ) ).

% find_None_iff2
tff(fact_4590_find__Some__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),X: C] :
      ( ( aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) = aa(C,option(C),some(C),X) )
    <=> ? [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
          & aa(C,$o,Pa,aa(nat,C,nth(C,Xs),I2))
          & ( X = aa(nat,C,nth(C,Xs),I2) )
          & ! [J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),I2)
             => ~ aa(C,$o,Pa,aa(nat,C,nth(C,Xs),J2)) ) ) ) ).

% find_Some_iff
tff(fact_4591_find__Some__iff2,axiom,
    ! [C: $tType,X: C,Pa: fun(C,$o),Xs: list(C)] :
      ( ( aa(C,option(C),some(C),X) = aa(list(C),option(C),aa(fun(C,$o),fun(list(C),option(C)),find(C),Pa),Xs) )
    <=> ? [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Xs))
          & aa(C,$o,Pa,aa(nat,C,nth(C,Xs),I2))
          & ( X = aa(nat,C,nth(C,Xs),I2) )
          & ! [J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),I2)
             => ~ aa(C,$o,Pa,aa(nat,C,nth(C,Xs),J2)) ) ) ) ).

% find_Some_iff2
tff(fact_4592_inf__option__def,axiom,
    ! [C: $tType] :
      ( inf(C)
     => ! [X: option(C),Y: option(C)] : aa(option(C),option(C),aa(option(C),fun(option(C),option(C)),inf_inf(option(C)),X),Y) = case_option(option(C),C,none(C),aTP_Lamp_ot(option(C),fun(C,option(C)),Y),X) ) ).

% inf_option_def
tff(fact_4593_map__of__distinct__upd,axiom,
    ! [C: $tType,D: $tType,X: C,Xs: list(product_prod(C,D)),Y: D] :
      ( ~ member2(C,X,aa(list(C),set(C),set2(C),aa(list(product_prod(C,D)),list(C),aa(fun(product_prod(C,D),C),fun(list(product_prod(C,D)),list(C)),map(product_prod(C,D),C),product_fst(C,D)),Xs)))
     => ( map_add(C,D,fun_upd(C,option(D),aTP_Lamp_od(C,option(D)),X,aa(D,option(D),some(D),Y)),map_of(C,D,Xs)) = fun_upd(C,option(D),map_of(C,D,Xs),X,aa(D,option(D),some(D),Y)) ) ) ).

% map_of_distinct_upd
tff(fact_4594_restrict__upd__same,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),X: C,Y: D] : restrict_map(C,D,fun_upd(C,option(D),M2,X,aa(D,option(D),some(D),Y)),aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) = restrict_map(C,D,M2,aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) ).

% restrict_upd_same
tff(fact_4595_fun__upd__None__restrict,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),D2: set(C),X: C] :
      fun_upd(C,option(D),restrict_map(C,D,M2,D2),X,none(D)) = $ite(member2(C,X,D2),restrict_map(C,D,M2,minus_minus(set(C),D2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),restrict_map(C,D,M2,D2)) ).

% fun_upd_None_restrict
tff(fact_4596_restrict__map__UNIV,axiom,
    ! [D: $tType,C: $tType,F: fun(C,option(D))] : restrict_map(C,D,F,top_top(set(C))) = F ).

% restrict_map_UNIV
tff(fact_4597_restrict__restrict,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),A4: set(C),B3: set(C)] : restrict_map(C,D,restrict_map(C,D,M2,A4),B3) = restrict_map(C,D,M2,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ).

% restrict_restrict
tff(fact_4598_restrict__map__to__empty,axiom,
    ! [C: $tType,D: $tType,M2: fun(C,option(D)),X3: C] : aa(C,option(D),restrict_map(C,D,M2,bot_bot(set(C))),X3) = none(D) ).

% restrict_map_to_empty
tff(fact_4599_fun__upd__restrict__conv,axiom,
    ! [C: $tType,D: $tType,X: C,D2: set(C),M2: fun(C,option(D)),Y: option(D)] :
      ( member2(C,X,D2)
     => ( fun_upd(C,option(D),restrict_map(C,D,M2,D2),X,Y) = fun_upd(C,option(D),restrict_map(C,D,M2,minus_minus(set(C),D2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),X,Y) ) ) ).

% fun_upd_restrict_conv
tff(fact_4600_restrict__fun__upd,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),X: C,Y: option(D),D2: set(C)] :
      restrict_map(C,D,fun_upd(C,option(D),M2,X,Y),D2) = $ite(member2(C,X,D2),fun_upd(C,option(D),restrict_map(C,D,M2,minus_minus(set(C),D2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),X,Y),restrict_map(C,D,M2,D2)) ).

% restrict_fun_upd
tff(fact_4601_le__map__restrict,axiom,
    ! [D: $tType,C: $tType] :
      ( order(D)
     => ! [M2: fun(C,option(D)),X5: set(C)] : aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),restrict_map(C,D,M2,X5)),M2) ) ).

% le_map_restrict
tff(fact_4602_map__add__first__le,axiom,
    ! [D: $tType,C: $tType] :
      ( order(D)
     => ! [M2: fun(C,option(D)),M6: fun(C,option(D)),N: fun(C,option(D))] :
          ( aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),M2),M6)
         => aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),map_add(C,D,M2,N)),map_add(C,D,M6,N)) ) ) ).

% map_add_first_le
tff(fact_4603_restrict__map__subset__eq,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),R: set(C),M6: fun(C,option(D)),R7: set(C)] :
      ( ( restrict_map(C,D,M2,R) = M6 )
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),R7),R)
       => ( restrict_map(C,D,M2,R7) = restrict_map(C,D,M6,R7) ) ) ) ).

% restrict_map_subset_eq
tff(fact_4604_map__add__left__None,axiom,
    ! [C: $tType,D: $tType,F: fun(D,option(C)),K: D,G: fun(D,option(C))] :
      ( ( aa(D,option(C),F,K) = none(C) )
     => ( aa(D,option(C),map_add(D,C,F,G),K) = aa(D,option(C),G,K) ) ) ).

% map_add_left_None
tff(fact_4605_map__add__find__left,axiom,
    ! [C: $tType,D: $tType,G: fun(D,option(C)),K: D,F: fun(D,option(C))] :
      ( ( aa(D,option(C),G,K) = none(C) )
     => ( aa(D,option(C),map_add(D,C,F,G),K) = aa(D,option(C),F,K) ) ) ).

% map_add_find_left
tff(fact_4606_restrict__map__eq_I2_J,axiom,
    ! [C: $tType,D: $tType,M2: fun(D,option(C)),A4: set(D),K: D,V: C] :
      ( ( aa(D,option(C),restrict_map(D,C,M2,A4),K) = aa(C,option(C),some(C),V) )
    <=> ( ( aa(D,option(C),M2,K) = aa(C,option(C),some(C),V) )
        & member2(D,K,A4) ) ) ).

% restrict_map_eq(2)
tff(fact_4607_map__restrict__insert__none__simp,axiom,
    ! [C: $tType,D: $tType,M2: fun(D,option(C)),X: D,S4: set(D)] :
      ( ( aa(D,option(C),M2,X) = none(C) )
     => ( restrict_map(D,C,M2,aa(set(D),set(D),uminus_uminus(set(D)),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),S4))) = restrict_map(D,C,M2,aa(set(D),set(D),uminus_uminus(set(D)),S4)) ) ) ).

% map_restrict_insert_none_simp
tff(fact_4608_restrict__map__upd,axiom,
    ! [D: $tType,C: $tType,F: fun(C,option(D)),S: set(C),K: C,V: D] : fun_upd(C,option(D),restrict_map(C,D,F,S),K,aa(D,option(D),some(D),V)) = restrict_map(C,D,fun_upd(C,option(D),F,K,aa(D,option(D),some(D),V)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),K),S)) ).

% restrict_map_upd
tff(fact_4609_fun__upd__restrict,axiom,
    ! [C: $tType,D: $tType,M2: fun(C,option(D)),D2: set(C),X: C,Y: option(D)] : fun_upd(C,option(D),restrict_map(C,D,M2,D2),X,Y) = fun_upd(C,option(D),restrict_map(C,D,M2,minus_minus(set(C),D2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),X,Y) ).

% fun_upd_restrict
tff(fact_4610_map__of__concat,axiom,
    ! [D: $tType,C: $tType,Xss2: list(list(product_prod(C,D)))] : map_of(C,D,aa(list(list(product_prod(C,D))),list(product_prod(C,D)),concat(product_prod(C,D)),Xss2)) = aa(fun(C,option(D)),fun(C,option(D)),aa(list(list(product_prod(C,D))),fun(fun(C,option(D)),fun(C,option(D))),aa(fun(list(product_prod(C,D)),fun(fun(C,option(D)),fun(C,option(D)))),fun(list(list(product_prod(C,D))),fun(fun(C,option(D)),fun(C,option(D)))),foldr(list(product_prod(C,D)),fun(C,option(D))),aTP_Lamp_ou(list(product_prod(C,D)),fun(fun(C,option(D)),fun(C,option(D))))),Xss2),aTP_Lamp_od(C,option(D))) ).

% map_of_concat
tff(fact_4611_restrict__complement__singleton__eq,axiom,
    ! [C: $tType,D: $tType,F: fun(C,option(D)),X: C] : restrict_map(C,D,F,aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) = fun_upd(C,option(D),F,X,none(D)) ).

% restrict_complement_singleton_eq
tff(fact_4612_map__upd__eq__restrict,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),X: C] : fun_upd(C,option(D),M2,X,none(D)) = restrict_map(C,D,M2,aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))) ).

% map_upd_eq_restrict
tff(fact_4613_subset__eq__mset__impl_Oelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: option($o)] :
      ( ( subset_eq_mset_impl(C,X,Xa) = Y )
     => ( ( ( X = nil(C) )
         => ( Y != aa($o,option($o),some($o),Xa != nil(C)) ) )
       => ~ ! [X2: C,Xs2: list(C)] :
              ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
             => ( Y != case_option(option($o),product_prod(list(C),product_prod(C,list(C))),none($o),product_case_prod(list(C),product_prod(C,list(C)),option($o),aTP_Lamp_ow(list(C),fun(list(C),fun(product_prod(C,list(C)),option($o))),Xs2)),extract(C,aa(C,fun(C,$o),fequal(C),X2),Xa)) ) ) ) ) ).

% subset_eq_mset_impl.elims
tff(fact_4614_subset__eq__mset__impl_Opelims,axiom,
    ! [C: $tType,X: list(C),Xa: list(C),Y: option($o)] :
      ( ( subset_eq_mset_impl(C,X,Xa) = Y )
     => ( accp(product_prod(list(C),list(C)),subset751672762298770561pl_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Xa))
       => ( ( ( X = nil(C) )
           => ( ( Y = aa($o,option($o),some($o),Xa != nil(C)) )
             => ~ accp(product_prod(list(C),list(C)),subset751672762298770561pl_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),nil(C)),Xa)) ) )
         => ~ ! [X2: C,Xs2: list(C)] :
                ( ( X = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
               => ( ( Y = case_option(option($o),product_prod(list(C),product_prod(C,list(C))),none($o),product_case_prod(list(C),product_prod(C,list(C)),option($o),aTP_Lamp_ow(list(C),fun(list(C),fun(product_prod(C,list(C)),option($o))),Xs2)),extract(C,aa(C,fun(C,$o),fequal(C),X2),Xa)) )
                 => ~ accp(product_prod(list(C),list(C)),subset751672762298770561pl_rel(C),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2)),Xa)) ) ) ) ) ) ).

% subset_eq_mset_impl.pelims
tff(fact_4615_subset__eq__mset__impl_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),Ys: list(C)] : subset_eq_mset_impl(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),Ys) = case_option(option($o),product_prod(list(C),product_prod(C,list(C))),none($o),product_case_prod(list(C),product_prod(C,list(C)),option($o),aTP_Lamp_ow(list(C),fun(list(C),fun(product_prod(C,list(C)),option($o))),Xs)),extract(C,aa(C,fun(C,$o),fequal(C),X),Ys)) ).

% subset_eq_mset_impl.simps(2)
tff(fact_4616_subset__eq__mset__impl_Osimps_I1_J,axiom,
    ! [C: $tType,Ys: list(C)] : subset_eq_mset_impl(C,nil(C),Ys) = aa($o,option($o),some($o),Ys != nil(C)) ).

% subset_eq_mset_impl.simps(1)
tff(fact_4617_Inf__fin_Oeq__fold_H,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [A4: set(C)] : aa(set(C),C,lattic7752659483105999362nf_fin(C),A4) = aa(option(C),C,the2(C),finite_fold(C,option(C),aTP_Lamp_ox(C,fun(option(C),option(C))),none(C),A4)) ) ).

% Inf_fin.eq_fold'
tff(fact_4618_ran__map__upd__Some,axiom,
    ! [D: $tType,C: $tType,M2: fun(D,option(C)),X: D,Y: C,Z2: C] :
      ( ( aa(D,option(C),M2,X) = aa(C,option(C),some(C),Y) )
     => ( inj_on(D,option(C),M2,dom(D,C,M2))
       => ( ~ member2(C,Z2,ran(D,C,M2))
         => ( ran(D,C,fun_upd(D,option(C),M2,X,aa(C,option(C),some(C),Z2))) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),minus_minus(set(C),ran(D,C,M2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C))))),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Z2),bot_bot(set(C)))) ) ) ) ) ).

% ran_map_upd_Some
tff(fact_4619_Eps__Opt__eq__None,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ( eps_Opt(C,Pa) = none(C) )
    <=> ~ ? [X_12: C] : aa(C,$o,Pa,X_12) ) ).

% Eps_Opt_eq_None
tff(fact_4620_restrict__map__self,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] : restrict_map(C,D,M2,dom(C,D,M2)) = M2 ).

% restrict_map_self
tff(fact_4621_some__opt__sym__eq__trivial,axiom,
    ! [C: $tType,X: C] : eps_Opt(C,aa(C,fun(C,$o),fequal(C),X)) = aa(C,option(C),some(C),X) ).

% some_opt_sym_eq_trivial
tff(fact_4622_some__opt__eq__trivial,axiom,
    ! [C: $tType,X: C] : eps_Opt(C,aTP_Lamp_ad(C,fun(C,$o),X)) = aa(C,option(C),some(C),X) ).

% some_opt_eq_trivial
tff(fact_4623_some__opt__false__trivial,axiom,
    ! [C: $tType] : eps_Opt(C,aTP_Lamp_bo(C,$o)) = none(C) ).

% some_opt_false_trivial
tff(fact_4624_dom__eq__empty__conv,axiom,
    ! [C: $tType,D: $tType,F: fun(C,option(D))] :
      ( ( dom(C,D,F) = bot_bot(set(C)) )
    <=> ! [X4: C] : aa(C,option(D),F,X4) = none(D) ) ).

% dom_eq_empty_conv
tff(fact_4625_dom__restrict,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),A4: set(C)] : dom(C,D,restrict_map(C,D,M2,A4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,M2)),A4) ).

% dom_restrict
tff(fact_4626_dom__empty,axiom,
    ! [D: $tType,C: $tType] : dom(C,D,aTP_Lamp_od(C,option(D))) = bot_bot(set(C)) ).

% dom_empty
tff(fact_4627_map__update__eta__repair_I1_J,axiom,
    ! [D: $tType,C: $tType,K: C,V: D,M2: fun(C,option(D))] : dom(C,D,aa(fun(C,option(D)),fun(C,option(D)),aa(D,fun(fun(C,option(D)),fun(C,option(D))),aTP_Lamp_oy(C,fun(D,fun(fun(C,option(D)),fun(C,option(D)))),K),V),M2)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),K),dom(C,D,M2)) ).

% map_update_eta_repair(1)
tff(fact_4628_dom__const_H,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D)] : dom(C,D,aTP_Lamp_oz(fun(C,D),fun(C,option(D)),F)) = top_top(set(C)) ).

% dom_const'
tff(fact_4629_restrict__map__inv,axiom,
    ! [C: $tType,D: $tType,F: fun(C,option(D)),X3: C] : aa(C,option(D),restrict_map(C,D,F,aa(set(C),set(C),uminus_uminus(set(C)),dom(C,D,F))),X3) = none(D) ).

% restrict_map_inv
tff(fact_4630_dom__fun__upd,axiom,
    ! [D: $tType,C: $tType,F: fun(C,option(D)),X: C,Y: option(D)] :
      dom(C,D,fun_upd(C,option(D),F,X,Y)) = $ite(Y = none(D),minus_minus(set(C),dom(C,D,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),dom(C,D,F))) ).

% dom_fun_upd
tff(fact_4631_ran__map__add,axiom,
    ! [D: $tType,C: $tType,M1: fun(C,option(D)),M22: fun(C,option(D))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,M1)),dom(C,D,M22)) = bot_bot(set(C)) )
     => ( ran(C,D,map_add(C,D,M1,M22)) = aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),ran(C,D,M1)),ran(C,D,M22)) ) ) ).

% ran_map_add
tff(fact_4632_ran__add,axiom,
    ! [D: $tType,C: $tType,F: fun(C,option(D)),G: fun(C,option(D))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,F)),dom(C,D,G)) = bot_bot(set(C)) )
     => ( ran(C,D,map_add(C,D,F,G)) = aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),ran(C,D,F)),ran(C,D,G)) ) ) ).

% ran_add
tff(fact_4633_nempty__dom,axiom,
    ! [D: $tType,C: $tType,E4: fun(C,option(D))] :
      ( ~ ! [X3: C] : aa(C,option(D),E4,X3) = none(D)
     => ~ ! [M4: C] : ~ member2(C,M4,dom(C,D,E4)) ) ).

% nempty_dom
tff(fact_4634_inj__on__map__the,axiom,
    ! [D: $tType,C: $tType,D2: set(C),M2: fun(C,option(D))] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),D2),dom(C,D,M2))
     => ( inj_on(C,option(D),M2,D2)
       => inj_on(C,D,comp(option(D),D,C,the2(D),M2),D2) ) ) ).

% inj_on_map_the
tff(fact_4635_ran__is__image,axiom,
    ! [C: $tType,D: $tType,M: fun(D,option(C))] : ran(D,C,M) = aa(set(D),set(C),image2(D,C,comp(option(C),C,D,the2(C),M)),dom(D,C,M)) ).

% ran_is_image
tff(fact_4636_map__dom__ran__finite,axiom,
    ! [D: $tType,C: $tType,M: fun(C,option(D))] :
      ( aa(set(C),$o,finite_finite2(C),dom(C,D,M))
     => aa(set(D),$o,finite_finite2(D),ran(C,D,M)) ) ).

% map_dom_ran_finite
tff(fact_4637_dom__if,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,$o),F: fun(C,option(D)),G: fun(C,option(D))] : dom(C,D,aa(fun(C,option(D)),fun(C,option(D)),aa(fun(C,option(D)),fun(fun(C,option(D)),fun(C,option(D))),aTP_Lamp_pa(fun(C,$o),fun(fun(C,option(D)),fun(fun(C,option(D)),fun(C,option(D)))),Pa),F),G)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,F)),collect(C,Pa))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,G)),collect(C,aTP_Lamp_bi(fun(C,$o),fun(C,$o),Pa)))) ).

% dom_if
tff(fact_4638_le__map__dom__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( preorder(D)
     => ! [M2: fun(C,option(D)),M6: fun(C,option(D))] :
          ( aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),M2),M6)
         => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),dom(C,D,M2)),dom(C,D,M6)) ) ) ).

% le_map_dom_mono
tff(fact_4639_Eps__Opt__eq__Some__implies,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C] :
      ( ( eps_Opt(C,Pa) = aa(C,option(C),some(C),X) )
     => aa(C,$o,Pa,X) ) ).

% Eps_Opt_eq_Some_implies
tff(fact_4640_Eps__Opt__eq__Some,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C] :
      ( ! [X7: C] :
          ( aa(C,$o,Pa,X)
         => ( aa(C,$o,Pa,X7)
           => ( X7 = X ) ) )
     => ( ( eps_Opt(C,Pa) = aa(C,option(C),some(C),X) )
      <=> aa(C,$o,Pa,X) ) ) ).

% Eps_Opt_eq_Some
tff(fact_4641_map__add__comm,axiom,
    ! [D: $tType,C: $tType,M1: fun(C,option(D)),M22: fun(C,option(D))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,M1)),dom(C,D,M22)) = bot_bot(set(C)) )
     => ( map_add(C,D,M1,M22) = map_add(C,D,M22,M1) ) ) ).

% map_add_comm
tff(fact_4642_map__add__left__comm,axiom,
    ! [D: $tType,C: $tType,A4: fun(C,option(D)),B3: fun(C,option(D)),C4: fun(C,option(D))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,A4)),dom(C,D,B3)) = bot_bot(set(C)) )
     => ( map_add(C,D,A4,map_add(C,D,B3,C4)) = map_add(C,D,B3,map_add(C,D,A4,C4)) ) ) ).

% map_add_left_comm
tff(fact_4643_restrict__map__eq_I1_J,axiom,
    ! [C: $tType,D: $tType,M2: fun(D,option(C)),A4: set(D),K: D] :
      ( ( aa(D,option(C),restrict_map(D,C,M2,A4),K) = none(C) )
    <=> ~ member2(D,K,aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),dom(D,C,M2)),A4)) ) ).

% restrict_map_eq(1)
tff(fact_4644_map__card__eq__iff,axiom,
    ! [D: $tType,C: $tType,M: fun(C,option(D)),X: C,Y: C] :
      ( aa(set(C),$o,finite_finite2(C),dom(C,D,M))
     => ( ( finite_card(C,dom(C,D,M)) = finite_card(D,ran(C,D,M)) )
       => ( member2(C,X,dom(C,D,M))
         => ( ( aa(C,option(D),M,X) = aa(C,option(D),M,Y) )
          <=> ( X = Y ) ) ) ) ) ).

% map_card_eq_iff
tff(fact_4645_finite__map__to__set,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] :
      ( aa(set(product_prod(C,D)),$o,finite_finite2(product_prod(C,D)),map_to_set(C,D,M2))
    <=> aa(set(C),$o,finite_finite2(C),dom(C,D,M2)) ) ).

% finite_map_to_set
tff(fact_4646_map__to__set__dom,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] : dom(C,D,M2) = aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),map_to_set(C,D,M2)) ).

% map_to_set_dom
tff(fact_4647_set__to__map__dom,axiom,
    ! [D: $tType,C: $tType,S: set(product_prod(C,D))] : dom(C,D,set_to_map(C,D,S)) = aa(set(product_prod(C,D)),set(C),image2(product_prod(C,D),C,product_fst(C,D)),S) ).

% set_to_map_dom
tff(fact_4648_card__map__to__set,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D))] : finite_card(product_prod(C,D),map_to_set(C,D,M2)) = finite_card(C,dom(C,D,M2)) ).

% card_map_to_set
tff(fact_4649_map__filter__simps_I1_J,axiom,
    ! [C: $tType,D: $tType,F: fun(D,option(C)),X: D,Xs: list(D)] : map_filter(D,C,F,aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)) = case_option(list(C),C,map_filter(D,C,F,Xs),aa(list(D),fun(C,list(C)),aTP_Lamp_pb(fun(D,option(C)),fun(list(D),fun(C,list(C))),F),Xs),aa(D,option(C),F,X)) ).

% map_filter_simps(1)
tff(fact_4650_map__add__distinct__le,axiom,
    ! [D: $tType,C: $tType] :
      ( preorder(D)
     => ! [M2: fun(C,option(D)),M6: fun(C,option(D)),N: fun(C,option(D)),N9: fun(C,option(D))] :
          ( aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),M2),M6)
         => ( aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),N),N9)
           => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,M6)),dom(C,D,N9)) = bot_bot(set(C)) )
             => aa(fun(C,option(D)),$o,aa(fun(C,option(D)),fun(fun(C,option(D)),$o),ord_less_eq(fun(C,option(D))),map_add(C,D,M2,N)),map_add(C,D,M6,N9)) ) ) ) ) ).

% map_add_distinct_le
tff(fact_4651_dom__eq__singleton__conv,axiom,
    ! [C: $tType,D: $tType,F: fun(C,option(D)),X: C] :
      ( ( dom(C,D,F) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) )
    <=> ? [V4: D] : F = fun_upd(C,option(D),aTP_Lamp_od(C,option(D)),X,aa(D,option(D),some(D),V4)) ) ).

% dom_eq_singleton_conv
tff(fact_4652_set__to__map__def,axiom,
    ! [C: $tType,D: $tType,S: set(product_prod(D,C)),K: D] : aa(D,option(C),set_to_map(D,C,S),K) = eps_Opt(C,aa(D,fun(C,$o),aTP_Lamp_pc(set(product_prod(D,C)),fun(D,fun(C,$o)),S),K)) ).

% set_to_map_def
tff(fact_4653_map__filter__def,axiom,
    ! [C: $tType,D: $tType,F: fun(D,option(C)),Xs: list(D)] : map_filter(D,C,F,Xs) = aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),comp(option(C),C,D,the2(C),F)),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),aTP_Lamp_pd(fun(D,option(C)),fun(D,$o),F)),Xs)) ).

% map_filter_def
tff(fact_4654_dom__override__on,axiom,
    ! [D: $tType,C: $tType,F: fun(C,option(D)),G: fun(C,option(D)),A4: set(C)] : dom(C,D,override_on(C,option(D),F,G,A4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),minus_minus(set(C),dom(C,D,F),collect(C,aa(set(C),fun(C,$o),aTP_Lamp_pe(fun(C,option(D)),fun(set(C),fun(C,$o)),G),A4)))),collect(C,aa(set(C),fun(C,$o),aTP_Lamp_pf(fun(C,option(D)),fun(set(C),fun(C,$o)),G),A4))) ).

% dom_override_on
tff(fact_4655_graph__map__add,axiom,
    ! [D: $tType,C: $tType,M1: fun(C,option(D)),M22: fun(C,option(D))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),dom(C,D,M1)),dom(C,D,M22)) = bot_bot(set(C)) )
     => ( graph(C,D,map_add(C,D,M1,M22)) = aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),sup_sup(set(product_prod(C,D))),graph(C,D,M1)),graph(C,D,M22)) ) ) ).

% graph_map_add
tff(fact_4656_eq__f__restr__conv,axiom,
    ! [D: $tType,C: $tType,S4: set(C),F: fun(fun(C,option(D)),fun(C,option(D))),A4: fun(C,option(D))] :
      ( ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S4),dom(C,D,aa(fun(C,option(D)),fun(C,option(D)),F,A4)))
        & ( A4 = restrict_map(C,D,aa(fun(C,option(D)),fun(C,option(D)),F,A4),aa(set(C),set(C),uminus_uminus(set(C)),S4)) ) )
    <=> ( map_le(C,D,A4,aa(fun(C,option(D)),fun(C,option(D)),F,A4))
        & ( S4 = minus_minus(set(C),dom(C,D,aa(fun(C,option(D)),fun(C,option(D)),F,A4)),dom(C,D,A4)) ) ) ) ).

% eq_f_restr_conv
tff(fact_4657_override__on__emptyset,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),G: fun(C,D)] : override_on(C,D,F,G,bot_bot(set(C))) = F ).

% override_on_emptyset
tff(fact_4658_map__leI,axiom,
    ! [D: $tType,C: $tType,M1: fun(C,option(D)),M22: fun(C,option(D))] :
      ( ! [X2: C,V2: D] :
          ( ( aa(C,option(D),M1,X2) = aa(D,option(D),some(D),V2) )
         => ( aa(C,option(D),M22,X2) = aa(D,option(D),some(D),V2) ) )
     => map_le(C,D,M1,M22) ) ).

% map_leI
tff(fact_4659_map__leD,axiom,
    ! [C: $tType,D: $tType,M1: fun(C,option(D)),M22: fun(C,option(D)),K: C,V: D] :
      ( map_le(C,D,M1,M22)
     => ( ( aa(C,option(D),M1,K) = aa(D,option(D),some(D),V) )
       => ( aa(C,option(D),M22,K) = aa(D,option(D),some(D),V) ) ) ) ).

% map_leD
tff(fact_4660_eq__f__restr__ss__eq,axiom,
    ! [D: $tType,C: $tType,S4: set(C),F: fun(fun(C,option(D)),fun(C,option(D))),A4: fun(C,option(D))] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),S4),dom(C,D,aa(fun(C,option(D)),fun(C,option(D)),F,A4)))
     => ( ( A4 = restrict_map(C,D,aa(fun(C,option(D)),fun(C,option(D)),F,A4),aa(set(C),set(C),uminus_uminus(set(C)),S4)) )
      <=> ( map_le(C,D,A4,aa(fun(C,option(D)),fun(C,option(D)),F,A4))
          & ( S4 = minus_minus(set(C),dom(C,D,aa(fun(C,option(D)),fun(C,option(D)),F,A4)),dom(C,D,A4)) ) ) ) ) ).

% eq_f_restr_ss_eq
tff(fact_4661_le__map__mmupd__not__dom,axiom,
    ! [C: $tType,D: $tType,M2: fun(C,option(D)),K5: set(C),V: D] : map_le(C,D,M2,map_mmupd(C,D,M2,minus_minus(set(C),K5,dom(C,D,M2)),V)) ).

% le_map_mmupd_not_dom
tff(fact_4662_map__mmupd__update__less,axiom,
    ! [C: $tType,D: $tType,K5: set(C),K6: set(C),M2: fun(C,option(D)),V: D] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),K5),K6)
     => map_le(C,D,map_mmupd(C,D,M2,minus_minus(set(C),K5,dom(C,D,M2)),V),map_mmupd(C,D,M2,minus_minus(set(C),K6,dom(C,D,M2)),V)) ) ).

% map_mmupd_update_less
tff(fact_4663_the__dflt__None__nonempty,axiom,
    ! [C: $tType,S: set(C)] :
      ( ( S != bot_bot(set(C)) )
     => ( dflt_None_set(C,S) = aa(set(C),option(set(C)),some(set(C)),S) ) ) ).

% the_dflt_None_nonempty
tff(fact_4664_mmupd__notin__upd,axiom,
    ! [D: $tType,C: $tType,K: C,K5: set(C),M2: fun(C,option(D)),V: D] :
      ( ~ member2(C,K,K5)
     => ( aa(C,option(D),map_mmupd(C,D,M2,K5,V),K) = aa(C,option(D),M2,K) ) ) ).

% mmupd_notin_upd
tff(fact_4665_map__mmupd__empty,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),V: D] : map_mmupd(C,D,M2,bot_bot(set(C)),V) = M2 ).

% map_mmupd_empty
tff(fact_4666_mmupd__in__upd,axiom,
    ! [C: $tType,D: $tType,K: C,K5: set(C),M2: fun(C,option(D)),V: D] :
      ( member2(C,K,K5)
     => ( aa(C,option(D),map_mmupd(C,D,M2,K5,V),K) = aa(D,option(D),some(D),V) ) ) ).

% mmupd_in_upd
tff(fact_4667_the__dflt__None__empty,axiom,
    ! [C: $tType] : dflt_None_set(C,bot_bot(set(C))) = none(set(C)) ).

% the_dflt_None_empty
tff(fact_4668_dom__mmupd,axiom,
    ! [D: $tType,C: $tType,M2: fun(C,option(D)),K5: set(C),V: D] : dom(C,D,map_mmupd(C,D,M2,K5,V)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),dom(C,D,M2)),K5) ).

% dom_mmupd
tff(fact_4669_map__mmupd__def,axiom,
    ! [C: $tType,D: $tType,M2: fun(D,option(C)),K5: set(D),V: C,K: D] :
      aa(D,option(C),map_mmupd(D,C,M2,K5,V),K) = $ite(member2(D,K,K5),aa(C,option(C),some(C),V),aa(D,option(C),M2,K)) ).

% map_mmupd_def
tff(fact_4670_map__mmupdE,axiom,
    ! [D: $tType,C: $tType,M2: fun(D,option(C)),K5: set(D),V: C,K: D,X: C] :
      ( ( aa(D,option(C),map_mmupd(D,C,M2,K5,V),K) = aa(C,option(C),some(C),X) )
     => ( ( ~ member2(D,K,K5)
         => ( aa(D,option(C),M2,K) != aa(C,option(C),some(C),X) ) )
       => ~ ( member2(D,K,K5)
           => ( X != V ) ) ) ) ).

% map_mmupdE
tff(fact_4671_dflt__None__set__def,axiom,
    ! [C: $tType,S: set(C)] :
      dflt_None_set(C,S) = $ite(S = bot_bot(set(C)),none(set(C)),aa(set(C),option(set(C)),some(set(C)),S)) ).

% dflt_None_set_def
tff(fact_4672_the__dflt__None__set,axiom,
    ! [C: $tType,X: set(C)] : the_default(set(C),bot_bot(set(C)),dflt_None_set(C,X)) = X ).

% the_dflt_None_set
tff(fact_4673_subset__Image1__Image1__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( order_preorder_on(C,field2(C,R3),R3)
     => ( member2(C,A3,field2(C,R3))
       => ( member2(C,B2,field2(C,R3))
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))))
          <=> member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),A3),R3) ) ) ) ) ).

% subset_Image1_Image1_iff
tff(fact_4674_at__most__one__mset__mset__diff,axiom,
    ! [C: $tType,A3: C,M: multiset(C)] :
      ( ~ member2(C,A3,set_mset(C,minus_minus(multiset(C),M,add_mset(C,A3,zero_zero(multiset(C))))))
     => ( set_mset(C,minus_minus(multiset(C),M,add_mset(C,A3,zero_zero(multiset(C))))) = minus_minus(set(C),set_mset(C,M),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ) ) ).

% at_most_one_mset_mset_diff
tff(fact_4675_Image__empty2,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(D,C))] : image(D,C,R,bot_bot(set(D))) = bot_bot(set(C)) ).

% Image_empty2
tff(fact_4676_set__mset__eq__empty__iff,axiom,
    ! [C: $tType,M: multiset(C)] :
      ( ( set_mset(C,M) = bot_bot(set(C)) )
    <=> ( M = zero_zero(multiset(C)) ) ) ).

% set_mset_eq_empty_iff
tff(fact_4677_set__mset__empty,axiom,
    ! [C: $tType] : set_mset(C,zero_zero(multiset(C))) = bot_bot(set(C)) ).

% set_mset_empty
tff(fact_4678_Image__empty1,axiom,
    ! [D: $tType,C: $tType,X5: set(D)] : image(D,C,bot_bot(set(product_prod(D,C))),X5) = bot_bot(set(C)) ).

% Image_empty1
tff(fact_4679_Image__Id__on,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : image(C,C,id_on(C,A4),B3) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) ).

% Image_Id_on
tff(fact_4680_Image__singleton__iff,axiom,
    ! [C: $tType,D: $tType,B2: C,R3: set(product_prod(D,C)),A3: D] :
      ( member2(C,B2,image(D,C,R3,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D)))))
    <=> member2(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),A3),B2),R3) ) ).

% Image_singleton_iff
tff(fact_4681_mset__diff__cancel1elem,axiom,
    ! [C: $tType,A3: C,B3: multiset(C)] :
      ( ~ member2(C,A3,set_mset(C,B3))
     => ( minus_minus(multiset(C),add_mset(C,A3,zero_zero(multiset(C))),B3) = add_mset(C,A3,zero_zero(multiset(C))) ) ) ).

% mset_diff_cancel1elem
tff(fact_4682_listrel__Nil,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(D,C))] : image(list(D),list(C),listrel(D,C,R3),aa(set(list(D)),set(list(D)),aa(list(D),fun(set(list(D)),set(list(D))),insert2(list(D)),nil(D)),bot_bot(set(list(D))))) = aa(set(list(C)),set(list(C)),aa(list(C),fun(set(list(C)),set(list(C))),insert2(list(C)),nil(C)),bot_bot(set(list(C)))) ).

% listrel_Nil
tff(fact_4683_pair__vimage__is__Image,axiom,
    ! [C: $tType,D: $tType,U: D,E5: set(product_prod(D,C))] : aa(set(product_prod(D,C)),set(C),aa(fun(C,product_prod(D,C)),fun(set(product_prod(D,C)),set(C)),vimage(C,product_prod(D,C)),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),U)),E5) = image(D,C,E5,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),U),bot_bot(set(D)))) ).

% pair_vimage_is_Image
tff(fact_4684_mset__right__cancel__union,axiom,
    ! [C: $tType,A3: C,A4: multiset(C),B3: multiset(C)] :
      ( member2(C,A3,set_mset(C,aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)))
     => ( ~ member2(C,A3,set_mset(C,B3))
       => member2(C,A3,set_mset(C,A4)) ) ) ).

% mset_right_cancel_union
tff(fact_4685_mset__left__cancel__union,axiom,
    ! [C: $tType,A3: C,A4: multiset(C),B3: multiset(C)] :
      ( member2(C,A3,set_mset(C,aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)))
     => ( ~ member2(C,A3,set_mset(C,A4))
       => member2(C,A3,set_mset(C,B3)) ) ) ).

% mset_left_cancel_union
tff(fact_4686_mset__un__cases,axiom,
    ! [C: $tType,A3: C,A4: multiset(C),B3: multiset(C)] :
      ( member2(C,A3,set_mset(C,aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)))
     => ( ~ member2(C,A3,set_mset(C,A4))
       => member2(C,A3,set_mset(C,B3)) ) ) ).

% mset_un_cases
tff(fact_4687_ex__Melem__conv,axiom,
    ! [C: $tType,A4: multiset(C)] :
      ( ? [X4: C] : member2(C,X4,set_mset(C,A4))
    <=> ( A4 != zero_zero(multiset(C)) ) ) ).

% ex_Melem_conv
tff(fact_4688_Image__Int__subset,axiom,
    ! [C: $tType,D: $tType,R: set(product_prod(D,C)),A4: set(D),B3: set(D)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(D,C,R,aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),image(D,C,R,A4)),image(D,C,R,B3))) ).

% Image_Int_subset
tff(fact_4689_rtrancl__image__advance,axiom,
    ! [C: $tType,Q2: C,R: set(product_prod(C,C)),Q0: set(C),X: C] :
      ( member2(C,Q2,image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),Q0))
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),X),R)
       => member2(C,X,image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),Q0)) ) ) ).

% rtrancl_image_advance
tff(fact_4690_rtrancl__image__advance__rtrancl,axiom,
    ! [C: $tType,Q2: C,R: set(product_prod(C,C)),Q0: set(C),X: C] :
      ( member2(C,Q2,image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),Q0))
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Q2),X),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R))
       => member2(C,X,image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),Q0)) ) ) ).

% rtrancl_image_advance_rtrancl
tff(fact_4691_finite__Image__subset,axiom,
    ! [C: $tType,D: $tType,A4: set(product_prod(D,C)),B3: set(D),C4: set(product_prod(D,C))] :
      ( aa(set(C),$o,finite_finite2(C),image(D,C,A4,B3))
     => ( aa(set(product_prod(D,C)),$o,aa(set(product_prod(D,C)),fun(set(product_prod(D,C)),$o),ord_less_eq(set(product_prod(D,C))),C4),A4)
       => aa(set(C),$o,finite_finite2(C),image(D,C,C4,B3)) ) ) ).

% finite_Image_subset
tff(fact_4692_rtrancl__image__unfold__right,axiom,
    ! [C: $tType,E5: set(product_prod(C,C)),V3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,E5,image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),V3))),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),V3)) ).

% rtrancl_image_unfold_right
tff(fact_4693_rtrancl__reachable__induct,axiom,
    ! [C: $tType,I5: set(C),INV: set(C),E5: set(product_prod(C,C))] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),I5),INV)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,E5,INV)),INV)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),I5)),INV) ) ) ).

% rtrancl_reachable_induct
tff(fact_4694_trancl__Image__unfold__right,axiom,
    ! [C: $tType,E5: set(product_prod(C,C)),S: set(C)] : image(C,C,transitive_trancl(C,E5),S) = image(C,C,E5,image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),S)) ).

% trancl_Image_unfold_right
tff(fact_4695_trancl__Image__unfold__left,axiom,
    ! [C: $tType,E5: set(product_prod(C,C)),S: set(C)] : image(C,C,transitive_trancl(C,E5),S) = image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),image(C,C,E5,S)) ).

% trancl_Image_unfold_left
tff(fact_4696_Image__empty__rtrancl__Image__id,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),V: C] :
      ( ( image(C,C,R,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C)))) = bot_bot(set(C)) )
     => ( image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C)))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C))) ) ) ).

% Image_empty_rtrancl_Image_id
tff(fact_4697_Image__empty__trancl__Image__empty,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),V: C] :
      ( ( image(C,C,R,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C)))) = bot_bot(set(C)) )
     => ( image(C,C,transitive_trancl(C,R),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C)))) = bot_bot(set(C)) ) ) ).

% Image_empty_trancl_Image_empty
tff(fact_4698_reachable__mono,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),R7: set(product_prod(C,C)),X5: set(C),X8: set(C)] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),R7)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),X5),X8)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),X5)),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R7),X8)) ) ) ).

% reachable_mono
tff(fact_4699_quotientI,axiom,
    ! [C: $tType,X: C,A4: set(C),R3: set(product_prod(C,C))] :
      ( member2(C,X,A4)
     => member2(set(C),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))),equiv_quotient(C,A4,R3)) ) ).

% quotientI
tff(fact_4700_quotientE,axiom,
    ! [C: $tType,X5: set(C),A4: set(C),R3: set(product_prod(C,C))] :
      ( member2(set(C),X5,equiv_quotient(C,A4,R3))
     => ~ ! [X2: C] :
            ( ( X5 = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),bot_bot(set(C)))) )
           => ~ member2(C,X2,A4) ) ) ).

% quotientE
tff(fact_4701_Image__subset__snd__image,axiom,
    ! [C: $tType,D: $tType,A4: set(product_prod(D,C)),B3: set(D)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(D,C,A4,B3)),aa(set(product_prod(D,C)),set(C),image2(product_prod(D,C),C,product_snd(D,C)),A4)) ).

% Image_subset_snd_image
tff(fact_4702_trancl__image__by__rtrancl,axiom,
    ! [C: $tType,E5: set(product_prod(C,C)),Vi: set(C)] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),image(C,C,transitive_trancl(C,E5),Vi)),Vi) = image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),Vi) ).

% trancl_image_by_rtrancl
tff(fact_4703_mset__left__cancel__elem,axiom,
    ! [C: $tType,A3: C,B2: C,A4: multiset(C)] :
      ( member2(C,A3,set_mset(C,aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,B2,zero_zero(multiset(C)))),A4)))
     => ( ( A3 != B2 )
       => member2(C,A3,set_mset(C,A4)) ) ) ).

% mset_left_cancel_elem
tff(fact_4704_mset__right__cancel__elem,axiom,
    ! [C: $tType,A3: C,A4: multiset(C),B2: C] :
      ( member2(C,A3,set_mset(C,aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),add_mset(C,B2,zero_zero(multiset(C))))))
     => ( ( A3 != B2 )
       => member2(C,A3,set_mset(C,A4)) ) ) ).

% mset_right_cancel_elem
tff(fact_4705_Image__singleton,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(D,C)),A3: D] : image(D,C,R3,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D)))) = collect(C,aa(D,fun(C,$o),aTP_Lamp_pc(set(product_prod(D,C)),fun(D,fun(C,$o)),R3),A3)) ).

% Image_singleton
tff(fact_4706_Image__fold,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D)),S: set(C)] :
      ( aa(set(product_prod(C,D)),$o,finite_finite2(product_prod(C,D)),R)
     => ( image(C,D,R,S) = finite_fold(product_prod(C,D),set(D),product_case_prod(C,D,fun(set(D),set(D)),aTP_Lamp_pg(set(C),fun(C,fun(D,fun(set(D),set(D)))),S)),bot_bot(set(D)),R) ) ) ).

% Image_fold
tff(fact_4707_listrel__Cons,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(D,C)),X: D,Xs: list(D)] : image(list(D),list(C),listrel(D,C,R3),aa(set(list(D)),set(list(D)),aa(list(D),fun(set(list(D)),set(list(D))),insert2(list(D)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),X),Xs)),bot_bot(set(list(D))))) = aa(set(list(C)),set(list(C)),aa(set(C),fun(set(list(C)),set(list(C))),set_Cons(C),image(D,C,R3,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D))))),image(list(D),list(C),listrel(D,C,R3),aa(set(list(D)),set(list(D)),aa(list(D),fun(set(list(D)),set(list(D))),insert2(list(D)),Xs),bot_bot(set(list(D)))))) ).

% listrel_Cons
tff(fact_4708_rtrancl__apply__insert,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),X: C,S: set(C)] : image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),S)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),S),image(C,C,R,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))))) ).

% rtrancl_apply_insert
tff(fact_4709_rtrancl__Image__in__Field,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),V3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R),V3)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),field2(C,R)),V3)) ).

% rtrancl_Image_in_Field
tff(fact_4710_set__mset__single,axiom,
    ! [C: $tType,B2: C] : set_mset(C,add_mset(C,B2,zero_zero(multiset(C)))) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))) ).

% set_mset_single
tff(fact_4711_E__closed__restr__reach__cases,axiom,
    ! [C: $tType,U: C,V: C,E5: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5))
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,E5,R)),R)
       => ( ~ member2(C,V,R)
         => ~ ( ~ member2(C,U,R)
             => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),rel_restrict(C,E5,R))) ) ) ) ) ).

% E_closed_restr_reach_cases
tff(fact_4712_rel__restrict__tranclI,axiom,
    ! [C: $tType,X: C,Y: C,E5: set(product_prod(C,C)),R: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),transitive_trancl(C,E5))
     => ( ~ member2(C,X,R)
       => ( ~ member2(C,Y,R)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,E5,R)),R)
           => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),transitive_trancl(C,rel_restrict(C,E5,R))) ) ) ) ) ).

% rel_restrict_tranclI
tff(fact_4713_mset__contains__eq,axiom,
    ! [C: $tType,M2: C,M: multiset(C)] :
      ( member2(C,M2,set_mset(C,M))
    <=> ( aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,M2,zero_zero(multiset(C)))),minus_minus(multiset(C),M,add_mset(C,M2,zero_zero(multiset(C))))) = M ) ) ).

% mset_contains_eq
tff(fact_4714_mset__union__diff__comm,axiom,
    ! [C: $tType,T4: C,S: multiset(C),T: multiset(C)] :
      ( member2(C,T4,set_mset(C,S))
     => ( aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),T),minus_minus(multiset(C),S,add_mset(C,T4,zero_zero(multiset(C))))) = minus_minus(multiset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),T),S),add_mset(C,T4,zero_zero(multiset(C)))) ) ) ).

% mset_union_diff_comm
tff(fact_4715_diff__union__single__conv2,axiom,
    ! [C: $tType,A3: C,J4: multiset(C),I5: multiset(C)] :
      ( member2(C,A3,set_mset(C,J4))
     => ( minus_minus(multiset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),J4),I5),add_mset(C,A3,zero_zero(multiset(C)))) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),minus_minus(multiset(C),J4,add_mset(C,A3,zero_zero(multiset(C))))),I5) ) ) ).

% diff_union_single_conv2
tff(fact_4716_mset__un__single__un__cases,axiom,
    ! [C: $tType,A3: C,A4: multiset(C),B3: multiset(C),C4: multiset(C)] :
      ( ( add_mset(C,A3,A4) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B3),C4) )
     => ( ( member2(C,A3,set_mset(C,B3))
         => ( A4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),minus_minus(multiset(C),B3,add_mset(C,A3,zero_zero(multiset(C))))),C4) ) )
       => ~ ( member2(C,A3,set_mset(C,C4))
           => ( A4 != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B3),minus_minus(multiset(C),C4,add_mset(C,A3,zero_zero(multiset(C))))) ) ) ) ) ).

% mset_un_single_un_cases
tff(fact_4717_Image__eq__UN,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(D,C)),B3: set(D)] : image(D,C,R3,B3) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),aTP_Lamp_ph(set(product_prod(D,C)),fun(D,set(C)),R3)),B3)) ).

% Image_eq_UN
tff(fact_4718_Sigma__Image,axiom,
    ! [C: $tType,D: $tType,A4: set(D),B3: fun(D,set(C)),X5: set(D)] : image(D,C,product_Sigma(D,C,A4,B3),X5) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(D),set(set(C)),image2(D,set(C),B3),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),X5),A4))) ).

% Sigma_Image
tff(fact_4719_finite__reachable__advance,axiom,
    ! [C: $tType,E5: set(product_prod(C,C)),V0: C,V: C] :
      ( aa(set(C),$o,finite_finite2(C),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V0),bot_bot(set(C)))))
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),V0),V),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5))
       => aa(set(C),$o,finite_finite2(C),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C))))) ) ) ).

% finite_reachable_advance
tff(fact_4720_rtrancl__Image__advance__ss,axiom,
    ! [C: $tType,U: C,V: C,E5: set(product_prod(C,C))] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),E5)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C))))),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),U),bot_bot(set(C))))) ) ).

% rtrancl_Image_advance_ss
tff(fact_4721_trancl__Image__advance__ss,axiom,
    ! [C: $tType,U: C,V: C,E5: set(product_prod(C,C))] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),E5)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,transitive_trancl(C,E5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),V),bot_bot(set(C))))),image(C,C,transitive_trancl(C,E5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),U),bot_bot(set(C))))) ) ).

% trancl_Image_advance_ss
tff(fact_4722_the__default_Osimps_I1_J,axiom,
    ! [C: $tType,Uu: C,X: C] : the_default(C,Uu,aa(C,option(C),some(C),X)) = X ).

% the_default.simps(1)
tff(fact_4723_the__default_Osimps_I2_J,axiom,
    ! [C: $tType,X: C] : the_default(C,X,none(C)) = X ).

% the_default.simps(2)
tff(fact_4724_trancl__restrict__reachable,axiom,
    ! [C: $tType,U: C,V: C,E5: set(product_prod(C,C)),S: set(C)] :
      ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),transitive_trancl(C,E5))
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,E5,S)),S)
       => ( member2(C,U,S)
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),U),V),transitive_trancl(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),E5),product_Sigma(C,C,S,aTP_Lamp_mg(set(C),fun(C,set(C)),S))))) ) ) ) ).

% trancl_restrict_reachable
tff(fact_4725_singleton__quotient,axiom,
    ! [C: $tType,X: C,R3: set(product_prod(C,C))] : equiv_quotient(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),R3) = aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),bot_bot(set(set(C)))) ).

% singleton_quotient
tff(fact_4726_quotient__def,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] : equiv_quotient(C,A4,R3) = aa(set(set(set(C))),set(set(C)),complete_Sup_Sup(set(set(C))),aa(set(C),set(set(set(C))),image2(C,set(set(C)),aTP_Lamp_pi(set(product_prod(C,C)),fun(C,set(set(C))),R3)),A4)) ).

% quotient_def
tff(fact_4727_sum__wcount__Int,axiom,
    ! [C: $tType,A4: set(C),F: fun(C,nat),N4: multiset(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),wcount(C,F,N4)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),set_mset(C,N4))) = aa(set(C),nat,aa(fun(C,nat),fun(set(C),nat),groups7311177749621191930dd_sum(C,nat),wcount(C,F,N4)),A4) ) ) ).

% sum_wcount_Int
tff(fact_4728_set__mset__replicate__mset__subset,axiom,
    ! [C: $tType,N: nat,X: C] :
      set_mset(C,replicate_mset(C,N,X)) = $ite(N = zero_zero(nat),bot_bot(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ).

% set_mset_replicate_mset_subset
tff(fact_4729_Refl__antisym__eq__Image1__Image1__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( refl_on(C,field2(C,R3),R3)
     => ( antisym(C,R3)
       => ( member2(C,A3,field2(C,R3))
         => ( member2(C,B2,field2(C,R3))
           => ( ( image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) )
            <=> ( A3 = B2 ) ) ) ) ) ) ).

% Refl_antisym_eq_Image1_Image1_iff
tff(fact_4730_antisym__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( antisym(C,R3)
     => antisym(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% antisym_Restr
tff(fact_4731_size__diff__se,axiom,
    ! [C: $tType,T4: C,S: multiset(C)] :
      ( member2(C,T4,set_mset(C,S))
     => ( aa(multiset(C),nat,size_size(multiset(C)),S) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(multiset(C),nat,size_size(multiset(C)),minus_minus(multiset(C),S,add_mset(C,T4,zero_zero(multiset(C)))))),one_one(nat)) ) ) ).

% size_diff_se
tff(fact_4732_sorted__list__of__multiset__def,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [M: multiset(C)] : linord6283353356039996273ltiset(C,M) = fold_mset(C,list(C),linorder_insort_key(C,C,aTP_Lamp_az(C,C)),nil(C),M) ) ).

% sorted_list_of_multiset_def
tff(fact_4733_flat__lub__def,axiom,
    ! [C: $tType,B2: C,A4: set(C)] :
      partial_flat_lub(C,B2,A4) = $ite(aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))),B2,the(C,aa(set(C),fun(C,$o),aTP_Lamp_pj(C,fun(set(C),fun(C,$o)),B2),A4))) ).

% flat_lub_def
tff(fact_4734_mset__size__le1__cases,axiom,
    ! [C: $tType,M: multiset(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(multiset(C),nat,size_size(multiset(C)),M)),aa(nat,nat,suc,zero_zero(nat)))
     => ( ( M != zero_zero(multiset(C)) )
       => ~ ! [M4: C] : M != add_mset(C,M4,zero_zero(multiset(C))) ) ) ).

% mset_size_le1_cases
tff(fact_4735_mset__size1elem,axiom,
    ! [C: $tType,Pa: multiset(C),Q2: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(multiset(C),nat,size_size(multiset(C)),Pa)),one_one(nat))
     => ( member2(C,Q2,set_mset(C,Pa))
       => ( Pa = add_mset(C,Q2,zero_zero(multiset(C))) ) ) ) ).

% mset_size1elem
tff(fact_4736_mset__size2elem,axiom,
    ! [C: $tType,Pa: multiset(C),Q2: C,Q4: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(multiset(C),nat,size_size(multiset(C)),Pa)),aa(num,nat,numeral_numeral(nat),bit0(one2)))
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,Q2,zero_zero(multiset(C)))),add_mset(C,Q4,zero_zero(multiset(C))))),Pa)
       => ( Pa = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,Q2,zero_zero(multiset(C)))),add_mset(C,Q4,zero_zero(multiset(C)))) ) ) ) ).

% mset_size2elem
tff(fact_4737_mset__set__Union,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( aa(set(C),$o,finite_finite2(C),B3)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
         => ( mset_set(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),mset_set(C,A4)),mset_set(C,B3)) ) ) ) ) ).

% mset_set_Union
tff(fact_4738_Partial__order__eq__Image1__Image1__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( order_7125193373082350890der_on(C,field2(C,R3),R3)
     => ( member2(C,A3,field2(C,R3))
       => ( member2(C,B2,field2(C,R3))
         => ( ( image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) )
          <=> ( A3 = B2 ) ) ) ) ) ).

% Partial_order_eq_Image1_Image1_iff
tff(fact_4739_mset__set_Oempty,axiom,
    ! [C: $tType] : mset_set(C,bot_bot(set(C))) = zero_zero(multiset(C)) ).

% mset_set.empty
tff(fact_4740_mset__le__addE,axiom,
    ! [C: $tType,Xs: multiset(C),Ys: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),Xs),Ys)
     => ~ ! [Zs3: multiset(C)] : Ys != aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Xs),Zs3) ) ).

% mset_le_addE
tff(fact_4741_mset__le__distrib,axiom,
    ! [C: $tType,X5: multiset(C),A4: multiset(C),B3: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),X5),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3))
     => ~ ! [Xa5: multiset(C),Xb3: multiset(C)] :
            ( ( X5 = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Xa5),Xb3) )
           => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),Xa5),A4)
             => ~ aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),Xb3),B3) ) ) ) ).

% mset_le_distrib
tff(fact_4742_mset__union__subset,axiom,
    ! [C: $tType,A4: multiset(C),B3: multiset(C),C4: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)),C4)
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A4),C4)
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),C4) ) ) ).

% mset_union_subset
tff(fact_4743_mset__le__decr__left1,axiom,
    ! [C: $tType,A3: multiset(C),C3: multiset(C),B2: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A3),C3)),B2)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),B2) ) ).

% mset_le_decr_left1
tff(fact_4744_mset__le__decr__left2,axiom,
    ! [C: $tType,C3: multiset(C),A3: multiset(C),B2: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),C3),A3)),B2)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),B2) ) ).

% mset_le_decr_left2
tff(fact_4745_mset__le__incr__right1,axiom,
    ! [C: $tType,A3: multiset(C),B2: multiset(C),C3: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),B2)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),B2),C3)) ) ).

% mset_le_incr_right1
tff(fact_4746_mset__le__incr__right2,axiom,
    ! [C: $tType,A3: multiset(C),B2: multiset(C),C3: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),B2)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),C3),B2)) ) ).

% mset_le_incr_right2
tff(fact_4747_mset__le__subtract,axiom,
    ! [C: $tType,A4: multiset(C),B3: multiset(C),C4: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A4),B3)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),minus_minus(multiset(C),A4,C4)),minus_minus(multiset(C),B3,C4)) ) ).

% mset_le_subtract
tff(fact_4748_mset__le__add__mset__decr__left1,axiom,
    ! [C: $tType,C3: C,A3: multiset(C),B2: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,C3,A3)),B2)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A3),B2) ) ).

% mset_le_add_mset_decr_left1
tff(fact_4749_mset__le__add__mset,axiom,
    ! [C: $tType,X: C,B3: multiset(C),C4: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,X,B3)),C4)
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,X,zero_zero(multiset(C)))),C4)
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),C4) ) ) ).

% mset_le_add_mset
tff(fact_4750_mset__le__single__cases,axiom,
    ! [C: $tType,M: multiset(C),A3: C] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),M),add_mset(C,A3,zero_zero(multiset(C))))
     => ( ( M != zero_zero(multiset(C)) )
       => ( M = add_mset(C,A3,zero_zero(multiset(C))) ) ) ) ).

% mset_le_single_cases
tff(fact_4751_mset__le__add__mset__decr__left2,axiom,
    ! [C: $tType,C3: C,A3: multiset(C),B2: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,C3,A3)),B2)
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,C3,zero_zero(multiset(C)))),B2) ) ).

% mset_le_add_mset_decr_left2
tff(fact_4752_mset__le__subtract__left,axiom,
    ! [C: $tType,A4: multiset(C),B3: multiset(C),X5: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)),X5)
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),minus_minus(multiset(C),X5,A4))
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A4),X5) ) ) ).

% mset_le_subtract_left
tff(fact_4753_mset__le__subtract__right,axiom,
    ! [C: $tType,A4: multiset(C),B3: multiset(C),X5: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)),X5)
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),A4),minus_minus(multiset(C),X5,B3))
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),X5) ) ) ).

% mset_le_subtract_right
tff(fact_4754_partial__order__on__empty,axiom,
    ! [C: $tType] : order_7125193373082350890der_on(C,bot_bot(set(C)),bot_bot(set(product_prod(C,C)))) ).

% partial_order_on_empty
tff(fact_4755_mset__le__subtract__add__mset__right,axiom,
    ! [C: $tType,X: C,B3: multiset(C),X5: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,X,B3)),X5)
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,X,zero_zero(multiset(C)))),minus_minus(multiset(C),X5,B3))
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),X5) ) ) ).

% mset_le_subtract_add_mset_right
tff(fact_4756_mset__le__subtract__add__mset__left,axiom,
    ! [C: $tType,X: C,B3: multiset(C),X5: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,X,B3)),X5)
     => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),minus_minus(multiset(C),X5,add_mset(C,X,zero_zero(multiset(C)))))
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),add_mset(C,X,zero_zero(multiset(C)))),X5) ) ) ).

% mset_le_subtract_add_mset_left
tff(fact_4757_subset__mset_OcINF__greatest,axiom,
    ! [D: $tType,C: $tType,A4: set(C),M2: multiset(D),F: fun(C,multiset(D))] :
      ( ( A4 != bot_bot(set(C)) )
     => ( ! [X2: C] :
            ( member2(C,X2,A4)
           => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),M2),aa(C,multiset(D),F,X2)) )
       => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),M2),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))) ) ) ).

% subset_mset.cINF_greatest
tff(fact_4758_subset__mset_OcSUP__least,axiom,
    ! [C: $tType,D: $tType,A4: set(C),F: fun(C,multiset(D)),M: multiset(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( ! [X2: C] :
            ( member2(C,X2,A4)
           => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(C,multiset(D),F,X2)),M) )
       => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))),M) ) ) ).

% subset_mset.cSUP_least
tff(fact_4759_mset__set__empty__iff,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ( mset_set(C,A4) = zero_zero(multiset(C)) )
    <=> ( ( A4 = bot_bot(set(C)) )
        | ~ aa(set(C),$o,finite_finite2(C),A4) ) ) ).

% mset_set_empty_iff
tff(fact_4760_infinite__set__mset__mset__set,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ( set_mset(C,mset_set(C,A4)) = bot_bot(set(C)) ) ) ).

% infinite_set_mset_mset_set
tff(fact_4761_mset__le__mono__add__single,axiom,
    ! [C: $tType,A3: C,Ys: multiset(C),B2: C,Ws2: multiset(C)] :
      ( member2(C,A3,set_mset(C,Ys))
     => ( member2(C,B2,set_mset(C,Ws2))
       => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,A3,zero_zero(multiset(C)))),add_mset(C,B2,zero_zero(multiset(C))))),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),Ys),Ws2)) ) ) ).

% mset_le_mono_add_single
tff(fact_4762_mset__union__subset__s,axiom,
    ! [C: $tType,A3: C,B3: multiset(C),C4: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,A3,zero_zero(multiset(C)))),B3)),C4)
     => ( member2(C,A3,set_mset(C,C4))
        & aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),B3),C4) ) ) ).

% mset_union_subset_s
tff(fact_4763_mset__2dist2__cases,axiom,
    ! [C: $tType,A3: C,B2: C,A4: multiset(C),B3: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,A3,zero_zero(multiset(C)))),add_mset(C,B2,zero_zero(multiset(C))))),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3))
     => ( ~ aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,A3,zero_zero(multiset(C)))),add_mset(C,B2,zero_zero(multiset(C))))),A4)
       => ( ~ aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),add_mset(C,A3,zero_zero(multiset(C)))),add_mset(C,B2,zero_zero(multiset(C))))),B3)
         => ( ( member2(C,A3,set_mset(C,A4))
             => ~ member2(C,B2,set_mset(C,B3)) )
           => ~ ( member2(C,A3,set_mset(C,B3))
               => ~ member2(C,B2,set_mset(C,A4)) ) ) ) ) ) ).

% mset_2dist2_cases
tff(fact_4764_Partial__order__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_7125193373082350890der_on(C,field2(C,R3),R3)
     => order_7125193373082350890der_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% Partial_order_Restr
tff(fact_4765_mset__set_Oinsert__remove,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( mset_set(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = add_mset(C,X,mset_set(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ).

% mset_set.insert_remove
tff(fact_4766_mset__set_Oremove,axiom,
    ! [C: $tType,A4: set(C),X: C] :
      ( aa(set(C),$o,finite_finite2(C),A4)
     => ( member2(C,X,A4)
       => ( mset_set(C,A4) = add_mset(C,X,mset_set(C,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ).

% mset_set.remove
tff(fact_4767_bot_Oordering__top__axioms,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ordering_top(C,aTP_Lamp_pk(C,fun(C,$o)),aTP_Lamp_pl(C,fun(C,$o)),bot_bot(C)) ) ).

% bot.ordering_top_axioms
tff(fact_4768_prod__mset_Oremove,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [X: C,A4: multiset(C)] :
          ( member2(C,X,set_mset(C,A4))
         => ( aa(multiset(C),C,comm_m9189036328036947845d_mset(C),A4) = aa(C,C,aa(C,fun(C,C),times_times(C),X),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),minus_minus(multiset(C),A4,add_mset(C,X,zero_zero(multiset(C)))))) ) ) ) ).

% prod_mset.remove
tff(fact_4769_proj__def,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(D,C)),X: D] : equiv_proj(D,C,R3,X) = image(D,C,R3,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D)))) ).

% proj_def
tff(fact_4770_prod__mset__empty,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ( aa(multiset(C),C,comm_m9189036328036947845d_mset(C),zero_zero(multiset(C))) = one_one(C) ) ) ).

% prod_mset_empty
tff(fact_4771_prod__mset_Oadd__mset,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [X: C,N4: multiset(C)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),add_mset(C,X,N4)) = aa(C,C,aa(C,fun(C,C),times_times(C),X),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),N4)) ) ).

% prod_mset.add_mset
tff(fact_4772_prod__mset_Ounion,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M: multiset(C),N4: multiset(C)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),M),N4)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),M)),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),N4)) ) ).

% prod_mset.union
tff(fact_4773_prod__mset__Un,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: multiset(C),B3: multiset(C)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),A4)),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),B3)) ) ).

% prod_mset_Un
tff(fact_4774_ordering__top_Oextremum,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C,A3: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),Top) ) ).

% ordering_top.extremum
tff(fact_4775_ordering__top_Oextremum__strict,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C,A3: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => ~ aa(C,$o,aa(C,fun(C,$o),Less,Top),A3) ) ).

% ordering_top.extremum_strict
tff(fact_4776_ordering__top_Oextremum__unique,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C,A3: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,Top),A3)
      <=> ( A3 = Top ) ) ) ).

% ordering_top.extremum_unique
tff(fact_4777_ordering__top_Onot__eq__extremum,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C,A3: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => ( ( A3 != Top )
      <=> aa(C,$o,aa(C,fun(C,$o),Less,A3),Top) ) ) ).

% ordering_top.not_eq_extremum
tff(fact_4778_ordering__top_Oextremum__uniqueI,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C,A3: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,Top),A3)
       => ( A3 = Top ) ) ) ).

% ordering_top.extremum_uniqueI
tff(fact_4779_prod__mset_Oneutral,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: multiset(C)] :
          ( ! [X2: C] :
              ( member2(C,X2,set_mset(C,A4))
             => ( X2 = one_one(C) ) )
         => ( aa(multiset(C),C,comm_m9189036328036947845d_mset(C),A4) = one_one(C) ) ) ) ).

% prod_mset.neutral
tff(fact_4780_is__unit__prod__mset__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A4: multiset(C)] :
          ( dvd_dvd(C,aa(multiset(C),C,comm_m9189036328036947845d_mset(C),A4),one_one(C))
        <=> ! [X4: C] :
              ( member2(C,X4,set_mset(C,A4))
             => dvd_dvd(C,X4,one_one(C)) ) ) ) ).

% is_unit_prod_mset_iff
tff(fact_4781_prod__mset_Oeq__fold,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [M: multiset(C)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),M) = fold_mset(C,C,times_times(C),one_one(C),M) ) ).

% prod_mset.eq_fold
tff(fact_4782_top_Oordering__top__axioms,axiom,
    ! [C: $tType] :
      ( order_top(C)
     => ordering_top(C,ord_less_eq(C),ord_less(C),top_top(C)) ) ).

% top.ordering_top_axioms
tff(fact_4783_proj__iff,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X: C,Y: C] :
      ( equiv_equiv(C,A4,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C))))),A4)
       => ( ( equiv_proj(C,C,R3,X) = equiv_proj(C,C,R3,Y) )
        <=> member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3) ) ) ) ).

% proj_iff
tff(fact_4784_cSUP__UNION,axiom,
    ! [D: $tType,E2: $tType,C: $tType] :
      ( condit1219197933456340205attice(E2)
     => ! [A4: set(C),B3: fun(C,set(D)),F: fun(D,E2)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => ( aa(C,set(D),B3,X2) != bot_bot(set(D)) ) )
           => ( condit941137186595557371_above(E2,aa(set(set(E2)),set(E2),complete_Sup_Sup(set(E2)),aa(set(C),set(set(E2)),image2(C,set(E2),aa(fun(D,E2),fun(C,set(E2)),aTP_Lamp_pm(fun(C,set(D)),fun(fun(D,E2),fun(C,set(E2))),B3),F)),A4)))
             => ( aa(set(E2),E2,complete_Sup_Sup(E2),aa(set(D),set(E2),image2(D,E2,F),aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),B3),A4)))) = aa(set(E2),E2,complete_Sup_Sup(E2),aa(set(C),set(E2),image2(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_pn(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),B3),F)),A4)) ) ) ) ) ) ).

% cSUP_UNION
tff(fact_4785_mono__cSup,axiom,
    ! [D: $tType,C: $tType] :
      ( ( condit1219197933456340205attice(C)
        & condit1219197933456340205attice(D) )
     => ! [F: fun(C,D),A4: set(C)] :
          ( order_mono(C,D,F)
         => ( condit941137186595557371_above(C,A4)
           => ( ( A4 != bot_bot(set(C)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(C,D,F,aa(set(C),C,complete_Sup_Sup(C),A4))) ) ) ) ) ).

% mono_cSup
tff(fact_4786_bdd__above__empty,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => condit941137186595557371_above(C,bot_bot(set(C))) ) ).

% bdd_above_empty
tff(fact_4787_equiv__listrel,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] :
      ( equiv_equiv(C,A4,R3)
     => equiv_equiv(list(C),aa(set(C),set(list(C)),lists(C),A4),listrel(C,C,R3)) ) ).

% equiv_listrel
tff(fact_4788_bdd__above__Int1,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( condit941137186595557371_above(C,A4)
         => condit941137186595557371_above(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% bdd_above_Int1
tff(fact_4789_bdd__above__Int2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B3: set(C),A4: set(C)] :
          ( condit941137186595557371_above(C,B3)
         => condit941137186595557371_above(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% bdd_above_Int2
tff(fact_4790_in__quotient__imp__non__empty,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X5: set(C)] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(set(C),X5,equiv_quotient(C,A4,R3))
       => ( X5 != bot_bot(set(C)) ) ) ) ).

% in_quotient_imp_non_empty
tff(fact_4791_cSup__le__iff,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [S: set(C),A3: C] :
          ( ( S != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,S)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),S)),A3)
            <=> ! [X4: C] :
                  ( member2(C,X4,S)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),A3) ) ) ) ) ) ).

% cSup_le_iff
tff(fact_4792_cSup__mono,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [B3: set(C),A4: set(C)] :
          ( ( B3 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,A4)
           => ( ! [B4: C] :
                  ( member2(C,B4,B3)
                 => ? [X3: C] :
                      ( member2(C,X3,A4)
                      & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B4),X3) ) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),B3)),aa(set(C),C,complete_Sup_Sup(C),A4)) ) ) ) ) ).

% cSup_mono
tff(fact_4793_less__cSup__iff,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C),Y: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,X5)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),aa(set(C),C,complete_Sup_Sup(C),X5))
            <=> ? [X4: C] :
                  ( member2(C,X4,X5)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y),X4) ) ) ) ) ) ).

% less_cSup_iff
tff(fact_4794_equiv__class__self,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),A3: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(C,A3,A4)
       => member2(C,A3,image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) ) ) ).

% equiv_class_self
tff(fact_4795_quotient__disj,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X5: set(C),Y5: set(C)] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(set(C),X5,equiv_quotient(C,A4,R3))
       => ( member2(set(C),Y5,equiv_quotient(C,A4,R3))
         => ( ( X5 = Y5 )
            | ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),X5),Y5) = bot_bot(set(C)) ) ) ) ) ) ).

% quotient_disj
tff(fact_4796_cSUP__le__iff,axiom,
    ! [C: $tType,D: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),U: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),U)
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X4)),U) ) ) ) ) ) ).

% cSUP_le_iff
tff(fact_4797_cSUP__mono,axiom,
    ! [C: $tType,D: $tType,E2: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),G: fun(E2,D),B3: set(E2),F: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(E2),set(D),image2(E2,D,G),B3))
           => ( ! [N7: C] :
                  ( member2(C,N7,A4)
                 => ? [X3: E2] :
                      ( member2(E2,X3,B3)
                      & aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,N7)),aa(E2,D,G,X3)) ) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Sup_Sup(D),aa(set(E2),set(D),image2(E2,D,G),B3))) ) ) ) ) ).

% cSUP_mono
tff(fact_4798_cSup__subset__mono,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,B3)
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),A4)),aa(set(C),C,complete_Sup_Sup(C),B3)) ) ) ) ) ).

% cSup_subset_mono
tff(fact_4799_cSup__insert,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),A3: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,X5)
           => ( aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),X5)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),aa(set(C),C,complete_Sup_Sup(C),X5)) ) ) ) ) ).

% cSup_insert
tff(fact_4800_cSup__insert__If,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),A3: C] :
          ( condit941137186595557371_above(C,X5)
         => ( aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),X5)) = $ite(X5 = bot_bot(set(C)),A3,aa(C,C,aa(C,fun(C,C),sup_sup(C),A3),aa(set(C),C,complete_Sup_Sup(C),X5))) ) ) ) ).

% cSup_insert_If
tff(fact_4801_cSup__union__distrib,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,A4)
           => ( ( B3 != bot_bot(set(C)) )
             => ( condit941137186595557371_above(C,B3)
               => ( aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(set(C),C,complete_Sup_Sup(C),A4)),aa(set(C),C,complete_Sup_Sup(C),B3)) ) ) ) ) ) ) ).

% cSup_union_distrib
tff(fact_4802_equiv__class__eq__iff,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X: C,Y: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3)
      <=> ( ( image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C)))) )
          & member2(C,X,A4)
          & member2(C,Y,A4) ) ) ) ).

% equiv_class_eq_iff
tff(fact_4803_eq__equiv__class__iff,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X: C,Y: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(C,X,A4)
       => ( member2(C,Y,A4)
         => ( ( image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C)))) )
          <=> member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3) ) ) ) ) ).

% eq_equiv_class_iff
tff(fact_4804_equiv__class__eq,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3)
       => ( image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) ) ) ) ).

% equiv_class_eq
tff(fact_4805_eq__equiv__class,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C,A4: set(C)] :
      ( ( image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) = image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))) )
     => ( equiv_equiv(C,A4,R3)
       => ( member2(C,B2,A4)
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3) ) ) ) ).

% eq_equiv_class
tff(fact_4806_eq__equiv__class__iff2,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X: C,Y: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(C,X,A4)
       => ( member2(C,Y,A4)
         => ( ( equiv_quotient(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))),R3) = equiv_quotient(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C))),R3) )
          <=> member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3) ) ) ) ) ).

% eq_equiv_class_iff2
tff(fact_4807_refines__equiv__class__eq2,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),S: set(product_prod(C,C)),A4: set(C),A3: C] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),S)
     => ( equiv_equiv(C,A4,R)
       => ( equiv_equiv(C,A4,S)
         => ( image(C,C,S,image(C,C,R,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = image(C,C,S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ) ) ) ) ).

% refines_equiv_class_eq2
tff(fact_4808_refines__equiv__class__eq,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),S: set(product_prod(C,C)),A4: set(C),A3: C] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),S)
     => ( equiv_equiv(C,A4,R)
       => ( equiv_equiv(C,A4,S)
         => ( image(C,C,R,image(C,C,S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) = image(C,C,S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ) ) ) ) ).

% refines_equiv_class_eq
tff(fact_4809_less__cSUP__iff,axiom,
    ! [D: $tType,C: $tType] :
      ( condit6923001295902523014norder(D)
     => ! [A4: set(C),F: fun(C,D),A3: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),A3),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4)))
            <=> ? [X4: C] :
                  ( member2(C,X4,A4)
                  & aa(D,$o,aa(D,fun(D,$o),ord_less(D),A3),aa(C,D,F,X4)) ) ) ) ) ) ).

% less_cSUP_iff
tff(fact_4810_conditionally__complete__lattice__class_OSUP__sup__distrib,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),G: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,G),A4))
             => ( aa(D,D,aa(D,fun(D,D),sup_sup(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,G),A4))) = aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_po(fun(C,D),fun(fun(C,D),fun(C,D)),F),G)),A4)) ) ) ) ) ) ).

% conditionally_complete_lattice_class.SUP_sup_distrib
tff(fact_4811_cSUP__subset__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),G: fun(C,D),B3: set(C),F: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,G),B3))
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
             => ( ! [X2: C] :
                    ( member2(C,X2,A4)
                   => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,G,X2)) )
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,G),B3))) ) ) ) ) ) ).

% cSUP_subset_mono
tff(fact_4812_cSup__inter__less__eq,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( condit941137186595557371_above(C,A4)
         => ( condit941137186595557371_above(C,B3)
           => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) != bot_bot(set(C)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))),aa(C,C,aa(C,fun(C,C),sup_sup(C),aa(set(C),C,complete_Sup_Sup(C),A4)),aa(set(C),C,complete_Sup_Sup(C),B3))) ) ) ) ) ).

% cSup_inter_less_eq
tff(fact_4813_cSUP__insert,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),A3: C] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4))) = aa(D,D,aa(D,fun(D,D),sup_sup(D),aa(C,D,F,A3)),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))) ) ) ) ) ).

% cSUP_insert
tff(fact_4814_cSUP__union,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),B3: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( ( B3 != bot_bot(set(C)) )
             => ( condit941137186595557371_above(D,aa(set(C),set(D),image2(C,D,F),B3))
               => ( aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))) = aa(D,D,aa(D,fun(D,D),sup_sup(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Sup_Sup(D),aa(set(C),set(D),image2(C,D,F),B3))) ) ) ) ) ) ) ).

% cSUP_union
tff(fact_4815_equiv__class__subset,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) ) ) ).

% equiv_class_subset
tff(fact_4816_subset__equiv__class,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),B2: C,A3: C] :
      ( equiv_equiv(C,A4,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))
       => ( member2(C,B2,A4)
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3) ) ) ) ).

% subset_equiv_class
tff(fact_4817_equiv__class__nondisjoint,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X: C,A3: C,B2: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(C,X,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))))
       => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3) ) ) ).

% equiv_class_nondisjoint
tff(fact_4818_in__quotient__imp__in__rel,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),X5: set(C),X: C,Y: C] :
      ( equiv_equiv(C,A4,R3)
     => ( member2(set(C),X5,equiv_quotient(C,A4,R3))
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C))))),X5)
         => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y),R3) ) ) ) ).

% in_quotient_imp_in_rel
tff(fact_4819_cSup__cInf,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [S: set(C)] :
          ( ( S != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,S)
           => ( aa(set(C),C,complete_Sup_Sup(C),S) = aa(set(C),C,complete_Inf_Inf(C),collect(C,aTP_Lamp_pp(set(C),fun(C,$o),S))) ) ) ) ) ).

% cSup_cInf
tff(fact_4820_mono__cSUP,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( ( condit1219197933456340205attice(C)
        & condit1219197933456340205attice(D) )
     => ! [F: fun(C,D),A4: fun(E2,C),I5: set(E2)] :
          ( order_mono(C,D,F)
         => ( condit941137186595557371_above(C,aa(set(E2),set(C),image2(E2,C,A4),I5))
           => ( ( I5 != bot_bot(set(E2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(E2),set(D),image2(E2,D,aa(fun(E2,C),fun(E2,D),aTP_Lamp_pq(fun(C,D),fun(fun(E2,C),fun(E2,D)),F),A4)),I5))),aa(C,D,F,aa(set(C),C,complete_Sup_Sup(C),aa(set(E2),set(C),image2(E2,C,A4),I5)))) ) ) ) ) ).

% mono_cSUP
tff(fact_4821_UN__equiv__class2,axiom,
    ! [C: $tType,E2: $tType,D: $tType,A14: set(C),R1: set(product_prod(C,C)),A24: set(D),R2: set(product_prod(D,D)),F: fun(C,fun(D,set(E2))),A1: C,A22: D] :
      ( equiv_equiv(C,A14,R1)
     => ( equiv_equiv(D,A24,R2)
       => ( equiv_congruent2(C,D,set(E2),R1,R2,F)
         => ( member2(C,A1,A14)
           => ( member2(D,A22,A24)
             => ( aa(set(set(E2)),set(E2),complete_Sup_Sup(set(E2)),aa(set(C),set(set(E2)),image2(C,set(E2),aa(D,fun(C,set(E2)),aa(fun(C,fun(D,set(E2))),fun(D,fun(C,set(E2))),aTP_Lamp_pr(set(product_prod(D,D)),fun(fun(C,fun(D,set(E2))),fun(D,fun(C,set(E2)))),R2),F),A22)),image(C,C,R1,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A1),bot_bot(set(C)))))) = aa(D,set(E2),aa(C,fun(D,set(E2)),F,A1),A22) ) ) ) ) ) ) ).

% UN_equiv_class2
tff(fact_4822_UN__equiv__class,axiom,
    ! [D: $tType,C: $tType,A4: set(C),R3: set(product_prod(C,C)),F: fun(C,set(D)),A3: C] :
      ( equiv_equiv(C,A4,R3)
     => ( equiv_congruent(C,set(D),R3,F)
       => ( member2(C,A3,A4)
         => ( aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),F),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) = aa(C,set(D),F,A3) ) ) ) ) ).

% UN_equiv_class
tff(fact_4823_disjnt__equiv__class,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( equiv_equiv(C,A4,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))),image(C,C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))))
      <=> ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3) ) ) ).

% disjnt_equiv_class
tff(fact_4824_disjnt__self__iff__empty,axiom,
    ! [C: $tType,S: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),S),S)
    <=> ( S = bot_bot(set(C)) ) ) ).

% disjnt_self_iff_empty
tff(fact_4825_disjnt__insert2,axiom,
    ! [C: $tType,Y5: set(C),A3: C,X5: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),Y5),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),X5))
    <=> ( ~ member2(C,A3,Y5)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),Y5),X5) ) ) ).

% disjnt_insert2
tff(fact_4826_disjnt__insert1,axiom,
    ! [C: $tType,A3: C,X5: set(C),Y5: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),X5)),Y5)
    <=> ( ~ member2(C,A3,Y5)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),X5),Y5) ) ) ).

% disjnt_insert1
tff(fact_4827_disjnt__Un2,axiom,
    ! [C: $tType,C4: set(C),A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),C4),A4)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),C4),B3) ) ) ).

% disjnt_Un2
tff(fact_4828_disjnt__Un1,axiom,
    ! [C: $tType,A4: set(C),B3: set(C),C4: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)),C4)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),C4)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),B3),C4) ) ) ).

% disjnt_Un1
tff(fact_4829_disjnt__Times1__iff,axiom,
    ! [C: $tType,D: $tType,C4: set(C),A4: set(D),B3: set(D)] :
      ( aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),disjnt(product_prod(C,D)),product_Sigma(C,D,C4,aTP_Lamp_mb(set(D),fun(C,set(D)),A4))),product_Sigma(C,D,C4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))
    <=> ( ( C4 = bot_bot(set(C)) )
        | aa(set(D),$o,aa(set(D),fun(set(D),$o),disjnt(D),A4),B3) ) ) ).

% disjnt_Times1_iff
tff(fact_4830_disjnt__Times2__iff,axiom,
    ! [D: $tType,C: $tType,A4: set(C),C4: set(D),B3: set(C)] :
      ( aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),disjnt(product_prod(C,D)),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),C4))),product_Sigma(C,D,B3,aTP_Lamp_mb(set(D),fun(C,set(D)),C4)))
    <=> ( ( C4 = bot_bot(set(D)) )
        | aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),B3) ) ) ).

% disjnt_Times2_iff
tff(fact_4831_disjnt__Sigma__iff,axiom,
    ! [D: $tType,C: $tType,A4: set(C),C4: fun(C,set(D)),B3: set(C)] :
      ( aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),disjnt(product_prod(C,D)),product_Sigma(C,D,A4,C4)),product_Sigma(C,D,B3,C4))
    <=> ( ! [X4: C] :
            ( member2(C,X4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))
           => ( aa(C,set(D),C4,X4) = bot_bot(set(D)) ) )
        | aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),B3) ) ) ).

% disjnt_Sigma_iff
tff(fact_4832_disjnt__insert,axiom,
    ! [C: $tType,X: C,N4: set(C),M: set(C)] :
      ( ~ member2(C,X,N4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),M),N4)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),M)),N4) ) ) ).

% disjnt_insert
tff(fact_4833_disjnt__iff,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),B3)
    <=> ! [X4: C] :
          ~ ( member2(C,X4,A4)
            & member2(C,X4,B3) ) ) ).

% disjnt_iff
tff(fact_4834_disjnt__sym,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),B3)
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),B3),A4) ) ).

% disjnt_sym
tff(fact_4835_disjnt__empty2,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),bot_bot(set(C))) ).

% disjnt_empty2
tff(fact_4836_disjnt__empty1,axiom,
    ! [C: $tType,A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),bot_bot(set(C))),A4) ).

% disjnt_empty1
tff(fact_4837_disjnt__subset1,axiom,
    ! [C: $tType,X5: set(C),Y5: set(C),Z6: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),X5),Y5)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),Z6),X5)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),Z6),Y5) ) ) ).

% disjnt_subset1
tff(fact_4838_disjnt__subset2,axiom,
    ! [C: $tType,X5: set(C),Y5: set(C),Z6: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),X5),Y5)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),Z6),Y5)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),X5),Z6) ) ) ).

% disjnt_subset2
tff(fact_4839_disjnt__def,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),disjnt(C),A4),B3)
    <=> ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) ) ) ).

% disjnt_def
tff(fact_4840_congruent2__implies__congruent__UN,axiom,
    ! [C: $tType,E2: $tType,D: $tType,A14: set(C),R1: set(product_prod(C,C)),A24: set(D),R2: set(product_prod(D,D)),F: fun(C,fun(D,set(E2))),A3: D] :
      ( equiv_equiv(C,A14,R1)
     => ( equiv_equiv(D,A24,R2)
       => ( equiv_congruent2(C,D,set(E2),R1,R2,F)
         => ( member2(D,A3,A24)
           => equiv_congruent(C,set(E2),R1,aa(D,fun(C,set(E2)),aa(fun(C,fun(D,set(E2))),fun(D,fun(C,set(E2))),aTP_Lamp_pr(set(product_prod(D,D)),fun(fun(C,fun(D,set(E2))),fun(D,fun(C,set(E2)))),R2),F),A3)) ) ) ) ) ).

% congruent2_implies_congruent_UN
tff(fact_4841_cINF__UNION,axiom,
    ! [D: $tType,E2: $tType,C: $tType] :
      ( condit1219197933456340205attice(E2)
     => ! [A4: set(C),B3: fun(C,set(D)),F: fun(D,E2)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => ( aa(C,set(D),B3,X2) != bot_bot(set(D)) ) )
           => ( condit1013018076250108175_below(E2,aa(set(set(E2)),set(E2),complete_Sup_Sup(set(E2)),aa(set(C),set(set(E2)),image2(C,set(E2),aa(fun(D,E2),fun(C,set(E2)),aTP_Lamp_pm(fun(C,set(D)),fun(fun(D,E2),fun(C,set(E2))),B3),F)),A4)))
             => ( aa(set(E2),E2,complete_Inf_Inf(E2),aa(set(D),set(E2),image2(D,E2,F),aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),B3),A4)))) = aa(set(E2),E2,complete_Inf_Inf(E2),aa(set(C),set(E2),image2(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_ps(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),B3),F)),A4)) ) ) ) ) ) ).

% cINF_UNION
tff(fact_4842_mono__cInf,axiom,
    ! [D: $tType,C: $tType] :
      ( ( condit1219197933456340205attice(C)
        & condit1219197933456340205attice(D) )
     => ! [F: fun(C,D),A4: set(C)] :
          ( order_mono(C,D,F)
         => ( condit1013018076250108175_below(C,A4)
           => ( ( A4 != bot_bot(set(C)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,aa(set(C),C,complete_Inf_Inf(C),A4))),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))) ) ) ) ) ).

% mono_cInf
tff(fact_4843_mono__cINF,axiom,
    ! [C: $tType,D: $tType,E2: $tType] :
      ( ( condit1219197933456340205attice(D)
        & condit1219197933456340205attice(C) )
     => ! [F: fun(C,D),A4: fun(E2,C),I5: set(E2)] :
          ( order_mono(C,D,F)
         => ( condit1013018076250108175_below(C,aa(set(E2),set(C),image2(E2,C,A4),I5))
           => ( ( I5 != bot_bot(set(E2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,aa(set(C),C,complete_Inf_Inf(C),aa(set(E2),set(C),image2(E2,C,A4),I5)))),aa(set(D),D,complete_Inf_Inf(D),aa(set(E2),set(D),image2(E2,D,aa(fun(E2,C),fun(E2,D),aTP_Lamp_pq(fun(C,D),fun(fun(E2,C),fun(E2,D)),F),A4)),I5))) ) ) ) ) ).

% mono_cINF
tff(fact_4844_bdd__below__empty,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => condit1013018076250108175_below(C,bot_bot(set(C))) ) ).

% bdd_below_empty
tff(fact_4845_bdd__below__image__inf,axiom,
    ! [C: $tType,D: $tType] :
      ( lattice(C)
     => ! [F: fun(D,C),G: fun(D,C),A4: set(D)] :
          ( condit1013018076250108175_below(C,aa(set(D),set(C),image2(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_pt(fun(D,C),fun(fun(D,C),fun(D,C)),F),G)),A4))
        <=> ( condit1013018076250108175_below(C,aa(set(D),set(C),image2(D,C,F),A4))
            & condit1013018076250108175_below(C,aa(set(D),set(C),image2(D,C,G),A4)) ) ) ) ).

% bdd_below_image_inf
tff(fact_4846_bdd__below__Int2,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [B3: set(C),A4: set(C)] :
          ( condit1013018076250108175_below(C,B3)
         => condit1013018076250108175_below(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% bdd_below_Int2
tff(fact_4847_bdd__below__Int1,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [A4: set(C),B3: set(C)] :
          ( condit1013018076250108175_below(C,A4)
         => condit1013018076250108175_below(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% bdd_below_Int1
tff(fact_4848_cInf__mono,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [B3: set(C),A4: set(C)] :
          ( ( B3 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,A4)
           => ( ! [B4: C] :
                  ( member2(C,B4,B3)
                 => ? [X3: C] :
                      ( member2(C,X3,A4)
                      & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X3),B4) ) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Inf_Inf(C),B3)) ) ) ) ) ).

% cInf_mono
tff(fact_4849_le__cInf__iff,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [S: set(C),A3: C] :
          ( ( S != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,S)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),aa(set(C),C,complete_Inf_Inf(C),S))
            <=> ! [X4: C] :
                  ( member2(C,X4,S)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),X4) ) ) ) ) ) ).

% le_cInf_iff
tff(fact_4850_cInf__less__iff,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [X5: set(C),Y: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,X5)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(set(C),C,complete_Inf_Inf(C),X5)),Y)
            <=> ? [X4: C] :
                  ( member2(C,X4,X5)
                  & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y) ) ) ) ) ) ).

% cInf_less_iff
tff(fact_4851_cINF__mono,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [B3: set(C),F: fun(E2,D),A4: set(E2),G: fun(C,D)] :
          ( ( B3 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(E2),set(D),image2(E2,D,F),A4))
           => ( ! [M4: C] :
                  ( member2(C,M4,B3)
                 => ? [X3: E2] :
                      ( member2(E2,X3,A4)
                      & aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(E2,D,F,X3)),aa(C,D,G,M4)) ) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(E2),set(D),image2(E2,D,F),A4))),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,G),B3))) ) ) ) ) ).

% cINF_mono
tff(fact_4852_le__cINF__iff,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),U: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),U),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4)))
            <=> ! [X4: C] :
                  ( member2(C,X4,A4)
                 => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),U),aa(C,D,F,X4)) ) ) ) ) ) ).

% le_cINF_iff
tff(fact_4853_cInf__superset__mono,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,B3)
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Inf_Inf(C),B3)),aa(set(C),C,complete_Inf_Inf(C),A4)) ) ) ) ) ).

% cInf_superset_mono
tff(fact_4854_cInf__insert,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),A3: C] :
          ( ( X5 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,X5)
           => ( aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),X5)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Inf_Inf(C),X5)) ) ) ) ) ).

% cInf_insert
tff(fact_4855_cInf__insert__If,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [X5: set(C),A3: C] :
          ( condit1013018076250108175_below(C,X5)
         => ( aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),X5)) = $ite(X5 = bot_bot(set(C)),A3,aa(C,C,aa(C,fun(C,C),inf_inf(C),A3),aa(set(C),C,complete_Inf_Inf(C),X5))) ) ) ) ).

% cInf_insert_If
tff(fact_4856_cInf__union__distrib,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,A4)
           => ( ( B3 != bot_bot(set(C)) )
             => ( condit1013018076250108175_below(C,B3)
               => ( aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3)) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Inf_Inf(C),B3)) ) ) ) ) ) ) ).

% cInf_union_distrib
tff(fact_4857_cINF__less__iff,axiom,
    ! [C: $tType,D: $tType] :
      ( condit6923001295902523014norder(D)
     => ! [A4: set(C),F: fun(C,D),A3: D] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))),A3)
            <=> ? [X4: C] :
                  ( member2(C,X4,A4)
                  & aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X4)),A3) ) ) ) ) ) ).

% cINF_less_iff
tff(fact_4858_cINF__inf__distrib,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),G: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,G),A4))
             => ( aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,G),A4))) = aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_pu(fun(C,D),fun(fun(C,D),fun(C,D)),F),G)),A4)) ) ) ) ) ) ).

% cINF_inf_distrib
tff(fact_4859_cINF__superset__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),G: fun(C,D),B3: set(C),F: fun(C,D)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,G),B3))
           => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
             => ( ! [X2: C] :
                    ( member2(C,X2,B3)
                   => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,G,X2)),aa(C,D,F,X2)) )
               => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,G),B3))),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))) ) ) ) ) ) ).

% cINF_superset_mono
tff(fact_4860_less__eq__cInf__inter,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C),B3: set(C)] :
          ( condit1013018076250108175_below(C,A4)
         => ( condit1013018076250108175_below(C,B3)
           => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) != bot_bot(set(C)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Inf_Inf(C),B3))),aa(set(C),C,complete_Inf_Inf(C),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3))) ) ) ) ) ).

% less_eq_cInf_inter
tff(fact_4861_cINF__insert,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),A3: C] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4))) = aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(C,D,F,A3)),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))) ) ) ) ) ).

% cINF_insert
tff(fact_4862_cINF__union,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [A4: set(C),F: fun(C,D),B3: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,F),A4))
           => ( ( B3 != bot_bot(set(C)) )
             => ( condit1013018076250108175_below(D,aa(set(C),set(D),image2(C,D,F),B3))
               => ( aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))) = aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),A4))),aa(set(D),D,complete_Inf_Inf(D),aa(set(C),set(D),image2(C,D,F),B3))) ) ) ) ) ) ) ).

% cINF_union
tff(fact_4863_cInf__le__cSup,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [A4: set(C)] :
          ( ( A4 != bot_bot(set(C)) )
         => ( condit941137186595557371_above(C,A4)
           => ( condit1013018076250108175_below(C,A4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Inf_Inf(C),A4)),aa(set(C),C,complete_Sup_Sup(C),A4)) ) ) ) ) ).

% cInf_le_cSup
tff(fact_4864_cInf__cSup,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [S: set(C)] :
          ( ( S != bot_bot(set(C)) )
         => ( condit1013018076250108175_below(C,S)
           => ( aa(set(C),C,complete_Inf_Inf(C),S) = aa(set(C),C,complete_Sup_Sup(C),collect(C,aTP_Lamp_pv(set(C),fun(C,$o),S))) ) ) ) ) ).

% cInf_cSup
tff(fact_4865_numeral__num__of__nat__unfold,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [N: nat] :
          aa(num,C,numeral_numeral(C),num_of_nat(N)) = $ite(N = zero_zero(nat),one_one(C),aa(nat,C,semiring_1_of_nat(C),N)) ) ).

% numeral_num_of_nat_unfold
tff(fact_4866_subset__singleton__iff__Uniq,axiom,
    ! [C: $tType,A4: set(C)] :
      ( ? [A6: C] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A6),bot_bot(set(C))))
    <=> uniq(C,aTP_Lamp_a(set(C),fun(C,$o),A4)) ) ).

% subset_singleton_iff_Uniq
tff(fact_4867_uncurry__apply,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F: fun(D,fun(E2,C)),A3: D,B2: E2] : aa(product_prod(D,E2),C,uncurry(D,E2,C,F),aa(E2,product_prod(D,E2),aa(D,fun(E2,product_prod(D,E2)),product_Pair(D,E2),A3),B2)) = aa(E2,C,aa(D,fun(E2,C),F,A3),B2) ).

% uncurry_apply
tff(fact_4868_uncurry__def,axiom,
    ! [E2: $tType,D: $tType,C: $tType,F: fun(C,fun(D,E2))] : uncurry(C,D,E2,F) = product_case_prod(C,D,E2,F) ).

% uncurry_def
tff(fact_4869_strict__sorted__equal__Uniq,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A4: set(C)] : uniq(list(C),aTP_Lamp_pw(set(C),fun(list(C),$o),A4)) ) ).

% strict_sorted_equal_Uniq
tff(fact_4870_ex__is__arg__min__if__finite,axiom,
    ! [D: $tType,C: $tType] :
      ( order(D)
     => ! [S: set(C),F: fun(C,D)] :
          ( aa(set(C),$o,finite_finite2(C),S)
         => ( ( S != bot_bot(set(C)) )
           => ? [X_1: C] : lattic501386751177426532rg_min(C,D,F,aTP_Lamp_a(set(C),fun(C,$o),S),X_1) ) ) ) ).

% ex_is_arg_min_if_finite
tff(fact_4871_interval__cases,axiom,
    ! [C: $tType] :
      ( condit6923001295902523014norder(C)
     => ! [S: set(C)] :
          ( ! [A5: C,B4: C,X2: C] :
              ( member2(C,A5,S)
             => ( member2(C,B4,S)
               => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A5),X2)
                 => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),B4)
                   => member2(C,X2,S) ) ) ) )
         => ? [A5: C,B4: C] :
              ( ( S = bot_bot(set(C)) )
              | ( S = top_top(set(C)) )
              | ( S = set_ord_lessThan(C,B4) )
              | ( S = set_ord_atMost(C,B4) )
              | ( S = set_ord_greaterThan(C,A5) )
              | ( S = set_ord_atLeast(C,A5) )
              | ( S = set_or5935395276787703475ssThan(C,A5,B4) )
              | ( S = set_or3652927894154168847AtMost(C,A5,B4) )
              | ( S = set_or7035219750837199246ssThan(C,A5,B4) )
              | ( S = set_or1337092689740270186AtMost(C,A5,B4) ) ) ) ) ).

% interval_cases
tff(fact_4872_take__Cons,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),N),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = case_nat(list(C),nil(C),aa(list(C),fun(nat,list(C)),aTP_Lamp_px(C,fun(list(C),fun(nat,list(C))),X),Xs),N) ).

% take_Cons
tff(fact_4873_atLeast__empty__triv,axiom,
    ! [C: $tType] : set_ord_atLeast(set(C),bot_bot(set(C))) = top_top(set(set(C))) ).

% atLeast_empty_triv
tff(fact_4874_Int__atLeastAtMostR2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,C3: C,D3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atLeast(C,A3)),set_or1337092689740270186AtMost(C,C3,D3)) = set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3),D3) ) ).

% Int_atLeastAtMostR2
tff(fact_4875_Int__atLeastAtMostL2,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C,C3: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or1337092689740270186AtMost(C,A3,B2)),set_ord_atLeast(C,C3)) = set_or1337092689740270186AtMost(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),C3),B2) ) ).

% Int_atLeastAtMostL2
tff(fact_4876_ivl__disj__un__singleton_I1_J,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [La: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),La),bot_bot(set(C)))),set_ord_greaterThan(C,La)) = set_ord_atLeast(C,La) ) ).

% ivl_disj_un_singleton(1)
tff(fact_4877_greaterThan__non__empty,axiom,
    ! [C: $tType] :
      ( no_top(C)
     => ! [X: C] : set_ord_greaterThan(C,X) != bot_bot(set(C)) ) ).

% greaterThan_non_empty
tff(fact_4878_not__empty__eq__Ici__eq__empty,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [La: C] : bot_bot(set(C)) != set_ord_atLeast(C,La) ) ).

% not_empty_eq_Ici_eq_empty
tff(fact_4879_atLeast__eq__UNIV__iff,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [X: C] :
          ( ( set_ord_atLeast(C,X) = top_top(set(C)) )
        <=> ( X = bot_bot(C) ) ) ) ).

% atLeast_eq_UNIV_iff
tff(fact_4880_lessThan__Int__lessThan,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [A3: C,B2: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_greaterThan(C,A3)),set_ord_greaterThan(C,B2)) = set_ord_greaterThan(C,aa(C,C,aa(C,fun(C,C),ord_max(C),A3),B2)) ) ).

% lessThan_Int_lessThan
tff(fact_4881_ivl__disj__int__one_I8_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or7035219750837199246ssThan(C,La,U)),set_ord_atLeast(C,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(8)
tff(fact_4882_atLeastAtMost__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [La: C,U: C] : set_or1337092689740270186AtMost(C,La,U) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atLeast(C,La)),set_ord_atMost(C,U)) ) ).

% atLeastAtMost_def
tff(fact_4883_atLeastLessThan__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [La: C,U: C] : set_or7035219750837199246ssThan(C,La,U) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atLeast(C,La)),set_ord_lessThan(C,U)) ) ).

% atLeastLessThan_def
tff(fact_4884_ivl__disj__int__one_I6_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or5935395276787703475ssThan(C,La,U)),set_ord_atLeast(C,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(6)
tff(fact_4885_ivl__disj__int__one_I7_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or1337092689740270186AtMost(C,La,U)),set_ord_greaterThan(C,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(7)
tff(fact_4886_drop__Cons,axiom,
    ! [C: $tType,N: nat,X: C,Xs: list(C)] : aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),N),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = case_nat(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs),aTP_Lamp_py(list(C),fun(nat,list(C)),Xs),N) ).

% drop_Cons
tff(fact_4887_list__update_Osimps_I2_J,axiom,
    ! [C: $tType,X: C,Xs: list(C),I: nat,V: C] : aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),I),V) = case_nat(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Xs),aa(C,fun(nat,list(C)),aa(list(C),fun(C,fun(nat,list(C))),aTP_Lamp_pz(C,fun(list(C),fun(C,fun(nat,list(C)))),X),Xs),V),I) ).

% list_update.simps(2)
tff(fact_4888_ivl__disj__int__one_I5_J,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [La: C,U: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_or3652927894154168847AtMost(C,La,U)),set_ord_greaterThan(C,U)) = bot_bot(set(C)) ) ).

% ivl_disj_int_one(5)
tff(fact_4889_greaterThanAtMost__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [La: C,U: C] : set_or3652927894154168847AtMost(C,La,U) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_greaterThan(C,La)),set_ord_atMost(C,U)) ) ).

% greaterThanAtMost_def
tff(fact_4890_nth__Cons,axiom,
    ! [C: $tType,X: C,Xs: list(C),N: nat] : aa(nat,C,nth(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)),N) = case_nat(C,X,nth(C,Xs),N) ).

% nth_Cons
tff(fact_4891_greaterThanLessThan__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [La: C,U: C] : set_or5935395276787703475ssThan(C,La,U) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_greaterThan(C,La)),set_ord_lessThan(C,U)) ) ).

% greaterThanLessThan_def
tff(fact_4892_greaterThanLessThan__eq,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [A3: C,B2: C] : set_or5935395276787703475ssThan(C,A3,B2) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_greaterThan(C,A3)),set_ord_lessThan(C,B2)) ) ).

% greaterThanLessThan_eq
tff(fact_4893_atMost__Int__atLeast,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [N: C] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_ord_atMost(C,N)),set_ord_atLeast(C,N)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),N),bot_bot(set(C))) ) ).

% atMost_Int_atLeast
tff(fact_4894_subset__mset_OcINF__superset__mono,axiom,
    ! [D: $tType,C: $tType,A4: set(C),G: fun(C,multiset(D)),B3: set(C),F: fun(C,multiset(D))] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),B3))
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ( ! [X2: C] :
                ( member2(C,X2,B3)
               => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(C,multiset(D),G,X2)),aa(C,multiset(D),F,X2)) )
           => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),B3))),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))) ) ) ) ) ).

% subset_mset.cINF_superset_mono
tff(fact_4895_sorted__wrt__iff__nth__Suc__transp,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( transp(C,Pa)
     => ( sorted_wrt(C,Pa,Xs)
      <=> ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,I2)),aa(list(C),nat,size_size(list(C)),Xs))
           => aa(C,$o,aa(C,fun(C,$o),Pa,aa(nat,C,nth(C,Xs),I2)),aa(nat,C,nth(C,Xs),aa(nat,nat,suc,I2))) ) ) ) ).

% sorted_wrt_iff_nth_Suc_transp
tff(fact_4896_upto_Opelims,axiom,
    ! [X: int,Xa: int,Y: list(int)] :
      ( ( upto(X,Xa) = Y )
     => ( accp(product_prod(int,int),upto_rel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),X),Xa))
       => ~ ( ( Y = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X),Xa),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),X),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),X),one_one(int)),Xa)),nil(int)) )
           => ~ accp(product_prod(int,int),upto_rel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),X),Xa)) ) ) ) ).

% upto.pelims
tff(fact_4897_subset__mset_Obdd__below__Int1,axiom,
    ! [C: $tType,A4: set(multiset(C)),B3: set(multiset(C))] :
      ( condit8119078960628432327_below(multiset(C),subseteq_mset(C),A4)
     => condit8119078960628432327_below(multiset(C),subseteq_mset(C),aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3)) ) ).

% subset_mset.bdd_below_Int1
tff(fact_4898_subset__mset_Obdd__below__Int2,axiom,
    ! [C: $tType,B3: set(multiset(C)),A4: set(multiset(C))] :
      ( condit8119078960628432327_below(multiset(C),subseteq_mset(C),B3)
     => condit8119078960628432327_below(multiset(C),subseteq_mset(C),aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3)) ) ).

% subset_mset.bdd_below_Int2
tff(fact_4899_transp__inf,axiom,
    ! [C: $tType,R3: fun(C,fun(C,$o)),S4: fun(C,fun(C,$o))] :
      ( transp(C,R3)
     => ( transp(C,S4)
       => transp(C,aa(fun(C,fun(C,$o)),fun(C,fun(C,$o)),aa(fun(C,fun(C,$o)),fun(fun(C,fun(C,$o)),fun(C,fun(C,$o))),inf_inf(fun(C,fun(C,$o))),R3),S4)) ) ) ).

% transp_inf
tff(fact_4900_list_Orel__transp,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o))] :
      ( transp(C,R)
     => transp(list(C),aa(fun(C,fun(C,$o)),fun(list(C),fun(list(C),$o)),list_all2(C,C),R)) ) ).

% list.rel_transp
tff(fact_4901_sorted__wrt2,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),X: C,Y: C,Zs: list(C)] :
      ( transp(C,Pa)
     => ( sorted_wrt(C,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)))
      <=> ( aa(C,$o,aa(C,fun(C,$o),Pa,X),Y)
          & sorted_wrt(C,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Zs)) ) ) ) ).

% sorted_wrt2
tff(fact_4902_upto_Opinduct,axiom,
    ! [A0: int,A1: int,Pa: fun(int,fun(int,$o))] :
      ( accp(product_prod(int,int),upto_rel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A0),A1))
     => ( ! [I3: int,J3: int] :
            ( accp(product_prod(int,int),upto_rel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),I3),J3))
           => ( ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I3),J3)
               => aa(int,$o,aa(int,fun(int,$o),Pa,aa(int,int,aa(int,fun(int,int),plus_plus(int),I3),one_one(int))),J3) )
             => aa(int,$o,aa(int,fun(int,$o),Pa,I3),J3) ) )
       => aa(int,$o,aa(int,fun(int,$o),Pa,A0),A1) ) ) ).

% upto.pinduct
tff(fact_4903_subset__mset_OcINF__mono,axiom,
    ! [E2: $tType,D: $tType,C: $tType,B3: set(C),F: fun(E2,multiset(D)),A4: set(E2),G: fun(C,multiset(D))] :
      ( ( B3 != bot_bot(set(C)) )
     => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(E2),set(multiset(D)),image2(E2,multiset(D),F),A4))
       => ( ! [M4: C] :
              ( member2(C,M4,B3)
             => ? [X3: E2] :
                  ( member2(E2,X3,A4)
                  & aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(E2,multiset(D),F,X3)),aa(C,multiset(D),G,M4)) ) )
         => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(E2),set(multiset(D)),image2(E2,multiset(D),F),A4))),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),B3))) ) ) ) ).

% subset_mset.cINF_mono
tff(fact_4904_subset__mset_Ole__cINF__iff,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),U: multiset(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),U),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4)))
        <=> ! [X4: C] :
              ( member2(C,X4,A4)
             => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),U),aa(C,multiset(D),F,X4)) ) ) ) ) ).

% subset_mset.le_cINF_iff
tff(fact_4905_upto_Opsimps,axiom,
    ! [I: int,J: int] :
      ( accp(product_prod(int,int),upto_rel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),I),J))
     => ( upto(I,J) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I),J),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),I),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),I),one_one(int)),J)),nil(int)) ) ) ).

% upto.psimps
tff(fact_4906_subset__mset_Omono__cINF,axiom,
    ! [C: $tType,D: $tType,E2: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [F: fun(multiset(C),D),A4: fun(E2,multiset(C)),I5: set(E2)] :
          ( aa(fun(multiset(C),D),$o,mono(multiset(C),D,subseteq_mset(C)),F)
         => ( condit8119078960628432327_below(multiset(C),subseteq_mset(C),aa(set(E2),set(multiset(C)),image2(E2,multiset(C),A4),I5))
           => ( ( I5 != bot_bot(set(E2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(multiset(C),D,F,aa(set(multiset(C)),multiset(C),complete_Inf_Inf(multiset(C)),aa(set(E2),set(multiset(C)),image2(E2,multiset(C),A4),I5)))),aa(set(D),D,complete_Inf_Inf(D),aa(set(E2),set(D),image2(E2,D,aa(fun(E2,multiset(C)),fun(E2,D),aTP_Lamp_qa(fun(multiset(C),D),fun(fun(E2,multiset(C)),fun(E2,D)),F),A4)),I5))) ) ) ) ) ).

% subset_mset.mono_cINF
tff(fact_4907_subset__mset_OcINF__union,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),B3: set(C)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( ( B3 != bot_bot(set(C)) )
         => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),B3))
           => ( aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))) = inter_mset(D,aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4)),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),B3))) ) ) ) ) ) ).

% subset_mset.cINF_union
tff(fact_4908_subset__mset_OcINF__insert,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),A3: C] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4))) = inter_mset(D,aa(C,multiset(D),F,A3),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))) ) ) ) ).

% subset_mset.cINF_insert
tff(fact_4909_set__mset__inter,axiom,
    ! [C: $tType,A4: multiset(C),B3: multiset(C)] : set_mset(C,inter_mset(C,A4,B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),set_mset(C,A4)),set_mset(C,B3)) ).

% set_mset_inter
tff(fact_4910_order_Omono_Ocong,axiom,
    ! [D: $tType,C: $tType] :
      ( order(D)
     => ! [Less_eq: fun(C,fun(C,$o))] : mono(C,D,Less_eq) = mono(C,D,Less_eq) ) ).

% order.mono.cong
tff(fact_4911_subset__mset_Omono__inf,axiom,
    ! [D: $tType,C: $tType] :
      ( semilattice_inf(D)
     => ! [F: fun(multiset(C),D),A4: multiset(C),B3: multiset(C)] :
          ( aa(fun(multiset(C),D),$o,mono(multiset(C),D,subseteq_mset(C)),F)
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(multiset(C),D,F,inter_mset(C,A4,B3))),aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(multiset(C),D,F,A4)),aa(multiset(C),D,F,B3))) ) ) ).

% subset_mset.mono_inf
tff(fact_4912_subset__mset_Oless__eq__cInf__inter,axiom,
    ! [C: $tType,A4: set(multiset(C)),B3: set(multiset(C))] :
      ( condit8119078960628432327_below(multiset(C),subseteq_mset(C),A4)
     => ( condit8119078960628432327_below(multiset(C),subseteq_mset(C),B3)
       => ( ( aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3) != bot_bot(set(multiset(C))) )
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),inter_mset(C,aa(set(multiset(C)),multiset(C),complete_Inf_Inf(multiset(C)),A4),aa(set(multiset(C)),multiset(C),complete_Inf_Inf(multiset(C)),B3))),aa(set(multiset(C)),multiset(C),complete_Inf_Inf(multiset(C)),aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3))) ) ) ) ).

% subset_mset.less_eq_cInf_inter
tff(fact_4913_subset__mset_OcINF__inf__distrib,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),G: fun(C,multiset(D))] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( condit8119078960628432327_below(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),A4))
         => ( inter_mset(D,aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4)),aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),A4))) = aa(set(multiset(D)),multiset(D),complete_Inf_Inf(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),aa(fun(C,multiset(D)),fun(C,multiset(D)),aTP_Lamp_qb(fun(C,multiset(D)),fun(fun(C,multiset(D)),fun(C,multiset(D))),F),G)),A4)) ) ) ) ) ).

% subset_mset.cINF_inf_distrib
tff(fact_4914_subset__mset_Omono__cSUP,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [F: fun(multiset(C),D),A4: fun(E2,multiset(C)),I5: set(E2)] :
          ( aa(fun(multiset(C),D),$o,mono(multiset(C),D,subseteq_mset(C)),F)
         => ( condit8047198070973881523_above(multiset(C),subseteq_mset(C),aa(set(E2),set(multiset(C)),image2(E2,multiset(C),A4),I5))
           => ( ( I5 != bot_bot(set(E2)) )
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(set(D),D,complete_Sup_Sup(D),aa(set(E2),set(D),image2(E2,D,aa(fun(E2,multiset(C)),fun(E2,D),aTP_Lamp_qa(fun(multiset(C),D),fun(fun(E2,multiset(C)),fun(E2,D)),F),A4)),I5))),aa(multiset(C),D,F,aa(set(multiset(C)),multiset(C),complete_Sup_Sup(multiset(C)),aa(set(E2),set(multiset(C)),image2(E2,multiset(C),A4),I5)))) ) ) ) ) ).

% subset_mset.mono_cSUP
tff(fact_4915_subset__mset_OcSUP__subset__mono,axiom,
    ! [D: $tType,C: $tType,A4: set(C),G: fun(C,multiset(D)),B3: set(C),F: fun(C,multiset(D))] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),B3))
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(C,multiset(D),F,X2)),aa(C,multiset(D),G,X2)) )
           => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),B3))) ) ) ) ) ).

% subset_mset.cSUP_subset_mono
tff(fact_4916_Eps__Opt__def,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      eps_Opt(C,Pa) = $ite(
        ? [X9: C] : aa(C,$o,Pa,X9),
        aa(C,option(C),some(C),fChoice(C,Pa)),
        none(C) ) ).

% Eps_Opt_def
tff(fact_4917_some__insert__self,axiom,
    ! [C: $tType,S: set(C)] :
      ( ( S != bot_bot(set(C)) )
     => ( aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),fChoice(C,aTP_Lamp_a(set(C),fun(C,$o),S))),S) = S ) ) ).

% some_insert_self
tff(fact_4918_some__elem,axiom,
    ! [C: $tType,S: set(C)] :
      ( ( S != bot_bot(set(C)) )
     => member2(C,fChoice(C,aTP_Lamp_a(set(C),fun(C,$o),S)),S) ) ).

% some_elem
tff(fact_4919_some__in__eq,axiom,
    ! [C: $tType,A4: set(C)] :
      ( member2(C,fChoice(C,aTP_Lamp_a(set(C),fun(C,$o),A4)),A4)
    <=> ( A4 != bot_bot(set(C)) ) ) ).

% some_in_eq
tff(fact_4920_inv__on__def,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(C),X: D] : aa(D,C,inv_on(C,D,F,A4),X) = fChoice(C,aa(D,fun(C,$o),aa(set(C),fun(D,fun(C,$o)),aTP_Lamp_nh(fun(C,D),fun(set(C),fun(D,fun(C,$o))),F),A4),X)) ).

% inv_on_def
tff(fact_4921_subset__mset_Obdd__above__Int1,axiom,
    ! [C: $tType,A4: set(multiset(C)),B3: set(multiset(C))] :
      ( condit8047198070973881523_above(multiset(C),subseteq_mset(C),A4)
     => condit8047198070973881523_above(multiset(C),subseteq_mset(C),aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3)) ) ).

% subset_mset.bdd_above_Int1
tff(fact_4922_subset__mset_Obdd__above__Int2,axiom,
    ! [C: $tType,B3: set(multiset(C)),A4: set(multiset(C))] :
      ( condit8047198070973881523_above(multiset(C),subseteq_mset(C),B3)
     => condit8047198070973881523_above(multiset(C),subseteq_mset(C),aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3)) ) ).

% subset_mset.bdd_above_Int2
tff(fact_4923_some__theI,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,$o))] :
      ( ? [A11: C,X_13: D] : aa(D,$o,aa(C,fun(D,$o),Pa,A11),X_13)
     => ( ! [B13: D,B23: D] :
            ( ? [A5: C] : aa(D,$o,aa(C,fun(D,$o),Pa,A5),B13)
           => ( ? [A5: C] : aa(D,$o,aa(C,fun(D,$o),Pa,A5),B23)
             => ( B13 = B23 ) ) )
       => aa(D,$o,aa(C,fun(D,$o),Pa,fChoice(C,aTP_Lamp_qc(fun(C,fun(D,$o)),fun(C,$o),Pa))),the(D,aTP_Lamp_qd(fun(C,fun(D,$o)),fun(D,$o),Pa))) ) ) ).

% some_theI
tff(fact_4924_subset__mset_OcSUP__le__iff,axiom,
    ! [C: $tType,D: $tType,A4: set(C),F: fun(C,multiset(D)),U: multiset(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))),U)
        <=> ! [X4: C] :
              ( member2(C,X4,A4)
             => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(C,multiset(D),F,X4)),U) ) ) ) ) ).

% subset_mset.cSUP_le_iff
tff(fact_4925_subset__mset_OcSUP__mono,axiom,
    ! [C: $tType,D: $tType,E2: $tType,A4: set(C),G: fun(E2,multiset(D)),B3: set(E2),F: fun(C,multiset(D))] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(E2),set(multiset(D)),image2(E2,multiset(D),G),B3))
       => ( ! [N7: C] :
              ( member2(C,N7,A4)
             => ? [X3: E2] :
                  ( member2(E2,X3,B3)
                  & aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(C,multiset(D),F,N7)),aa(E2,multiset(D),G,X3)) ) )
         => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(E2),set(multiset(D)),image2(E2,multiset(D),G),B3))) ) ) ) ).

% subset_mset.cSUP_mono
tff(fact_4926_fun__of__rel__def,axiom,
    ! [C: $tType,D: $tType,R: set(product_prod(D,C)),X: D] : fun_of_rel(D,C,R,X) = fChoice(C,aa(D,fun(C,$o),aTP_Lamp_pc(set(product_prod(D,C)),fun(D,fun(C,$o)),R),X)) ).

% fun_of_rel_def
tff(fact_4927_subset__mset_OcSUP__union,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),B3: set(C)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( ( B3 != bot_bot(set(C)) )
         => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),B3))
           => ( aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3))) = union_mset(D,aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4)),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),B3))) ) ) ) ) ) ).

% subset_mset.cSUP_union
tff(fact_4928_subset__mset_OcSUP__insert,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),A3: C] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4))) = union_mset(D,aa(C,multiset(D),F,A3),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))) ) ) ) ).

% subset_mset.cSUP_insert
tff(fact_4929_subset__mset_OcSup__inter__less__eq,axiom,
    ! [C: $tType,A4: set(multiset(C)),B3: set(multiset(C))] :
      ( condit8047198070973881523_above(multiset(C),subseteq_mset(C),A4)
     => ( condit8047198070973881523_above(multiset(C),subseteq_mset(C),B3)
       => ( ( aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3) != bot_bot(set(multiset(C))) )
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(set(multiset(C)),multiset(C),complete_Sup_Sup(multiset(C)),aa(set(multiset(C)),set(multiset(C)),aa(set(multiset(C)),fun(set(multiset(C)),set(multiset(C))),inf_inf(set(multiset(C))),A4),B3))),union_mset(C,aa(set(multiset(C)),multiset(C),complete_Sup_Sup(multiset(C)),A4),aa(set(multiset(C)),multiset(C),complete_Sup_Sup(multiset(C)),B3))) ) ) ) ).

% subset_mset.cSup_inter_less_eq
tff(fact_4930_subset__mset_OSUP__sup__distrib,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,multiset(D)),G: fun(C,multiset(D))] :
      ( ( A4 != bot_bot(set(C)) )
     => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4))
       => ( condit8047198070973881523_above(multiset(D),subseteq_mset(D),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),A4))
         => ( union_mset(D,aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),F),A4)),aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),G),A4))) = aa(set(multiset(D)),multiset(D),complete_Sup_Sup(multiset(D)),aa(set(C),set(multiset(D)),image2(C,multiset(D),aa(fun(C,multiset(D)),fun(C,multiset(D)),aTP_Lamp_qe(fun(C,multiset(D)),fun(fun(C,multiset(D)),fun(C,multiset(D))),F),G)),A4)) ) ) ) ) ).

% subset_mset.SUP_sup_distrib
tff(fact_4931_sgn__neg,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C))
         => ( sgn_sgn(C,A3) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ) ).

% sgn_neg
tff(fact_4932_irrefl__tranclI,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),X: C] :
      ( ( aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),converse(C,C,R3)),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)) = bot_bot(set(product_prod(C,C))) )
     => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),X),transitive_trancl(C,R3)) ) ).

% irrefl_tranclI
tff(fact_4933_su__rel__fun__def,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D)] :
      ( su_rel_fun(C,D,F2,F)
    <=> ( ! [A9: C,B9: D,B14: D] :
            ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A9),B9),F2)
           => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A9),B14),F2)
             => ( B9 = B14 ) ) )
        & ! [A9: C,P2: $o] :
            ( ! [B9: D] :
                ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A9),B9),F2)
               => (P2) )
           => (P2) )
        & ! [A9: C] : aa(C,D,F,A9) = the(D,aa(C,fun(D,$o),aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),F2),A9)) ) ) ).

% su_rel_fun_def
tff(fact_4934_sgn__1,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ( sgn_sgn(C,one_one(C)) = one_one(C) ) ) ).

% sgn_1
tff(fact_4935_pair__set__inverse,axiom,
    ! [C: $tType,D: $tType,Pa: fun(D,fun(C,$o))] : converse(D,C,collect(product_prod(D,C),product_case_prod(D,C,$o,Pa))) = collect(product_prod(C,D),product_case_prod(C,D,$o,aTP_Lamp_qf(fun(D,fun(C,$o)),fun(C,fun(D,$o)),Pa))) ).

% pair_set_inverse
tff(fact_4936_divide__sgn,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] : divide_divide(C,A3,sgn_sgn(C,B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),sgn_sgn(C,B2)) ) ).

% divide_sgn
tff(fact_4937_sgn__pos,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( sgn_sgn(C,A3) = one_one(C) ) ) ) ).

% sgn_pos
tff(fact_4938_abs__sgn__eq__1,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( aa(C,C,abs_abs(C),sgn_sgn(C,A3)) = one_one(C) ) ) ) ).

% abs_sgn_eq_1
tff(fact_4939_sgn__mult__self__eq,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),sgn_sgn(C,A3)),sgn_sgn(C,A3)) = aa($o,C,zero_neq_one_of_bool(C),A3 != zero_zero(C)) ) ).

% sgn_mult_self_eq
tff(fact_4940_converse__Int,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(D,C)),S4: set(product_prod(D,C))] : converse(D,C,aa(set(product_prod(D,C)),set(product_prod(D,C)),aa(set(product_prod(D,C)),fun(set(product_prod(D,C)),set(product_prod(D,C))),inf_inf(set(product_prod(D,C))),R3),S4)) = aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),converse(D,C,R3)),converse(D,C,S4)) ).

% converse_Int
tff(fact_4941_listrel1__converse,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : listrel1(C,converse(C,C,R3)) = converse(list(C),list(C),listrel1(C,R3)) ).

% listrel1_converse
tff(fact_4942_sgn__mult,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ! [A3: C,B2: C] : sgn_sgn(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),sgn_sgn(C,A3)),sgn_sgn(C,B2)) ) ).

% sgn_mult
tff(fact_4943_in__listrel1__converse,axiom,
    ! [C: $tType,X: list(C),Y: list(C),R3: set(product_prod(C,C))] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),listrel1(C,converse(C,C,R3)))
    <=> member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),converse(list(C),list(C),listrel1(C,R3))) ) ).

% in_listrel1_converse
tff(fact_4944_sgn__minus__1,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ( sgn_sgn(C,aa(C,C,uminus_uminus(C),one_one(C))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% sgn_minus_1
tff(fact_4945_su__rel__fun_Orepr,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D),A4: C,B3: D] :
      ( su_rel_fun(C,D,F2,F)
     => ( ( aa(C,D,F,A4) = B3 )
      <=> member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A4),B3),F2) ) ) ).

% su_rel_fun.repr
tff(fact_4946_su__rel__fun_Orepr1,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D),A4: C] :
      ( su_rel_fun(C,D,F2,F)
     => member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A4),aa(C,D,F,A4)),F2) ) ).

% su_rel_fun.repr1
tff(fact_4947_su__rel__fun_Orepr2,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D),A4: C,B3: D] :
      ( su_rel_fun(C,D,F2,F)
     => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A4),B3),F2)
       => ( B3 = aa(C,D,F,A4) ) ) ) ).

% su_rel_fun.repr2
tff(fact_4948_su__rel__fun_Ounique,axiom,
    ! [C: $tType,D: $tType,F2: set(product_prod(C,D)),F: fun(C,D),A4: C,B3: D,B15: D] :
      ( su_rel_fun(C,D,F2,F)
     => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A4),B3),F2)
       => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A4),B15),F2)
         => ( B3 = B15 ) ) ) ) ).

% su_rel_fun.unique
tff(fact_4949_su__rel__fun_Osurjective,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D),A4: C] :
      ( su_rel_fun(C,D,F2,F)
     => ~ ! [B6: D] : ~ member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A4),B6),F2) ) ).

% su_rel_fun.surjective
tff(fact_4950_mult__sgn__abs,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] : aa(C,C,aa(C,fun(C,C),times_times(C),sgn_sgn(C,X)),aa(C,C,abs_abs(C),X)) = X ) ).

% mult_sgn_abs
tff(fact_4951_sgn__mult__abs,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),sgn_sgn(C,A3)),aa(C,C,abs_abs(C),A3)) = A3 ) ).

% sgn_mult_abs
tff(fact_4952_abs__mult__sgn,axiom,
    ! [C: $tType] :
      ( idom_abs_sgn(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,abs_abs(C),A3)),sgn_sgn(C,A3)) = A3 ) ).

% abs_mult_sgn
tff(fact_4953_linordered__idom__class_Oabs__sgn,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [K: C] : aa(C,C,abs_abs(C),K) = aa(C,C,aa(C,fun(C,C),times_times(C),K),sgn_sgn(C,K)) ) ).

% linordered_idom_class.abs_sgn
tff(fact_4954_sgn__1__pos,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          ( ( sgn_sgn(C,A3) = one_one(C) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3) ) ) ).

% sgn_1_pos
tff(fact_4955_abs__sgn__eq,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          aa(C,C,abs_abs(C),sgn_sgn(C,A3)) = $ite(A3 = zero_zero(C),zero_zero(C),one_one(C)) ) ).

% abs_sgn_eq
tff(fact_4956_sgn__if,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [X: C] :
          sgn_sgn(C,X) = $ite(
            X = zero_zero(C),
            zero_zero(C),
            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),X),one_one(C),aa(C,C,uminus_uminus(C),one_one(C))) ) ) ).

% sgn_if
tff(fact_4957_sgn__1__neg,axiom,
    ! [C: $tType] :
      ( linordered_idom(C)
     => ! [A3: C] :
          ( ( sgn_sgn(C,A3) = aa(C,C,uminus_uminus(C),one_one(C)) )
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),zero_zero(C)) ) ) ).

% sgn_1_neg
tff(fact_4958_su__rel__fun_Of__def,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D),A4: C] :
      ( su_rel_fun(C,D,F2,F)
     => ( aa(C,D,F,A4) = the(D,aa(C,fun(D,$o),aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),F2),A4)) ) ) ).

% su_rel_fun.f_def
tff(fact_4959_su__rel__fun_Ointro,axiom,
    ! [D: $tType,C: $tType,F2: set(product_prod(C,D)),F: fun(C,D)] :
      ( ! [A8: C,B6: D,B7: D] :
          ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A8),B6),F2)
         => ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A8),B7),F2)
           => ( B6 = B7 ) ) )
     => ( ! [A8: C,P: $o] :
            ( ! [B16: D] :
                ( member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A8),B16),F2)
               => (P) )
           => (P) )
       => ( ! [A8: C] : aa(C,D,F,A8) = the(D,aa(C,fun(D,$o),aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),F2),A8))
         => su_rel_fun(C,D,F2,F) ) ) ) ).

% su_rel_fun.intro
tff(fact_4960_Image__INT__eq,axiom,
    ! [D: $tType,C: $tType,E2: $tType,R3: set(product_prod(D,C)),A4: set(E2),B3: fun(E2,set(D))] :
      ( single_valued(C,D,converse(D,C,R3))
     => ( ( A4 != bot_bot(set(E2)) )
       => ( image(D,C,R3,aa(set(set(D)),set(D),complete_Inf_Inf(set(D)),aa(set(E2),set(set(D)),image2(E2,set(D),B3),A4))) = aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),aa(set(E2),set(set(C)),image2(E2,set(C),aa(fun(E2,set(D)),fun(E2,set(C)),aTP_Lamp_qg(set(product_prod(D,C)),fun(fun(E2,set(D)),fun(E2,set(C))),R3),B3)),A4)) ) ) ) ).

% Image_INT_eq
tff(fact_4961_length__upto,axiom,
    ! [I: int,J: int] : aa(list(int),nat,size_size(list(int)),upto(I,J)) = nat2(aa(int,int,aa(int,fun(int,int),plus_plus(int),minus_minus(int,J,I)),one_one(int))) ).

% length_upto
tff(fact_4962_prod__list__def,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ( groups5270119922927024881d_list(C) = groups_monoid_F(C,times_times(C),one_one(C)) ) ) ).

% prod_list_def
tff(fact_4963_single__valued__inter1,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D)),S: set(product_prod(C,D))] :
      ( single_valued(C,D,R)
     => single_valued(C,D,aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),R),S)) ) ).

% single_valued_inter1
tff(fact_4964_single__valued__inter2,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D)),S: set(product_prod(C,D))] :
      ( single_valued(C,D,R)
     => single_valued(C,D,aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),S),R)) ) ).

% single_valued_inter2
tff(fact_4965_bijective__alt,axiom,
    ! [D: $tType,C: $tType,R: set(product_prod(C,D))] :
      ( bijective(C,D,R)
    <=> ( single_valued(C,D,R)
        & single_valued(D,C,converse(C,D,R)) ) ) ).

% bijective_alt
tff(fact_4966_Image__Int__eq,axiom,
    ! [C: $tType,D: $tType,R: set(product_prod(D,C)),A4: set(D),B3: set(D)] :
      ( single_valued(C,D,converse(D,C,R))
     => ( image(D,C,R,aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),image(D,C,R,A4)),image(D,C,R,B3)) ) ) ).

% Image_Int_eq
tff(fact_4967_Gcd__fin_Oeq__fold,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          aa(set(C),C,semiring_gcd_Gcd_fin(C),A4) = $ite(aa(set(C),$o,finite_finite2(C),A4),finite_fold(C,C,gcd_gcd(C),zero_zero(C),A4),one_one(C)) ) ).

% Gcd_fin.eq_fold
tff(fact_4968_lexn_Osimps_I2_J,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),N: nat] : aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),aa(nat,nat,suc,N)) = aa(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C))),aa(set(product_prod(list(C),list(C))),fun(set(product_prod(list(C),list(C))),set(product_prod(list(C),list(C)))),inf_inf(set(product_prod(list(C),list(C)))),aa(set(product_prod(product_prod(C,list(C)),product_prod(C,list(C)))),set(product_prod(list(C),list(C))),image2(product_prod(product_prod(C,list(C)),product_prod(C,list(C))),product_prod(list(C),list(C)),product_map_prod(product_prod(C,list(C)),list(C),product_prod(C,list(C)),list(C),product_case_prod(C,list(C),list(C),cons(C)),product_case_prod(C,list(C),list(C),cons(C)))),lex_prod(C,list(C),R3,aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),N)))),collect(product_prod(list(C),list(C)),product_case_prod(list(C),list(C),$o,aTP_Lamp_qh(nat,fun(list(C),fun(list(C),$o)),N)))) ).

% lexn.simps(2)
tff(fact_4969_Linear__order__Well__order__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( order_679001287576687338der_on(C,field2(C,R3),R3)
     => ( order_well_order_on(C,field2(C,R3),R3)
      <=> ! [A9: set(C)] :
            ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A9),field2(C,R3))
           => ( ( A9 != bot_bot(set(C)) )
             => ? [X4: C] :
                  ( member2(C,X4,A9)
                  & ! [Xa2: C] :
                      ( member2(C,Xa2,A9)
                     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),Xa2),R3) ) ) ) ) ) ) ).

% Linear_order_Well_order_iff
tff(fact_4970_gcd_Obottom__right__bottom,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),one_one(C)) = one_one(C) ) ).

% gcd.bottom_right_bottom
tff(fact_4971_gcd_Obottom__left__bottom,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),gcd_gcd(C),one_one(C)),A3) = one_one(C) ) ).

% gcd.bottom_left_bottom
tff(fact_4972_is__unit__gcd__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2),one_one(C))
        <=> ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) = one_one(C) ) ) ) ).

% is_unit_gcd_iff
tff(fact_4973_Gcd__2,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A3: C,B2: C] : gcd_Gcd(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) ) ).

% Gcd_2
tff(fact_4974_gcd__add__mult,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [M2: C,K: C,N: C] : aa(C,C,aa(C,fun(C,C),gcd_gcd(C),M2),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),K),M2)),N)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),M2),N) ) ).

% gcd_add_mult
tff(fact_4975_gcd__dvd__prod,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,K: C] : dvd_dvd(C,aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2),aa(C,C,aa(C,fun(C,C),times_times(C),K),B2)) ) ).

% gcd_dvd_prod
tff(fact_4976_well__order__on__empty,axiom,
    ! [C: $tType] : order_well_order_on(C,bot_bot(set(C)),bot_bot(set(product_prod(C,C)))) ).

% well_order_on_empty
tff(fact_4977_gcd__mult__unit1,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)),C3) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),C3) ) ) ) ).

% gcd_mult_unit1
tff(fact_4978_gcd__mult__unit2,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),C3) ) ) ) ).

% gcd_mult_unit2
tff(fact_4979_gcd__div__unit1,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),divide_divide(C,B2,A3)),C3) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),C3) ) ) ) ).

% gcd_div_unit1
tff(fact_4980_gcd__div__unit2,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),divide_divide(C,C3,A3)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),C3) ) ) ) ).

% gcd_div_unit2
tff(fact_4981_Well__order__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => order_well_order_on(C,field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% Well_order_Restr
tff(fact_4982_Gcd__fin_Oremove,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,A4: set(C)] :
          ( member2(C,A3,A4)
         => ( aa(set(C),C,semiring_gcd_Gcd_fin(C),A4) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),aa(set(C),C,semiring_gcd_Gcd_fin(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ) ).

% Gcd_fin.remove
tff(fact_4983_Gcd__fin_Oinsert__remove,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,A4: set(C)] : aa(set(C),C,semiring_gcd_Gcd_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),aa(set(C),C,semiring_gcd_Gcd_fin(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ).

% Gcd_fin.insert_remove
tff(fact_4984_well__order__on__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),field2(C,R3))
       => order_well_order_on(C,A4,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ) ).

% well_order_on_Restr
tff(fact_4985_ofilter__Restr__Int,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => order_ofilter(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ) ) ).

% ofilter_Restr_Int
tff(fact_4986_ofilter__Restr__subset,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
         => order_ofilter(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3))),A4) ) ) ) ).

% ofilter_Restr_subset
tff(fact_4987_Field__Restr__ofilter,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( field2(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) = A4 ) ) ) ).

% Field_Restr_ofilter
tff(fact_4988_ofilter__subset__embedS,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( order_ofilter(C,R3,B3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
          <=> bNF_Wellorder_embedS(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3))),id(C)) ) ) ) ) ).

% ofilter_subset_embedS
tff(fact_4989_ofilter__subset__embed,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( order_ofilter(C,R3,B3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
          <=> bNF_Wellorder_embed(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3))),id(C)) ) ) ) ) ).

% ofilter_subset_embed
tff(fact_4990_ofilter__embed,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
      <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),field2(C,R3))
          & bNF_Wellorder_embed(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),R3,id(C)) ) ) ) ).

% ofilter_embed
tff(fact_4991_ofilter__subset__embedS__iso,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( order_ofilter(C,R3,B3)
         => ( ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
            <=> bNF_Wellorder_embedS(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3))),id(C)) )
            & ( ( A4 = B3 )
            <=> bNF_Wellorder_iso(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3))),id(C)) ) ) ) ) ) ).

% ofilter_subset_embedS_iso
tff(fact_4992_embed__implies__iso__Restr,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(C,C)),R6: set(product_prod(D,D)),F: fun(D,C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_well_order_on(D,field2(D,R6),R6)
       => ( bNF_Wellorder_embed(D,C,R6,R3,F)
         => bNF_Wellorder_iso(D,C,R6,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,aa(set(D),set(C),image2(D,C,F),field2(D,R6)),aa(fun(D,C),fun(C,set(C)),aTP_Lamp_qi(set(product_prod(D,D)),fun(fun(D,C),fun(C,set(C))),R6),F))),F) ) ) ) ).

% embed_implies_iso_Restr
tff(fact_4993_ofilter__subset__ordLess,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( order_ofilter(C,R3,B3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),B3)
          <=> member2(product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),product_Pair(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3)))),bNF_We4044943003108391690rdLess(C,C)) ) ) ) ) ).

% ofilter_subset_ordLess
tff(fact_4994_pure__assn__raw_Ocases,axiom,
    ! [C: $tType,D: $tType,X: product_prod($o,product_prod(C,set(D)))] :
      ~ ! [B4: $o,H2: C,As: set(D)] : X != aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(B4)),aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As)) ).

% pure_assn_raw.cases
tff(fact_4995_ofilter__ordLess,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),A4),field2(C,R3))
        <=> member2(product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),product_Pair(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),R3),bNF_We4044943003108391690rdLess(C,C)) ) ) ) ).

% ofilter_ordLess
tff(fact_4996_underS__Restr__ordLess,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( ( field2(C,R3) != bot_bot(set(C)) )
       => member2(product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),product_Pair(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,order_underS(C,R3,A3),aa(C,fun(C,set(C)),aTP_Lamp_qj(set(product_prod(C,C)),fun(C,fun(C,set(C))),R3),A3)))),R3),bNF_We4044943003108391690rdLess(C,C)) ) ) ).

% underS_Restr_ordLess
tff(fact_4997_ofilter__subset__ordLeq,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B3: set(C)] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( order_ofilter(C,R3,B3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B3)
          <=> member2(product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),product_Pair(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,B3,aTP_Lamp_mg(set(C),fun(C,set(C)),B3)))),bNF_Wellorder_ordLeq(C,C)) ) ) ) ) ).

% ofilter_subset_ordLeq
tff(fact_4998_ofilter__Restr__under,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),A3: C] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_ofilter(C,R3,A4)
       => ( member2(C,A3,A4)
         => ( order_under(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4))),A3) = order_under(C,R3,A3) ) ) ) ) ).

% ofilter_Restr_under
tff(fact_4999_underS__empty,axiom,
    ! [C: $tType,A3: C,R3: set(product_prod(C,C))] :
      ( ~ member2(C,A3,field2(C,R3))
     => ( order_underS(C,R3,A3) = bot_bot(set(C)) ) ) ).

% underS_empty
tff(fact_5000_Refl__under__underS,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C] :
      ( refl_on(C,field2(C,R3),R3)
     => ( member2(C,A3,field2(C,R3))
       => ( order_under(C,R3,A3) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),order_underS(C,R3,A3)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) ) ) ) ).

% Refl_under_underS
tff(fact_5001_ordLeq__iff__ordLess__Restr,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,C)),R6: set(product_prod(D,D))] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_well_order_on(D,field2(D,R6),R6)
       => ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),R3),R6),bNF_Wellorder_ordLeq(C,D))
        <=> ! [X4: C] :
              ( member2(C,X4,field2(C,R3))
             => member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,order_underS(C,R3,X4),aa(C,fun(C,set(C)),aTP_Lamp_qj(set(product_prod(C,C)),fun(C,fun(C,set(C))),R3),X4)))),R6),bNF_We4044943003108391690rdLess(C,D)) ) ) ) ) ).

% ordLeq_iff_ordLess_Restr
tff(fact_5002_underS__Field3,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C] :
      ( ( field2(C,R3) != bot_bot(set(C)) )
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),order_underS(C,R3,A3)),field2(C,R3)) ) ).

% underS_Field3
tff(fact_5003_ordLess__iff__ordIso__Restr,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(C,C)),R6: set(product_prod(D,D))] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( order_well_order_on(D,field2(D,R6),R6)
       => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),R6),R3),bNF_We4044943003108391690rdLess(D,C))
        <=> ? [X4: C] :
              ( member2(C,X4,field2(C,R3))
              & member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),R6),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,order_underS(C,R3,X4),aa(C,fun(C,set(C)),aTP_Lamp_qj(set(product_prod(C,C)),fun(C,fun(C,set(C))),R3),X4)))),bNF_Wellorder_ordIso(D,C)) ) ) ) ) ).

% ordLess_iff_ordIso_Restr
tff(fact_5004_min__ext__compat,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),S: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),relcomp(C,C,C,R,S)),R)
     => aa(set(product_prod(set(C),set(C))),$o,aa(set(product_prod(set(C),set(C))),fun(set(product_prod(set(C),set(C))),$o),ord_less_eq(set(product_prod(set(C),set(C)))),relcomp(set(C),set(C),set(C),min_ext(C,R),aa(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C))),aa(set(product_prod(set(C),set(C))),fun(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C)))),sup_sup(set(product_prod(set(C),set(C)))),min_ext(C,S)),aa(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C))),aa(product_prod(set(C),set(C)),fun(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C)))),insert2(product_prod(set(C),set(C))),aa(set(C),product_prod(set(C),set(C)),aa(set(C),fun(set(C),product_prod(set(C),set(C))),product_Pair(set(C),set(C)),bot_bot(set(C))),bot_bot(set(C)))),bot_bot(set(product_prod(set(C),set(C)))))))),min_ext(C,R)) ) ).

% min_ext_compat
tff(fact_5005_Gcd__fin__def,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ( semiring_gcd_Gcd_fin(C) = bounde2362111253966948842tice_F(C,gcd_gcd(C),zero_zero(C),one_one(C)) ) ) ).

% Gcd_fin_def
tff(fact_5006_max__ext__compat,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),S: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),relcomp(C,C,C,R,S)),R)
     => aa(set(product_prod(set(C),set(C))),$o,aa(set(product_prod(set(C),set(C))),fun(set(product_prod(set(C),set(C))),$o),ord_less_eq(set(product_prod(set(C),set(C)))),relcomp(set(C),set(C),set(C),max_ext(C,R),aa(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C))),aa(set(product_prod(set(C),set(C))),fun(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C)))),sup_sup(set(product_prod(set(C),set(C)))),max_ext(C,S)),aa(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C))),aa(product_prod(set(C),set(C)),fun(set(product_prod(set(C),set(C))),set(product_prod(set(C),set(C)))),insert2(product_prod(set(C),set(C))),aa(set(C),product_prod(set(C),set(C)),aa(set(C),fun(set(C),product_prod(set(C),set(C))),product_Pair(set(C),set(C)),bot_bot(set(C))),bot_bot(set(C)))),bot_bot(set(product_prod(set(C),set(C)))))))),max_ext(C,R)) ) ).

% max_ext_compat
tff(fact_5007_bounded__quasi__semilattice__set_Oremove,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Top: C,Bot: C,Normalize: fun(C,C),A3: C,A4: set(C)] :
      ( bounde6485984586167503788ce_set(C,F,Top,Bot,Normalize)
     => ( member2(C,A3,A4)
       => ( aa(set(C),C,bounde2362111253966948842tice_F(C,F,Top,Bot),A4) = aa(C,C,aa(C,fun(C,C),F,A3),aa(set(C),C,bounde2362111253966948842tice_F(C,F,Top,Bot),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ) ).

% bounded_quasi_semilattice_set.remove
tff(fact_5008_bounded__quasi__semilattice__set_Oinsert__remove,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Top: C,Bot: C,Normalize: fun(C,C),A3: C,A4: set(C)] :
      ( bounde6485984586167503788ce_set(C,F,Top,Bot,Normalize)
     => ( aa(set(C),C,bounde2362111253966948842tice_F(C,F,Top,Bot),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = aa(C,C,aa(C,fun(C,C),F,A3),aa(set(C),C,bounde2362111253966948842tice_F(C,F,Top,Bot),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ).

% bounded_quasi_semilattice_set.insert_remove
tff(fact_5009_bounded__quasi__semilattice__set_Oempty,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Top: C,Bot: C,Normalize: fun(C,C)] :
      ( bounde6485984586167503788ce_set(C,F,Top,Bot,Normalize)
     => ( aa(set(C),C,bounde2362111253966948842tice_F(C,F,Top,Bot),bot_bot(set(C))) = Top ) ) ).

% bounded_quasi_semilattice_set.empty
tff(fact_5010_max__ext_Ocases,axiom,
    ! [C: $tType,A1: set(C),A22: set(C),R: set(product_prod(C,C))] :
      ( member2(product_prod(set(C),set(C)),aa(set(C),product_prod(set(C),set(C)),aa(set(C),fun(set(C),product_prod(set(C),set(C))),product_Pair(set(C),set(C)),A1),A22),max_ext(C,R))
     => ~ ( aa(set(C),$o,finite_finite2(C),A1)
         => ( aa(set(C),$o,finite_finite2(C),A22)
           => ( ( A22 != bot_bot(set(C)) )
             => ~ ! [X3: C] :
                    ( member2(C,X3,A1)
                   => ? [Xa4: C] :
                        ( member2(C,Xa4,A22)
                        & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X3),Xa4),R) ) ) ) ) ) ) ).

% max_ext.cases
tff(fact_5011_max__ext_Osimps,axiom,
    ! [C: $tType,A1: set(C),A22: set(C),R: set(product_prod(C,C))] :
      ( member2(product_prod(set(C),set(C)),aa(set(C),product_prod(set(C),set(C)),aa(set(C),fun(set(C),product_prod(set(C),set(C))),product_Pair(set(C),set(C)),A1),A22),max_ext(C,R))
    <=> ( aa(set(C),$o,finite_finite2(C),A1)
        & aa(set(C),$o,finite_finite2(C),A22)
        & ( A22 != bot_bot(set(C)) )
        & ! [X4: C] :
            ( member2(C,X4,A1)
           => ? [Xa2: C] :
                ( member2(C,Xa2,A22)
                & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),Xa2),R) ) ) ) ) ).

% max_ext.simps
tff(fact_5012_max__ext_Omax__extI,axiom,
    ! [C: $tType,X5: set(C),Y5: set(C),R: set(product_prod(C,C))] :
      ( aa(set(C),$o,finite_finite2(C),X5)
     => ( aa(set(C),$o,finite_finite2(C),Y5)
       => ( ( Y5 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,X5)
               => ? [Xa3: C] :
                    ( member2(C,Xa3,Y5)
                    & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),Xa3),R) ) )
           => member2(product_prod(set(C),set(C)),aa(set(C),product_prod(set(C),set(C)),aa(set(C),fun(set(C),product_prod(set(C),set(C))),product_Pair(set(C),set(C)),X5),Y5),max_ext(C,R)) ) ) ) ) ).

% max_ext.max_extI
tff(fact_5013_min__ext__def,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : min_ext(C,R3) = collect(product_prod(set(C),set(C)),aTP_Lamp_qk(set(product_prod(C,C)),fun(product_prod(set(C),set(C)),$o),R3)) ).

% min_ext_def
tff(fact_5014_refl__on__reflcl__Image,axiom,
    ! [C: $tType,B3: set(C),A4: set(product_prod(C,C)),C4: set(C)] :
      ( refl_on(C,B3,A4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),B3)
       => ( image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),A4),id2(C)),C4) = image(C,C,A4,C4) ) ) ) ).

% refl_on_reflcl_Image
tff(fact_5015_bind__singleton__conv__image,axiom,
    ! [C: $tType,D: $tType,A4: set(D),F: fun(D,C)] : bind2(D,C,A4,aTP_Lamp_dr(fun(D,C),fun(D,set(C)),F)) = aa(set(D),set(C),image2(D,C,F),A4) ).

% bind_singleton_conv_image
tff(fact_5016_bex__empty,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ~ ? [X3: C] :
          ( member2(C,X3,bot_bot(set(C)))
          & aa(C,$o,Pa,X3) ) ).

% bex_empty
tff(fact_5017_empty__bind,axiom,
    ! [D: $tType,C: $tType,F: fun(D,set(C))] : bind2(D,C,bot_bot(set(D)),F) = bot_bot(set(C)) ).

% empty_bind
tff(fact_5018_bijective__Id,axiom,
    ! [C: $tType] : bijective(C,C,id2(C)) ).

% bijective_Id
tff(fact_5019_bex__UNIV,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( member2(C,X4,top_top(set(C)))
          & aa(C,$o,Pa,X4) )
    <=> ? [X_12: C] : aa(C,$o,Pa,X_12) ) ).

% bex_UNIV
tff(fact_5020_below__Id__inv,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),converse(C,C,R)),id2(C))
    <=> aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),id2(C)) ) ).

% below_Id_inv
tff(fact_5021_Set_Obind__bind,axiom,
    ! [E2: $tType,C: $tType,D: $tType,A4: set(E2),B3: fun(E2,set(D)),C4: fun(D,set(C))] : bind2(D,C,bind2(E2,D,A4,B3),C4) = bind2(E2,C,A4,aa(fun(D,set(C)),fun(E2,set(C)),aTP_Lamp_ql(fun(E2,set(D)),fun(fun(D,set(C)),fun(E2,set(C))),B3),C4)) ).

% Set.bind_bind
tff(fact_5022_image__def,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: set(D)] : aa(set(D),set(C),image2(D,C,F),A4) = collect(C,aa(set(D),fun(C,$o),aTP_Lamp_qm(fun(D,C),fun(set(D),fun(C,$o)),F),A4)) ).

% image_def
tff(fact_5023_Set_Obind__def,axiom,
    ! [C: $tType,D: $tType,A4: set(D),F: fun(D,set(C))] : bind2(D,C,A4,F) = collect(C,aa(fun(D,set(C)),fun(C,$o),aTP_Lamp_qn(set(D),fun(fun(D,set(C)),fun(C,$o)),A4),F)) ).

% Set.bind_def
tff(fact_5024_bind__const,axiom,
    ! [D: $tType,C: $tType,A4: set(D),B3: set(C)] :
      bind2(D,C,A4,aTP_Lamp_an(set(C),fun(D,set(C)),B3)) = $ite(A4 = bot_bot(set(D)),bot_bot(set(C)),B3) ).

% bind_const
tff(fact_5025_nonempty__bind__const,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( bind2(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)) = B3 ) ) ).

% nonempty_bind_const
tff(fact_5026_vimage__image__eq,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C)] : aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),F),aa(set(C),set(D),image2(C,D,F),A4)) = collect(C,aa(set(C),fun(C,$o),aTP_Lamp_qo(fun(C,D),fun(set(C),fun(C,$o)),F),A4)) ).

% vimage_image_eq
tff(fact_5027_single__valued__below__Id,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),id2(C))
     => single_valued(C,C,R) ) ).

% single_valued_below_Id
tff(fact_5028_nths__nths,axiom,
    ! [C: $tType,Xs: list(C),A4: set(nat),B3: set(nat)] : aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),A4)),B3) = aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Xs),collect(nat,aa(set(nat),fun(nat,$o),aTP_Lamp_qq(set(nat),fun(set(nat),fun(nat,$o)),A4),B3))) ).

% nths_nths
tff(fact_5029_rtrancl__Int__subset,axiom,
    ! [C: $tType,S4: set(product_prod(C,C)),R3: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),id2(C)),S4)
     => ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),relcomp(C,C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)),S4),R3)),S4)
       => aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),R3)),S4) ) ) ).

% rtrancl_Int_subset
tff(fact_5030_map__project__def,axiom,
    ! [C: $tType,D: $tType,F: fun(D,option(C)),A4: set(D)] : map_project(D,C,F,A4) = collect(C,aa(set(D),fun(C,$o),aTP_Lamp_qr(fun(D,option(C)),fun(set(D),fun(C,$o)),F),A4)) ).

% map_project_def
tff(fact_5031_Linear__order__wf__diff__Id,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( order_679001287576687338der_on(C,field2(C,R3),R3)
     => ( wf(C,minus_minus(set(product_prod(C,C)),R3,id2(C)))
      <=> ! [A9: set(C)] :
            ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A9),field2(C,R3))
           => ( ( A9 != bot_bot(set(C)) )
             => ? [X4: C] :
                  ( member2(C,X4,A9)
                  & ! [Xa2: C] :
                      ( member2(C,Xa2,A9)
                     => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),Xa2),R3) ) ) ) ) ) ) ).

% Linear_order_wf_diff_Id
tff(fact_5032_bsqr__def,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : bNF_Wellorder_bsqr(C,R3) = collect(product_prod(product_prod(C,C),product_prod(C,C)),product_case_prod(product_prod(C,C),product_prod(C,C),$o,product_case_prod(C,C,fun(product_prod(C,C),$o),aTP_Lamp_qt(set(product_prod(C,C)),fun(C,fun(C,fun(product_prod(C,C),$o))),R3)))) ).

% bsqr_def
tff(fact_5033_wf__listrel1__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( wf(list(C),listrel1(C,R3))
    <=> wf(C,R3) ) ).

% wf_listrel1_iff
tff(fact_5034_wf__lex,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( wf(C,R3)
     => wf(list(C),lex(C,R3)) ) ).

% wf_lex
tff(fact_5035_wf__lenlex,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( wf(C,R3)
     => wf(list(C),lenlex(C,R3)) ) ).

% wf_lenlex
tff(fact_5036_brk__rel__wf,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( wf(C,R)
     => wf(product_prod($o,C),brk_rel(C,C,R)) ) ).

% brk_rel_wf
tff(fact_5037_wf__lexn,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),N: nat] :
      ( wf(C,R3)
     => wf(list(C),aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),N)) ) ).

% wf_lexn
tff(fact_5038_wf__measures,axiom,
    ! [C: $tType,Fs: list(fun(C,nat))] : wf(C,measures(C,Fs)) ).

% wf_measures
tff(fact_5039_wf__Int1,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),R6: set(product_prod(C,C))] :
      ( wf(C,R3)
     => wf(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),R6)) ) ).

% wf_Int1
tff(fact_5040_wf__Int2,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),R6: set(product_prod(C,C))] :
      ( wf(C,R3)
     => wf(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R6),R3)) ) ).

% wf_Int2
tff(fact_5041_wfE__min_H,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),Q: set(C)] :
      ( wf(C,R)
     => ( ( Q != bot_bot(set(C)) )
       => ~ ! [Z4: C] :
              ( member2(C,Z4,Q)
             => ~ ! [Y4: C] :
                    ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y4),Z4),R)
                   => ~ member2(C,Y4,Q) ) ) ) ) ).

% wfE_min'
tff(fact_5042_finite__wf__eq__wf__converse,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( aa(set(product_prod(C,C)),$o,finite_finite2(product_prod(C,C)),R)
     => ( wf(C,converse(C,C,R))
      <=> wf(C,R) ) ) ).

% finite_wf_eq_wf_converse
tff(fact_5043_wfI__pf,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( ! [A8: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A8),image(C,C,R,A8))
         => ( A8 = bot_bot(set(C)) ) )
     => wf(C,R) ) ).

% wfI_pf
tff(fact_5044_wfE__pf,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] :
      ( wf(C,R)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),image(C,C,R,A4))
       => ( A4 = bot_bot(set(C)) ) ) ) ).

% wfE_pf
tff(fact_5045_wf__bounded__supset,axiom,
    ! [C: $tType,S: set(C)] :
      ( aa(set(C),$o,finite_finite2(C),S)
     => wf(set(C),collect(product_prod(set(C),set(C)),product_case_prod(set(C),set(C),$o,aTP_Lamp_qu(set(C),fun(set(C),fun(set(C),$o)),S)))) ) ).

% wf_bounded_supset
tff(fact_5046_wf__eq__minimal2,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( wf(C,R3)
    <=> ! [A9: set(C)] :
          ( ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A9),field2(C,R3))
            & ( A9 != bot_bot(set(C)) ) )
         => ? [X4: C] :
              ( member2(C,X4,A9)
              & ! [Xa2: C] :
                  ( member2(C,Xa2,A9)
                 => ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Xa2),X4),R3) ) ) ) ) ).

% wf_eq_minimal2
tff(fact_5047_trans__wf__iff,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( trans(C,R3)
     => ( wf(C,R3)
      <=> ! [A6: C] : wf(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,image(C,C,converse(C,C,R3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A6),bot_bot(set(C)))),aa(C,fun(C,set(C)),aTP_Lamp_qv(set(product_prod(C,C)),fun(C,fun(C,set(C))),R3),A6)))) ) ) ).

% trans_wf_iff
tff(fact_5048_wo__rel_Ocases__Total3,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C,Phi: fun(C,fun(C,$o))] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))),field2(C,R3))
       => ( ( ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),minus_minus(set(product_prod(C,C)),R3,id2(C)))
              | member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),A3),minus_minus(set(product_prod(C,C)),R3,id2(C))) )
           => aa(C,$o,aa(C,fun(C,$o),Phi,A3),B2) )
         => ( ( ( A3 = B2 )
             => aa(C,$o,aa(C,fun(C,$o),Phi,A3),B2) )
           => aa(C,$o,aa(C,fun(C,$o),Phi,A3),B2) ) ) ) ) ).

% wo_rel.cases_Total3
tff(fact_5049_max__ext__eq,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] : max_ext(C,R) = collect(product_prod(set(C),set(C)),product_case_prod(set(C),set(C),$o,aTP_Lamp_qw(set(product_prod(C,C)),fun(set(C),fun(set(C),$o)),R))) ).

% max_ext_eq
tff(fact_5050_lenlex__transI,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( trans(C,R3)
     => trans(list(C),lenlex(C,R3)) ) ).

% lenlex_transI
tff(fact_5051_ball__UNIV,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ! [X4: C] :
          ( member2(C,X4,top_top(set(C)))
         => aa(C,$o,Pa,X4) )
    <=> ! [X_12: C] : aa(C,$o,Pa,X_12) ) ).

% ball_UNIV
tff(fact_5052_lexn__transI,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),N: nat] :
      ( trans(C,R3)
     => trans(list(C),aa(nat,set(product_prod(list(C),list(C))),lexn(C,R3),N)) ) ).

% lexn_transI
tff(fact_5053_lexord__transI,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( trans(C,R3)
     => trans(list(C),lexord(C,R3)) ) ).

% lexord_transI
tff(fact_5054_lex__transI,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( trans(C,R3)
     => trans(list(C),lex(C,R3)) ) ).

% lex_transI
tff(fact_5055_listrel__trans,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( trans(C,R3)
     => trans(list(C),listrel(C,C,R3)) ) ).

% listrel_trans
tff(fact_5056_trans__Int,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),S4: set(product_prod(C,C))] :
      ( trans(C,R3)
     => ( trans(C,S4)
       => trans(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),S4)) ) ) ).

% trans_Int
tff(fact_5057_lexord__trans,axiom,
    ! [C: $tType,X: list(C),Y: list(C),R3: set(product_prod(C,C)),Z2: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lexord(C,R3))
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Y),Z2),lexord(C,R3))
       => ( trans(C,R3)
         => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Z2),lexord(C,R3)) ) ) ) ).

% lexord_trans
tff(fact_5058_lenlex__trans,axiom,
    ! [C: $tType,X: list(C),Y: list(C),R3: set(product_prod(C,C)),Z2: list(C)] :
      ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Y),lenlex(C,R3))
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Y),Z2),lenlex(C,R3))
       => ( trans(C,R3)
         => member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),X),Z2),lenlex(C,R3)) ) ) ) ).

% lenlex_trans
tff(fact_5059_trans__Restr,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C)] :
      ( trans(C,R3)
     => trans(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,A4,aTP_Lamp_mg(set(C),fun(C,set(C)),A4)))) ) ).

% trans_Restr
tff(fact_5060_wo__rel_Omax2__among,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( member2(C,A3,field2(C,R3))
       => ( member2(C,B2,field2(C,R3))
         => member2(C,bNF_We1388413361240627857o_max2(C,R3,A3,B2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) ) ) ) ).

% wo_rel.max2_among
tff(fact_5061_trans__rtrancl__eq__reflcl,axiom,
    ! [C: $tType,A4: set(product_prod(C,C))] :
      ( trans(C,A4)
     => ( aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),A4) = aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),A4),id2(C)) ) ) ).

% trans_rtrancl_eq_reflcl
tff(fact_5062_Least__def,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Pa: fun(C,$o)] : ord_Least(C,Pa) = the(C,aTP_Lamp_qx(fun(C,$o),fun(C,$o),Pa)) ) ).

% Least_def
tff(fact_5063_wo__rel_Ocases__Total,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C,Phi: fun(C,fun(C,$o))] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))),field2(C,R3))
       => ( ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2),R3)
           => aa(C,$o,aa(C,fun(C,$o),Phi,A3),B2) )
         => ( ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),A3),R3)
             => aa(C,$o,aa(C,fun(C,$o),Phi,A3),B2) )
           => aa(C,$o,aa(C,fun(C,$o),Phi,A3),B2) ) ) ) ) ).

% wo_rel.cases_Total
tff(fact_5064_wo__rel_Omax2__greater__among,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A3: C,B2: C] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( member2(C,A3,field2(C,R3))
       => ( member2(C,B2,field2(C,R3))
         => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),bNF_We1388413361240627857o_max2(C,R3,A3,B2)),R3)
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),bNF_We1388413361240627857o_max2(C,R3,A3,B2)),R3)
            & member2(C,bNF_We1388413361240627857o_max2(C,R3,A3,B2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) ) ) ) ) ).

% wo_rel.max2_greater_among
tff(fact_5065_Image__absorb__rtrancl,axiom,
    ! [C: $tType,A4: set(product_prod(C,C)),B3: set(C),C4: set(C)] :
      ( trans(C,A4)
     => ( refl_on(C,B3,A4)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),B3)
         => ( image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),A4),C4) = image(C,C,A4,C4) ) ) ) ) ).

% Image_absorb_rtrancl
tff(fact_5066_Greatest__def,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o)] : order_Greatest(C,Pa) = the(C,aTP_Lamp_qy(fun(C,$o),fun(C,$o),Pa)) ) ).

% Greatest_def
tff(fact_5067_wo__rel_OWell__order__isMinim__exists,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C)] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( B3 != bot_bot(set(C)) )
         => ? [X_1: C] : bNF_We4791949203932849705sMinim(C,R3,B3,X_1) ) ) ) ).

% wo_rel.Well_order_isMinim_exists
tff(fact_5068_ord_OLeast__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Pa: fun(C,$o)] : aa(fun(C,$o),C,least(C,Less_eq),Pa) = the(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_qz(fun(C,fun(C,$o)),fun(fun(C,$o),fun(C,$o)),Less_eq),Pa)) ).

% ord.Least_def
tff(fact_5069_ord_OLeast_Ocong,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o))] : least(C,Less_eq) = least(C,Less_eq) ).

% ord.Least.cong
tff(fact_5070_Greatest__equality,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o),X: C] :
          ( aa(C,$o,Pa,X)
         => ( ! [Y2: C] :
                ( aa(C,$o,Pa,Y2)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),X) )
           => ( order_Greatest(C,Pa) = X ) ) ) ) ).

% Greatest_equality
tff(fact_5071_GreatestI2__order,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Pa: fun(C,$o),X: C,Q: fun(C,$o)] :
          ( aa(C,$o,Pa,X)
         => ( ! [Y2: C] :
                ( aa(C,$o,Pa,Y2)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y2),X) )
           => ( ! [X2: C] :
                  ( aa(C,$o,Pa,X2)
                 => ( ! [Y4: C] :
                        ( aa(C,$o,Pa,Y4)
                       => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y4),X2) )
                   => aa(C,$o,Q,X2) ) )
             => aa(C,$o,Q,order_Greatest(C,Pa)) ) ) ) ) ).

% GreatestI2_order
tff(fact_5072_wo__rel_Ominim__isMinim,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C)] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( B3 != bot_bot(set(C)) )
         => bNF_We4791949203932849705sMinim(C,R3,B3,bNF_We6954850376910717587_minim(C,R3,B3)) ) ) ) ).

% wo_rel.minim_isMinim
tff(fact_5073_wo__rel_Ominim__inField,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C)] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( B3 != bot_bot(set(C)) )
         => member2(C,bNF_We6954850376910717587_minim(C,R3,B3),field2(C,R3)) ) ) ) ).

% wo_rel.minim_inField
tff(fact_5074_wo__rel_Ominim__in,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C)] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( B3 != bot_bot(set(C)) )
         => member2(C,bNF_We6954850376910717587_minim(C,R3,B3),B3) ) ) ) ).

% wo_rel.minim_in
tff(fact_5075_list__ex__length,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),Xs)
    <=> ? [N3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(C),nat,size_size(list(C)),Xs))
          & aa(C,$o,Pa,aa(nat,C,nth(C,Xs),N3)) ) ) ).

% list_ex_length
tff(fact_5076_and_Osemilattice__neutr__axioms,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => semilattice_neutr(C,bit_se5824344872417868541ns_and(C),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% and.semilattice_neutr_axioms
tff(fact_5077_successively__append__iff,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs)
        & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Ys)
        & ( ( Xs = nil(C) )
          | ( Ys = nil(C) )
          | aa(C,$o,aa(C,fun(C,$o),Pa,last(C,Xs)),aa(list(C),C,hd(C),Ys)) ) ) ) ).

% successively_append_iff
tff(fact_5078_list__ex__simps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> ( aa(C,$o,Pa,X)
        | aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),Xs) ) ) ).

% list_ex_simps(1)
tff(fact_5079_list__ex__simps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : ~ aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),nil(C)) ).

% list_ex_simps(2)
tff(fact_5080_list__ex__append,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),Xs)
        | aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),Ys) ) ) ).

% list_ex_append
tff(fact_5081_list__ex__rev,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),aa(list(C),list(C),rev(C),Xs))
    <=> aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),Xs) ) ).

% list_ex_rev
tff(fact_5082_successively__rev,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),rev(C),Xs))
    <=> aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Pa)),Xs) ) ).

% successively_rev
tff(fact_5083_successively__map,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(C,$o)),F: fun(D,C),Xs: list(D)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))
    <=> aa(list(D),$o,aa(fun(D,fun(D,$o)),fun(list(D),$o),successively(D),aa(fun(D,C),fun(D,fun(D,$o)),aTP_Lamp_bb(fun(C,fun(C,$o)),fun(fun(D,C),fun(D,fun(D,$o))),Pa),F)),Xs) ) ).

% successively_map
tff(fact_5084_successively__remdups__adjI,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs)
     => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),remdups_adj(C),Xs)) ) ).

% successively_remdups_adjI
tff(fact_5085_successively__cong,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,fun(C,$o)),Q: fun(C,fun(C,$o)),Ys: list(C)] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( aa(C,$o,aa(C,fun(C,$o),Pa,X2),Y2)
            <=> aa(C,$o,aa(C,fun(C,$o),Q,X2),Y2) ) ) )
     => ( ( Xs = Ys )
       => ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs)
        <=> aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Q),Ys) ) ) ) ).

% successively_cong
tff(fact_5086_successively__mono,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C),Q: fun(C,fun(C,$o))] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs)
     => ( ! [X2: C,Y2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
           => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
             => ( aa(C,$o,aa(C,fun(C,$o),Pa,X2),Y2)
               => aa(C,$o,aa(C,fun(C,$o),Q,X2),Y2) ) ) )
       => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Q),Xs) ) ) ).

% successively_mono
tff(fact_5087_successively__if__sorted__wrt,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( sorted_wrt(C,Pa,Xs)
     => aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs) ) ).

% successively_if_sorted_wrt
tff(fact_5088_successively_Oelims_I3_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( ~ aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),Xa)
     => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
            ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
           => ( aa(C,$o,aa(C,fun(C,$o),X,X2),Y2)
              & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) ) ) ).

% successively.elims(3)
tff(fact_5089_successively_Osimps_I3_J,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),X: C,Y: C,Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)))
    <=> ( aa(C,$o,aa(C,fun(C,$o),Pa,X),Y)
        & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Xs)) ) ) ).

% successively.simps(3)
tff(fact_5090_successively_Osimps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o))] : aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),nil(C)) ).

% successively.simps(1)
tff(fact_5091_list__ex__cong,axiom,
    ! [C: $tType,Xs: list(C),Ys: list(C),F: fun(C,$o),G: fun(C,$o)] :
      ( ( Xs = Ys )
     => ( ! [X2: C] :
            ( member2(C,X2,aa(list(C),set(C),set2(C),Ys))
           => ( aa(C,$o,F,X2)
            <=> aa(C,$o,G,X2) ) )
       => ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),F),Xs)
        <=> aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),G),Ys) ) ) ) ).

% list_ex_cong
tff(fact_5092_distinct__adj__def,axiom,
    ! [C: $tType] : distinct_adj(C) = aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),aTP_Lamp_fg(C,fun(C,$o))) ).

% distinct_adj_def
tff(fact_5093_successively_Oelims_I2_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),Xa)
     => ( ( Xa != nil(C) )
       => ( ! [X2: C] : Xa != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))
         => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
               => ~ ( aa(C,$o,aa(C,fun(C,$o),X,X2),Y2)
                    & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) ) ) ) ) ).

% successively.elims(2)
tff(fact_5094_successively_Oelims_I1_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Y: $o] :
      ( ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),Xa)
      <=> (Y) )
     => ( ( ( Xa = nil(C) )
         => ~ (Y) )
       => ( ( ? [X2: C] : Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C))
           => ~ (Y) )
         => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
               => ( (Y)
                <=> ~ ( aa(C,$o,aa(C,fun(C,$o),X,X2),Y2)
                      & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) ) ) ) ) ) ).

% successively.elims(1)
tff(fact_5095_successively_Osimps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),X: C] : aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),nil(C))) ).

% successively.simps(2)
tff(fact_5096_semilattice__neutr__order_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semila1105856199041335345_order(C,F,Z2,Less_eq,Less)
     => semilattice_neutr(C,F,Z2) ) ).

% semilattice_neutr_order.axioms(1)
tff(fact_5097_successively__iff__sorted__wrt__strong,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,fun(C,$o))] :
      ( ! [X2: C,Y2: C,Z4: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => ( member2(C,Y2,aa(list(C),set(C),set2(C),Xs))
           => ( member2(C,Z4,aa(list(C),set(C),set2(C),Xs))
             => ( aa(C,$o,aa(C,fun(C,$o),Pa,X2),Y2)
               => ( aa(C,$o,aa(C,fun(C,$o),Pa,Y2),Z4)
                 => aa(C,$o,aa(C,fun(C,$o),Pa,X2),Z4) ) ) ) ) )
     => ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs)
      <=> sorted_wrt(C,Pa,Xs) ) ) ).

% successively_iff_sorted_wrt_strong
tff(fact_5098_successively__remdups__adj__iff,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,fun(C,$o))] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,aa(C,fun(C,$o),Pa,X2),X2) )
     => ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),remdups_adj(C),Xs))
      <=> aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs) ) ) ).

% successively_remdups_adj_iff
tff(fact_5099_successively__conv__sorted__wrt,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),Xs: list(C)] :
      ( transp(C,Pa)
     => ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs)
      <=> sorted_wrt(C,Pa,Xs) ) ) ).

% successively_conv_sorted_wrt
tff(fact_5100_successively__altdef,axiom,
    ! [C: $tType,X3: fun(C,fun(C,$o))] : aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X3) = aa(fun(C,fun(list(C),fun($o,$o))),fun(list(C),$o),aa($o,fun(fun(C,fun(list(C),fun($o,$o))),fun(list(C),$o)),rec_list($o,C),$true),aTP_Lamp_rb(fun(C,fun(C,$o)),fun(C,fun(list(C),fun($o,$o))),X3)) ).

% successively_altdef
tff(fact_5101_sup__bot_Osemilattice__neutr__axioms,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => semilattice_neutr(C,sup_sup(C),bot_bot(C)) ) ).

% sup_bot.semilattice_neutr_axioms
tff(fact_5102_inf__top_Osemilattice__neutr__axioms,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => semilattice_neutr(C,inf_inf(C),top_top(C)) ) ).

% inf_top.semilattice_neutr_axioms
tff(fact_5103_Bex__set__list__ex,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
          & aa(C,$o,Pa,X4) )
    <=> aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_ex(C),Pa),Xs) ) ).

% Bex_set_list_ex
tff(fact_5104_successively__Cons,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),X: C,Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> ( ( Xs = nil(C) )
        | ( aa(C,$o,aa(C,fun(C,$o),Pa,X),aa(list(C),C,hd(C),Xs))
          & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),Pa),Xs) ) ) ) ).

% successively_Cons
tff(fact_5105_successively_Opelims_I1_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C),Y: $o] :
      ( ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),Xa)
      <=> (Y) )
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ( ( ( Xa = nil(C) )
           => ( (Y)
             => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),nil(C))) ) )
         => ( ! [X2: C] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
               => ( (Y)
                 => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))) ) )
           => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
                 => ( ( (Y)
                    <=> ( aa(C,$o,aa(C,fun(C,$o),X,X2),Y2)
                        & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) )
                   => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)))) ) ) ) ) ) ) ).

% successively.pelims(1)
tff(fact_5106_successively_Opelims_I2_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),Xa)
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ( ( ( Xa = nil(C) )
           => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),nil(C))) )
         => ( ! [X2: C] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
               => ~ accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))) )
           => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
                 => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2))))
                   => ~ ( aa(C,$o,aa(C,fun(C,$o),X,X2),Y2)
                        & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) ) ) ) ) ) ) ).

% successively.pelims(2)
tff(fact_5107_successively_Opelims_I3_J,axiom,
    ! [C: $tType,X: fun(C,fun(C,$o)),Xa: list(C)] :
      ( ~ aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),Xa)
     => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),Xa))
       => ~ ! [X2: C,Y2: C,Xs2: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) )
             => ( accp(product_prod(fun(C,fun(C,$o)),list(C)),successively_rel(C),aa(list(C),product_prod(fun(C,fun(C,$o)),list(C)),aa(fun(C,fun(C,$o)),fun(list(C),product_prod(fun(C,fun(C,$o)),list(C))),product_Pair(fun(C,fun(C,$o)),list(C)),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2))))
               => ( aa(C,$o,aa(C,fun(C,$o),X,X2),Y2)
                  & aa(list(C),$o,aa(fun(C,fun(C,$o)),fun(list(C),$o),successively(C),X),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y2),Xs2)) ) ) ) ) ) ).

% successively.pelims(3)
tff(fact_5108_bij__betw__nth,axiom,
    ! [C: $tType,Xs: list(C),A4: set(nat),B3: set(C)] :
      ( aa(list(C),$o,distinct(C),Xs)
     => ( ( A4 = set_ord_lessThan(nat,aa(list(C),nat,size_size(list(C)),Xs)) )
       => ( ( B3 = aa(list(C),set(C),set2(C),Xs) )
         => bij_betw(nat,C,nth(C,Xs),A4,B3) ) ) ) ).

% bij_betw_nth
tff(fact_5109_prod__mset_Ounion__disjoint,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: multiset(C),B3: multiset(C),G: fun(C,D)] :
          ( ( inter_mset(C,A4,B3) = zero_zero(multiset(C)) )
         => ( aa(multiset(D),D,comm_m9189036328036947845d_mset(D),image_mset(C,D,G,union_mset(C,A4,B3))) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(multiset(D),D,comm_m9189036328036947845d_mset(D),image_mset(C,D,G,A4))),aa(multiset(D),D,comm_m9189036328036947845d_mset(D),image_mset(C,D,G,B3))) ) ) ) ).

% prod_mset.union_disjoint
tff(fact_5110_power__int__add__1_H,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: int] :
          ( ( ( X != zero_zero(C) )
            | ( M2 != aa(int,int,uminus_uminus(int),one_one(int)) ) )
         => ( power_int(C,X,aa(int,int,aa(int,fun(int,int),plus_plus(int),M2),one_one(int))) = aa(C,C,aa(C,fun(C,C),times_times(C),X),power_int(C,X,M2)) ) ) ) ).

% power_int_add_1'
tff(fact_5111_power__int__1__left,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [N: int] : power_int(C,one_one(C),N) = one_one(C) ) ).

% power_int_1_left
tff(fact_5112_power__int__mult__distrib__numeral2,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C,W: num,M2: int] : power_int(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),aa(num,C,numeral_numeral(C),W)),M2) = aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,M2)),power_int(C,aa(num,C,numeral_numeral(C),W),M2)) ) ).

% power_int_mult_distrib_numeral2
tff(fact_5113_power__int__mult__distrib__numeral1,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [W: num,Y: C,M2: int] : power_int(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),W)),Y),M2) = aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,aa(num,C,numeral_numeral(C),W),M2)),power_int(C,Y,M2)) ) ).

% power_int_mult_distrib_numeral1
tff(fact_5114_power__int__0__right,axiom,
    ! [C: $tType] :
      ( ( inverse(C)
        & power(C) )
     => ! [X: C] : power_int(C,X,zero_zero(int)) = one_one(C) ) ).

% power_int_0_right
tff(fact_5115_mset__map,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),Xs: list(D)] : mset(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)) = image_mset(D,C,F,mset(D,Xs)) ).

% mset_map
tff(fact_5116_prod__mset_Oneutral__const,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: multiset(D)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,aTP_Lamp_ae(D,C),A4)) = one_one(C) ) ).

% prod_mset.neutral_const
tff(fact_5117_power__int__minus__one__mult__self,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [M2: int] : aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),M2)),power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),M2)) = one_one(C) ) ).

% power_int_minus_one_mult_self
tff(fact_5118_power__int__minus__one__mult__self_H,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [M2: int,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),M2)),aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),M2)),B2)) = B2 ) ).

% power_int_minus_one_mult_self'
tff(fact_5119_power__int__add__numeral2,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: num,N: num,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,aa(num,int,numeral_numeral(int),M2))),aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,aa(num,int,numeral_numeral(int),N))),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,aa(num,int,numeral_numeral(int),aa(num,num,aa(num,fun(num,num),plus_plus(num),M2),N)))),B2) ) ).

% power_int_add_numeral2
tff(fact_5120_power__int__add__numeral,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: num,N: num] : aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,aa(num,int,numeral_numeral(int),M2))),power_int(C,X,aa(num,int,numeral_numeral(int),N))) = power_int(C,X,aa(num,int,numeral_numeral(int),aa(num,num,aa(num,fun(num,num),plus_plus(num),M2),N))) ) ).

% power_int_add_numeral
tff(fact_5121_prod__mset_Oinsert,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),X: D,A4: multiset(D)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,G,add_mset(D,X,A4))) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(D,C,G,X)),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,G,A4))) ) ).

% prod_mset.insert
tff(fact_5122_mset__map__split__orig,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Pa: multiset(D),M12: multiset(C),M23: multiset(C)] :
      ( ( image_mset(D,C,F,Pa) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),M12),M23) )
     => ~ ! [P12: multiset(D),P23: multiset(D)] :
            ( ( Pa = aa(multiset(D),multiset(D),aa(multiset(D),fun(multiset(D),multiset(D)),plus_plus(multiset(D)),P12),P23) )
           => ( ( image_mset(D,C,F,P12) = M12 )
             => ( image_mset(D,C,F,P23) != M23 ) ) ) ) ).

% mset_map_split_orig
tff(fact_5123_power__int__mult__distrib,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C,Y: C,M2: int] : power_int(C,aa(C,C,aa(C,fun(C,C),times_times(C),X),Y),M2) = aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,M2)),power_int(C,Y,M2)) ) ).

% power_int_mult_distrib
tff(fact_5124_power__int__commutes,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,N: int] : aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,N)),X) = aa(C,C,aa(C,fun(C,C),times_times(C),X),power_int(C,X,N)) ) ).

% power_int_commutes
tff(fact_5125_mset__map__id,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),G: fun(C,D),X5: multiset(C)] :
      ( ! [X2: C] : aa(D,C,F,aa(C,D,G,X2)) = X2
     => ( image_mset(D,C,F,image_mset(C,D,G,X5)) = X5 ) ) ).

% mset_map_id
tff(fact_5126_bij__betw__empty1,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(D)] :
      ( bij_betw(C,D,F,bot_bot(set(C)),A4)
     => ( A4 = bot_bot(set(D)) ) ) ).

% bij_betw_empty1
tff(fact_5127_bij__betw__empty2,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),A4: set(C)] :
      ( bij_betw(C,D,F,A4,bot_bot(set(D)))
     => ( A4 = bot_bot(set(C)) ) ) ).

% bij_betw_empty2
tff(fact_5128_mset__map__split__orig__le,axiom,
    ! [D: $tType,C: $tType,F: fun(D,C),Pa: multiset(D),M12: multiset(C),M23: multiset(C)] :
      ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),image_mset(D,C,F,Pa)),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),M12),M23))
     => ~ ! [P12: multiset(D),P23: multiset(D)] :
            ( ( Pa = aa(multiset(D),multiset(D),aa(multiset(D),fun(multiset(D),multiset(D)),plus_plus(multiset(D)),P12),P23) )
           => ( aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),image_mset(D,C,F,P12)),M12)
             => ~ aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),image_mset(D,C,F,P23)),M23) ) ) ) ).

% mset_map_split_orig_le
tff(fact_5129_power__int__one__over,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,N: int] : power_int(C,divide_divide(C,one_one(C),X),N) = divide_divide(C,one_one(C),power_int(C,X,N)) ) ).

% power_int_one_over
tff(fact_5130_prod__mset_Odistrib,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [G: fun(D,C),H: fun(D,C),A4: multiset(D)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_cf(fun(D,C),fun(fun(D,C),fun(D,C)),G),H),A4)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,G,A4))),aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,H,A4))) ) ).

% prod_mset.distrib
tff(fact_5131_notIn__Un__bij__betw3,axiom,
    ! [C: $tType,D: $tType,B2: C,A4: set(C),F: fun(C,D),A12: set(D)] :
      ( ~ member2(C,B2,A4)
     => ( ~ member2(D,aa(C,D,F,B2),A12)
       => ( bij_betw(C,D,F,A4,A12)
        <=> bij_betw(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A12),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),aa(C,D,F,B2)),bot_bot(set(D))))) ) ) ) ).

% notIn_Un_bij_betw3
tff(fact_5132_notIn__Un__bij__betw,axiom,
    ! [C: $tType,D: $tType,B2: C,A4: set(C),F: fun(C,D),A12: set(D)] :
      ( ~ member2(C,B2,A4)
     => ( ~ member2(D,aa(C,D,F,B2),A12)
       => ( bij_betw(C,D,F,A4,A12)
         => bij_betw(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C)))),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A12),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),aa(C,D,F,B2)),bot_bot(set(D))))) ) ) ) ).

% notIn_Un_bij_betw
tff(fact_5133_bij__betw__combine,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(C),B3: set(D),C4: set(C),D2: set(D)] :
      ( bij_betw(C,D,F,A4,B3)
     => ( bij_betw(C,D,F,C4,D2)
       => ( ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),B3),D2) = bot_bot(set(D)) )
         => bij_betw(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),C4),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),B3),D2)) ) ) ) ).

% bij_betw_combine
tff(fact_5134_bij__betw__partition,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(C),C4: set(C),B3: set(D),D2: set(D)] :
      ( bij_betw(C,D,F,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),C4),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),B3),D2))
     => ( bij_betw(C,D,F,C4,D2)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),C4) = bot_bot(set(C)) )
         => ( ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),B3),D2) = bot_bot(set(D)) )
           => bij_betw(C,D,F,A4,B3) ) ) ) ) ).

% bij_betw_partition
tff(fact_5135_power__int__0__left__If,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [M2: int] :
          power_int(C,zero_zero(C),M2) = $ite(M2 = zero_zero(int),one_one(C),zero_zero(C)) ) ).

% power_int_0_left_If
tff(fact_5136_power__int__increasing,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [N: int,N4: int,A3: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),power_int(C,A3,N)),power_int(C,A3,N4)) ) ) ) ).

% power_int_increasing
tff(fact_5137_power__int__strict__increasing,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [N: int,N4: int,A3: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),power_int(C,A3,N)),power_int(C,A3,N4)) ) ) ) ).

% power_int_strict_increasing
tff(fact_5138_power__int__minus__one__minus,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [N: int] : power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),aa(int,int,uminus_uminus(int),N)) = power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),N) ) ).

% power_int_minus_one_minus
tff(fact_5139_power__int__minus__one__diff__commute,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: int,B2: int] : power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),minus_minus(int,A3,B2)) = power_int(C,aa(C,C,uminus_uminus(C),one_one(C)),minus_minus(int,B2,A3)) ) ).

% power_int_minus_one_diff_commute
tff(fact_5140_bij__betw__disjoint__Un,axiom,
    ! [C: $tType,D: $tType,F: fun(C,D),A4: set(C),C4: set(D),G: fun(C,D),B3: set(C),D2: set(D)] :
      ( bij_betw(C,D,F,A4,C4)
     => ( bij_betw(C,D,G,B3,D2)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3) = bot_bot(set(C)) )
         => ( ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),C4),D2) = bot_bot(set(D)) )
           => bij_betw(C,D,aa(fun(C,D),fun(C,D),aa(set(C),fun(fun(C,D),fun(C,D)),aTP_Lamp_ds(fun(C,D),fun(set(C),fun(fun(C,D),fun(C,D))),F),A4),G),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B3),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),C4),D2)) ) ) ) ) ).

% bij_betw_disjoint_Un
tff(fact_5141_infinite__imp__bij__betw2,axiom,
    ! [C: $tType,A4: set(C),A3: C] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ? [H2: fun(C,C)] : bij_betw(C,C,H2,A4,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) ) ).

% infinite_imp_bij_betw2
tff(fact_5142_infinite__imp__bij__betw,axiom,
    ! [C: $tType,A4: set(C),A3: C] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ? [H2: fun(C,C)] : bij_betw(C,C,H2,A4,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C))))) ) ).

% infinite_imp_bij_betw
tff(fact_5143_power__int__strict__decreasing,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [N: int,N4: int,A3: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),power_int(C,A3,N4)),power_int(C,A3,N)) ) ) ) ) ).

% power_int_strict_decreasing
tff(fact_5144_one__le__power__int,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C,N: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),X)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),N)
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),power_int(C,X,N)) ) ) ) ).

% one_le_power_int
tff(fact_5145_one__less__power__int,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,N: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),A3)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),N)
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),power_int(C,A3,N)) ) ) ) ).

% one_less_power_int
tff(fact_5146_power__int__add,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: int,N: int] :
          ( ( ( X != zero_zero(C) )
            | ( aa(int,int,aa(int,fun(int,int),plus_plus(int),M2),N) != zero_zero(int) ) )
         => ( power_int(C,X,aa(int,int,aa(int,fun(int,int),plus_plus(int),M2),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,M2)),power_int(C,X,N)) ) ) ) ).

% power_int_add
tff(fact_5147_prod_Oreindex__bij__betw__not__neutral,axiom,
    ! [C: $tType,E2: $tType,D: $tType] :
      ( comm_monoid_mult(E2)
     => ! [S3: set(C),T5: set(D),H: fun(C,D),S: set(C),T: set(D),G: fun(D,E2)] :
          ( aa(set(C),$o,finite_finite2(C),S3)
         => ( aa(set(D),$o,finite_finite2(D),T5)
           => ( bij_betw(C,D,H,minus_minus(set(C),S,S3),minus_minus(set(D),T,T5))
             => ( ! [A5: C] :
                    ( member2(C,A5,S3)
                   => ( aa(D,E2,G,aa(C,D,H,A5)) = one_one(E2) ) )
               => ( ! [B4: D] :
                      ( member2(D,B4,T5)
                     => ( aa(D,E2,G,B4) = one_one(E2) ) )
                 => ( aa(set(C),E2,aa(fun(C,E2),fun(set(C),E2),groups7121269368397514597t_prod(C,E2),aa(fun(D,E2),fun(C,E2),aTP_Lamp_rc(fun(C,D),fun(fun(D,E2),fun(C,E2)),H),G)),S) = aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7121269368397514597t_prod(D,E2),G),T) ) ) ) ) ) ) ) ).

% prod.reindex_bij_betw_not_neutral
tff(fact_5148_power__int__minus__left__distrib,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( ( division_ring(E2)
        & one(C)
        & uminus(C) )
     => ! [X: D,A3: E2,N: int] :
          ( nO_MATCH(C,D,aa(C,C,uminus_uminus(C),one_one(C)),X)
         => ( power_int(E2,aa(E2,E2,uminus_uminus(E2),A3),N) = aa(E2,E2,aa(E2,fun(E2,E2),times_times(E2),power_int(E2,aa(E2,E2,uminus_uminus(E2),one_one(E2)),N)),power_int(E2,A3,N)) ) ) ) ).

% power_int_minus_left_distrib
tff(fact_5149_power__int__le__one,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C,N: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),X)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),N)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),one_one(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),power_int(C,X,N)),one_one(C)) ) ) ) ) ).

% power_int_le_one
tff(fact_5150_power__int__decreasing,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [N: int,N4: int,A3: C] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),N),N4)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),A3)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C))
             => ( ( ( A3 != zero_zero(C) )
                  | ( N4 != zero_zero(int) )
                  | ( N = zero_zero(int) ) )
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),power_int(C,A3,N4)),power_int(C,A3,N)) ) ) ) ) ) ).

% power_int_decreasing
tff(fact_5151_power__int__le__imp__le__exp,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C,M2: int,N: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),power_int(C,X,M2)),power_int(C,X,N))
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),N)
             => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),M2),N) ) ) ) ) ).

% power_int_le_imp_le_exp
tff(fact_5152_power__int__le__imp__less__exp,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C,M2: int,N: int] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),X)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),power_int(C,X,M2)),power_int(C,X,N))
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),N)
             => aa(int,$o,aa(int,fun(int,$o),ord_less(int),M2),N) ) ) ) ) ).

% power_int_le_imp_less_exp
tff(fact_5153_power__int__minus__mult,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C,N: int] :
          ( ( ( X != zero_zero(C) )
            | ( N != zero_zero(int) ) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,minus_minus(int,N,one_one(int)))),X) = power_int(C,X,N) ) ) ) ).

% power_int_minus_mult
tff(fact_5154_power__int__add__1,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: int] :
          ( ( ( X != zero_zero(C) )
            | ( M2 != aa(int,int,uminus_uminus(int),one_one(int)) ) )
         => ( power_int(C,X,aa(int,int,aa(int,fun(int,int),plus_plus(int),M2),one_one(int))) = aa(C,C,aa(C,fun(C,C),times_times(C),power_int(C,X,M2)),X) ) ) ) ).

% power_int_add_1
tff(fact_5155_count__image__mset,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),A4: multiset(D),X: C] : aa(C,nat,count(C,image_mset(D,C,F,A4)),X) = aa(set(D),nat,aa(fun(D,nat),fun(set(D),nat),groups7311177749621191930dd_sum(D,nat),count(D,A4)),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(set(C),set(D),aa(fun(D,C),fun(set(C),set(D)),vimage(D,C),F),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))),set_mset(D,A4))) ).

% count_image_mset
tff(fact_5156_sum__mset__constant,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(C)
     => ! [Y: C,A4: multiset(D)] : comm_m7189776963980413722m_mset(C,image_mset(D,C,aTP_Lamp_fy(C,fun(D,C),Y),A4)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(multiset(D),nat,size_size(multiset(D)),A4))),Y) ) ).

% sum_mset_constant
tff(fact_5157_numeral__BitM,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [N: num] : aa(num,C,numeral_numeral(C),bitM(N)) = minus_minus(C,aa(num,C,numeral_numeral(C),bit0(N)),one_one(C)) ) ).

% numeral_BitM
tff(fact_5158_mset__empty__count,axiom,
    ! [C: $tType,M: multiset(C)] :
      ( ! [P4: C] : aa(C,nat,count(C,M),P4) = zero_zero(nat)
    <=> ( M = zero_zero(multiset(C)) ) ) ).

% mset_empty_count
tff(fact_5159_sum__mset__replicate__mset,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [N: nat,A3: C] : comm_m7189776963980413722m_mset(C,replicate_mset(C,N,A3)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),A3) ) ).

% sum_mset_replicate_mset
tff(fact_5160_sum__mset__delta,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_1(C)
     => ! [Y: D,C3: C,A4: multiset(D)] : comm_m7189776963980413722m_mset(C,image_mset(D,C,aa(C,fun(D,C),aTP_Lamp_rd(D,fun(C,fun(D,C)),Y),C3),A4)) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),aa(nat,C,semiring_1_of_nat(C),aa(D,nat,count(D,A4),Y))) ) ).

% sum_mset_delta
tff(fact_5161_sum__mset__delta_H,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_1(C)
     => ! [Y: D,C3: C,A4: multiset(D)] : comm_m7189776963980413722m_mset(C,image_mset(D,C,aa(C,fun(D,C),aTP_Lamp_re(D,fun(C,fun(D,C)),Y),C3),A4)) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),aa(nat,C,semiring_1_of_nat(C),aa(D,nat,count(D,A4),Y))) ) ).

% sum_mset_delta'
tff(fact_5162_sum__mset__product,axiom,
    ! [E2: $tType,C: $tType,D: $tType] :
      ( ( comm_monoid_add(D)
        & times(D)
        & semiring_0(C) )
     => ! [F: fun(D,C),A4: multiset(D),G: fun(E2,C),B3: multiset(E2)] : aa(C,C,aa(C,fun(C,C),times_times(C),comm_m7189776963980413722m_mset(C,image_mset(D,C,F,A4))),comm_m7189776963980413722m_mset(C,image_mset(E2,C,G,B3))) = comm_m7189776963980413722m_mset(C,image_mset(D,C,aa(multiset(E2),fun(D,C),aa(fun(E2,C),fun(multiset(E2),fun(D,C)),aTP_Lamp_rg(fun(D,C),fun(fun(E2,C),fun(multiset(E2),fun(D,C))),F),G),B3),A4)) ) ).

% sum_mset_product
tff(fact_5163_sum__mset__distrib__right,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [F: fun(D,C),M: multiset(D),C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),comm_m7189776963980413722m_mset(C,image_mset(D,C,F,M))),C3) = comm_m7189776963980413722m_mset(C,image_mset(D,C,aa(C,fun(D,C),aTP_Lamp_gf(fun(D,C),fun(C,fun(D,C)),F),C3),M)) ) ).

% sum_mset_distrib_right
tff(fact_5164_sum__mset__distrib__left,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [C3: C,F: fun(D,C),M: multiset(D)] : aa(C,C,aa(C,fun(C,C),times_times(C),C3),comm_m7189776963980413722m_mset(C,image_mset(D,C,F,M))) = comm_m7189776963980413722m_mset(C,image_mset(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_ge(C,fun(fun(D,C),fun(D,C)),C3),F),M)) ) ).

% sum_mset_distrib_left
tff(fact_5165_count__ne__remove,axiom,
    ! [C: $tType,X: C,T4: C,S: multiset(C)] :
      ( ( X != T4 )
     => ( aa(C,nat,count(C,S),X) = aa(C,nat,count(C,minus_minus(multiset(C),S,add_mset(C,T4,zero_zero(multiset(C))))),X) ) ) ).

% count_ne_remove
tff(fact_5166_count__mset__set__finite__iff,axiom,
    ! [C: $tType,S: set(C),A3: C] :
      ( aa(set(C),$o,finite_finite2(C),S)
     => ( aa(C,nat,count(C,mset_set(C,S)),A3) = $ite(member2(C,A3,S),one_one(nat),zero_zero(nat)) ) ) ).

% count_mset_set_finite_iff
tff(fact_5167_prod__mset__delta_H,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [Y: D,C3: C,A4: multiset(D)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,aa(C,fun(D,C),aTP_Lamp_rh(D,fun(C,fun(D,C)),Y),C3),A4)) = aa(nat,C,aa(C,fun(nat,C),power_power(C),C3),aa(D,nat,count(D,A4),Y)) ) ).

% prod_mset_delta'
tff(fact_5168_prod__mset__delta,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [Y: D,C3: C,A4: multiset(D)] : aa(multiset(C),C,comm_m9189036328036947845d_mset(C),image_mset(D,C,aa(C,fun(D,C),aTP_Lamp_ri(D,fun(C,fun(D,C)),Y),C3),A4)) = aa(nat,C,aa(C,fun(nat,C),power_power(C),C3),aa(D,nat,count(D,A4),Y)) ) ).

% prod_mset_delta
tff(fact_5169_power__diff__conv__inverse,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: nat,N: nat] :
          ( ( X != zero_zero(C) )
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
           => ( aa(nat,C,aa(C,fun(nat,C),power_power(C),X),minus_minus(nat,N,M2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),inverse_inverse(C,X)),M2)) ) ) ) ) ).

% power_diff_conv_inverse
tff(fact_5170_sum__list__triv,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(C)
     => ! [R3: C,Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aTP_Lamp_fy(C,fun(D,C),R3)),Xs)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),aa(list(D),nat,size_size(list(D)),Xs))),R3) ) ).

% sum_list_triv
tff(fact_5171_add_Ogroup__axioms,axiom,
    ! [C: $tType] :
      ( group_add(C)
     => group(C,plus_plus(C),zero_zero(C),uminus_uminus(C)) ) ).

% add.group_axioms
tff(fact_5172_inverse__mult__distrib,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] : inverse_inverse(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,A3)),inverse_inverse(C,B2)) ) ).

% inverse_mult_distrib
tff(fact_5173_inverse__1,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ( inverse_inverse(C,one_one(C)) = one_one(C) ) ) ).

% inverse_1
tff(fact_5174_inverse__eq__1__iff,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [X: C] :
          ( ( inverse_inverse(C,X) = one_one(C) )
        <=> ( X = one_one(C) ) ) ) ).

% inverse_eq_1_iff
tff(fact_5175_sum__list_ONil,axiom,
    ! [C: $tType] :
      ( monoid_add(C)
     => ( groups8242544230860333062m_list(C,nil(C)) = zero_zero(C) ) ) ).

% sum_list.Nil
tff(fact_5176_sum__list_OCons,axiom,
    ! [C: $tType] :
      ( monoid_add(C)
     => ! [X: C,Xs: list(C)] : groups8242544230860333062m_list(C,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),X),groups8242544230860333062m_list(C,Xs)) ) ).

% sum_list.Cons
tff(fact_5177_sum__list__0,axiom,
    ! [D: $tType,C: $tType] :
      ( monoid_add(C)
     => ! [Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aTP_Lamp_rj(D,C)),Xs)) = zero_zero(C) ) ).

% sum_list_0
tff(fact_5178_right__inverse,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),inverse_inverse(C,A3)) = one_one(C) ) ) ) ).

% right_inverse
tff(fact_5179_left__inverse,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,A3)),A3) = one_one(C) ) ) ) ).

% left_inverse
tff(fact_5180_inverse__eq__divide__numeral,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [W: num] : inverse_inverse(C,aa(num,C,numeral_numeral(C),W)) = divide_divide(C,one_one(C),aa(num,C,numeral_numeral(C),W)) ) ).

% inverse_eq_divide_numeral
tff(fact_5181_inverse__eq__divide__neg__numeral,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [W: num] : inverse_inverse(C,aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))) = divide_divide(C,one_one(C),aa(C,C,uminus_uminus(C),aa(num,C,numeral_numeral(C),W))) ) ).

% inverse_eq_divide_neg_numeral
tff(fact_5182_inverse__unique,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2) = one_one(C) )
         => ( inverse_inverse(C,A3) = B2 ) ) ) ).

% inverse_unique
tff(fact_5183_group_Oinverse__distrib__swap,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C,B2: C] :
      ( group(C,F,Z2,Inverse)
     => ( aa(C,C,Inverse,aa(C,C,aa(C,fun(C,C),F,A3),B2)) = aa(C,C,aa(C,fun(C,C),F,aa(C,C,Inverse,B2)),aa(C,C,Inverse,A3)) ) ) ).

% group.inverse_distrib_swap
tff(fact_5184_group_Ogroup__left__neutral,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C] :
      ( group(C,F,Z2,Inverse)
     => ( aa(C,C,aa(C,fun(C,C),F,Z2),A3) = A3 ) ) ).

% group.group_left_neutral
tff(fact_5185_group_Oinverse__neutral,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( group(C,F,Z2,Inverse)
     => ( aa(C,C,Inverse,Z2) = Z2 ) ) ).

% group.inverse_neutral
tff(fact_5186_group_Oinverse__inverse,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C] :
      ( group(C,F,Z2,Inverse)
     => ( aa(C,C,Inverse,aa(C,C,Inverse,A3)) = A3 ) ) ).

% group.inverse_inverse
tff(fact_5187_group_Oinverse__unique,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C,B2: C] :
      ( group(C,F,Z2,Inverse)
     => ( ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = Z2 )
       => ( aa(C,C,Inverse,A3) = B2 ) ) ) ).

% group.inverse_unique
tff(fact_5188_group_Oright__inverse,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C] :
      ( group(C,F,Z2,Inverse)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,Inverse,A3)) = Z2 ) ) ).

% group.right_inverse
tff(fact_5189_group_Oright__cancel,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),B2: C,A3: C,C3: C] :
      ( group(C,F,Z2,Inverse)
     => ( ( aa(C,C,aa(C,fun(C,C),F,B2),A3) = aa(C,C,aa(C,fun(C,C),F,C3),A3) )
      <=> ( B2 = C3 ) ) ) ).

% group.right_cancel
tff(fact_5190_group_Oleft__inverse,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C] :
      ( group(C,F,Z2,Inverse)
     => ( aa(C,C,aa(C,fun(C,C),F,aa(C,C,Inverse,A3)),A3) = Z2 ) ) ).

% group.left_inverse
tff(fact_5191_group_Oleft__cancel,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C),A3: C,B2: C,C3: C] :
      ( group(C,F,Z2,Inverse)
     => ( ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = aa(C,C,aa(C,fun(C,C),F,A3),C3) )
      <=> ( B2 = C3 ) ) ) ).

% group.left_cancel
tff(fact_5192_mult__commute__imp__mult__inverse__commute,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Y: C,X: C] :
          ( ( aa(C,C,aa(C,fun(C,C),times_times(C),Y),X) = aa(C,C,aa(C,fun(C,C),times_times(C),X),Y) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,Y)),X) = aa(C,C,aa(C,fun(C,C),times_times(C),X),inverse_inverse(C,Y)) ) ) ) ).

% mult_commute_imp_mult_inverse_commute
tff(fact_5193_nonzero__inverse__mult__distrib,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( inverse_inverse(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,B2)),inverse_inverse(C,A3)) ) ) ) ) ).

% nonzero_inverse_mult_distrib
tff(fact_5194_divide__inverse__commute,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] : divide_divide(C,A3,B2) = aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,B2)),A3) ) ).

% divide_inverse_commute
tff(fact_5195_divide__inverse,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C] : divide_divide(C,A3,B2) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),inverse_inverse(C,B2)) ) ).

% divide_inverse
tff(fact_5196_field__class_Ofield__divide__inverse,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] : divide_divide(C,A3,B2) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),inverse_inverse(C,B2)) ) ).

% field_class.field_divide_inverse
tff(fact_5197_inverse__eq__divide,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C] : inverse_inverse(C,A3) = divide_divide(C,one_one(C),A3) ) ).

% inverse_eq_divide
tff(fact_5198_power__mult__power__inverse__commute,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: nat,N: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)),aa(nat,C,aa(C,fun(nat,C),power_power(C),inverse_inverse(C,X)),N)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),inverse_inverse(C,X)),N)),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)) ) ).

% power_mult_power_inverse_commute
tff(fact_5199_power__mult__inverse__distrib,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [X: C,M2: nat] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)),inverse_inverse(C,X)) = aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,X)),aa(nat,C,aa(C,fun(nat,C),power_power(C),X),M2)) ) ).

% power_mult_inverse_distrib
tff(fact_5200_mult__inverse__of__nat__commute,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Xa: nat,X: C] : aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,aa(nat,C,semiring_1_of_nat(C),Xa))),X) = aa(C,C,aa(C,fun(C,C),times_times(C),X),inverse_inverse(C,aa(nat,C,semiring_1_of_nat(C),Xa))) ) ).

% mult_inverse_of_nat_commute
tff(fact_5201_mult__inverse__of__int__commute,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Xa: int,X: C] : aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,aa(int,C,ring_1_of_int(C),Xa))),X) = aa(C,C,aa(C,fun(C,C),times_times(C),X),inverse_inverse(C,aa(int,C,ring_1_of_int(C),Xa))) ) ).

% mult_inverse_of_int_commute
tff(fact_5202_sum__list__addf,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_add(C)
     => ! [F: fun(D,C),G: fun(D,C),Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aa(fun(D,C),fun(D,C),aTP_Lamp_rk(fun(D,C),fun(fun(D,C),fun(D,C)),F),G)),Xs)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))),groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),Xs))) ) ).

% sum_list_addf
tff(fact_5203_sum__list__mult__const,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_0(C)
     => ! [F: fun(D,C),C3: C,Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aa(C,fun(D,C),aTP_Lamp_gf(fun(D,C),fun(C,fun(D,C)),F),C3)),Xs)) = aa(C,C,aa(C,fun(C,C),times_times(C),groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))),C3) ) ).

% sum_list_mult_const
tff(fact_5204_sum__list__const__mult,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [C3: C,F: fun(D,C),Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aa(fun(D,C),fun(D,C),aTP_Lamp_ge(C,fun(fun(D,C),fun(D,C)),C3),F)),Xs)) = aa(C,C,aa(C,fun(C,C),times_times(C),C3),groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))) ) ).

% sum_list_const_mult
tff(fact_5205_sum__list__subtractf,axiom,
    ! [C: $tType,D: $tType] :
      ( ab_group_add(C)
     => ! [F: fun(D,C),G: fun(D,C),Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aa(fun(D,C),fun(D,C),aTP_Lamp_rl(fun(D,C),fun(fun(D,C),fun(D,C)),F),G)),Xs)) = minus_minus(C,groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs)),groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),Xs))) ) ).

% sum_list_subtractf
tff(fact_5206_inverse__le__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),inverse_inverse(C,X)),one_one(C))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),zero_zero(C))
            | aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),X) ) ) ) ).

% inverse_le_1_iff
tff(fact_5207_one__less__inverse,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),inverse_inverse(C,A3)) ) ) ) ).

% one_less_inverse
tff(fact_5208_one__less__inverse__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),inverse_inverse(C,X))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),X)
            & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X),one_one(C)) ) ) ) ).

% one_less_inverse_iff
tff(fact_5209_inverse__add,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),inverse_inverse(C,A3)),inverse_inverse(C,B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),inverse_inverse(C,A3))),inverse_inverse(C,B2)) ) ) ) ) ).

% inverse_add
tff(fact_5210_division__ring__inverse__add,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),inverse_inverse(C,A3)),inverse_inverse(C,B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,A3)),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2))),inverse_inverse(C,B2)) ) ) ) ) ).

% division_ring_inverse_add
tff(fact_5211_field__class_Ofield__inverse,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,A3)),A3) = one_one(C) ) ) ) ).

% field_class.field_inverse
tff(fact_5212_division__ring__inverse__diff,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( minus_minus(C,inverse_inverse(C,A3),inverse_inverse(C,B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),inverse_inverse(C,A3)),minus_minus(C,B2,A3))),inverse_inverse(C,B2)) ) ) ) ) ).

% division_ring_inverse_diff
tff(fact_5213_nonzero__inverse__eq__divide,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( inverse_inverse(C,A3) = divide_divide(C,one_one(C),A3) ) ) ) ).

% nonzero_inverse_eq_divide
tff(fact_5214_sum__list__abs,axiom,
    ! [C: $tType] :
      ( ordere166539214618696060dd_abs(C)
     => ! [Xs: list(C)] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,abs_abs(C),groups8242544230860333062m_list(C,Xs))),groups8242544230860333062m_list(C,aa(list(C),list(C),aa(fun(C,C),fun(list(C),list(C)),map(C,C),abs_abs(C)),Xs))) ) ).

% sum_list_abs
tff(fact_5215_uminus__sum__list__map,axiom,
    ! [C: $tType,D: $tType] :
      ( ab_group_add(C)
     => ! [F: fun(D,C),Xs: list(D)] : aa(C,C,uminus_uminus(C),groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),Xs))) = groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),comp(C,C,D,uminus_uminus(C),F)),Xs)) ) ).

% uminus_sum_list_map
tff(fact_5216_sum__list__replicate,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [N: nat,C3: C] : groups8242544230860333062m_list(C,aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),N),C3)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),N)),C3) ) ).

% sum_list_replicate
tff(fact_5217_sum__list__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( monoid_add(D)
        & ordere6658533253407199908up_add(D) )
     => ! [Xs: list(C),F: fun(C,D),G: fun(C,D)] :
          ( ! [X2: C] :
              ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,X2)),aa(C,D,G,X2)) )
         => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))),groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Xs))) ) ) ).

% sum_list_mono
tff(fact_5218_sum__list__map__filter_H,axiom,
    ! [C: $tType,D: $tType] :
      ( monoid_add(C)
     => ! [F: fun(D,C),Pa: fun(D,$o),Xs: list(D)] : groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),aa(list(D),list(D),aa(fun(D,$o),fun(list(D),list(D)),filter2(D),Pa),Xs))) = groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),aa(fun(D,$o),fun(D,C),aTP_Lamp_rm(fun(D,C),fun(fun(D,$o),fun(D,C)),F),Pa)),Xs)) ) ).

% sum_list_map_filter'
tff(fact_5219_inverse__le__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),inverse_inverse(C,A3)),inverse_inverse(C,B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),B2),A3) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),B2) ) ) ) ) ).

% inverse_le_iff
tff(fact_5220_inverse__less__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C,B2: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),inverse_inverse(C,A3)),inverse_inverse(C,B2))
        <=> ( ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),B2),A3) )
            & ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)),zero_zero(C))
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),A3),B2) ) ) ) ) ).

% inverse_less_iff
tff(fact_5221_one__le__inverse,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [A3: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),A3)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),A3),one_one(C))
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),inverse_inverse(C,A3)) ) ) ) ).

% one_le_inverse
tff(fact_5222_inverse__less__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),inverse_inverse(C,X)),one_one(C))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),zero_zero(C))
            | aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),X) ) ) ) ).

% inverse_less_1_iff
tff(fact_5223_one__le__inverse__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [X: C] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),inverse_inverse(C,X))
        <=> ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),zero_zero(C)),X)
            & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),one_one(C)) ) ) ) ).

% one_le_inverse_iff
tff(fact_5224_sum__list__strict__mono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( monoid_add(D)
        & strict9044650504122735259up_add(D) )
     => ! [Xs: list(C),F: fun(C,D),G: fun(C,D)] :
          ( ( Xs != nil(C) )
         => ( ! [X2: C] :
                ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
               => aa(D,$o,aa(D,fun(D,$o),ord_less(D),aa(C,D,F,X2)),aa(C,D,G,X2)) )
           => aa(D,$o,aa(D,fun(D,$o),ord_less(D),groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs))),groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Xs))) ) ) ) ).

% sum_list_strict_mono
tff(fact_5225_sum__list__map__filter,axiom,
    ! [D: $tType,C: $tType] :
      ( monoid_add(D)
     => ! [Xs: list(C),Pa: fun(C,$o),F: fun(C,D)] :
          ( ! [X2: C] :
              ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
             => ( ~ aa(C,$o,Pa,X2)
               => ( aa(C,D,F,X2) = zero_zero(D) ) ) )
         => ( groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),filter2(C),Pa),Xs))) = groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) ) ) ) ).

% sum_list_map_filter
tff(fact_5226_sum__list__distinct__conv__sum__set,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [Xs: list(C),F: fun(C,D)] :
          ( aa(list(C),$o,distinct(C),Xs)
         => ( groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),F),aa(list(C),set(C),set2(C),Xs)) ) ) ) ).

% sum_list_distinct_conv_sum_set
tff(fact_5227_sum_Odistinct__set__conv__list,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [Xs: list(C),G: fun(C,D)] :
          ( aa(list(C),$o,distinct(C),Xs)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(list(C),set(C),set2(C),Xs)) = groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Xs)) ) ) ) ).

% sum.distinct_set_conv_list
tff(fact_5228_sum__list__map__remove1,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [X: C,Xs: list(C),F: fun(C,D)] :
          ( member2(C,X,aa(list(C),set(C),set2(C),Xs))
         => ( groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),Xs)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(C,D,F,X)),groups8242544230860333062m_list(D,aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),remove1(C),X),Xs)))) ) ) ) ).

% sum_list_map_remove1
tff(fact_5229_sum__code,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_add(C)
     => ! [G: fun(D,C),Xs: list(D)] : aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),G),aa(list(D),set(D),set2(D),Xs)) = groups8242544230860333062m_list(C,aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),aa(list(D),list(D),remdups(D),Xs))) ) ).

% sum_code
tff(fact_5230_uncurry__curry__id,axiom,
    ! [E2: $tType,D: $tType,C: $tType,F: fun(product_prod(C,D),E2)] : uncurry(C,D,E2,product_curry(C,D,E2,F)) = F ).

% uncurry_curry_id
tff(fact_5231_curry__uncurry__id,axiom,
    ! [E2: $tType,D: $tType,C: $tType,F: fun(C,fun(D,E2))] : product_curry(C,D,E2,uncurry(C,D,E2,F)) = F ).

% curry_uncurry_id
tff(fact_5232_finite__reachable__restrictedI,axiom,
    ! [C: $tType,Q: set(C),I5: set(C),E5: set(product_prod(C,C))] :
      ( aa(set(C),$o,finite_finite2(C),Q)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),I5),Q)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),range(C,C,E5)),Q)
         => aa(set(C),$o,finite_finite2(C),image(C,C,aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),E5),I5)) ) ) ) ).

% finite_reachable_restrictedI
tff(fact_5233_Range__empty,axiom,
    ! [D: $tType,C: $tType] : range(D,C,bot_bot(set(product_prod(D,C)))) = bot_bot(set(C)) ).

% Range_empty
tff(fact_5234_Range__empty__iff,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(D,C))] :
      ( ( range(D,C,R3) = bot_bot(set(C)) )
    <=> ( R3 = bot_bot(set(product_prod(D,C))) ) ) ).

% Range_empty_iff
tff(fact_5235_Range__Int__subset,axiom,
    ! [C: $tType,D: $tType,A4: set(product_prod(D,C)),B3: set(product_prod(D,C))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),range(D,C,aa(set(product_prod(D,C)),set(product_prod(D,C)),aa(set(product_prod(D,C)),fun(set(product_prod(D,C)),set(product_prod(D,C))),inf_inf(set(product_prod(D,C))),A4),B3))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),range(D,C,A4)),range(D,C,B3))) ).

% Range_Int_subset
tff(fact_5236_trancl__Image__in__Range,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),V3: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),image(C,C,transitive_trancl(C,R),V3)),range(C,C,R)) ).

% trancl_Image_in_Range
tff(fact_5237_Range__rel__restrict,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),range(C,C,rel_restrict(C,R,A4))),minus_minus(set(C),range(C,C,R),A4)) ).

% Range_rel_restrict
tff(fact_5238_wf__UN,axiom,
    ! [D: $tType,C: $tType,I5: set(C),R3: fun(C,set(product_prod(D,D)))] :
      ( ! [I3: C] :
          ( member2(C,I3,I5)
         => wf(D,aa(C,set(product_prod(D,D)),R3,I3)) )
     => ( ! [I3: C,J3: C] :
            ( member2(C,I3,I5)
           => ( member2(C,J3,I5)
             => ( ( aa(C,set(product_prod(D,D)),R3,I3) != aa(C,set(product_prod(D,D)),R3,J3) )
               => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),domain(D,D,aa(C,set(product_prod(D,D)),R3,I3))),range(D,D,aa(C,set(product_prod(D,D)),R3,J3))) = bot_bot(set(D)) ) ) ) )
       => wf(D,aa(set(set(product_prod(D,D))),set(product_prod(D,D)),complete_Sup_Sup(set(product_prod(D,D))),aa(set(C),set(set(product_prod(D,D))),image2(C,set(product_prod(D,D)),R3),I5))) ) ) ).

% wf_UN
tff(fact_5239_dom__ran__disj__comp,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),domain(C,C,R)),range(C,C,R)) = bot_bot(set(C)) )
     => ( relcomp(C,C,C,R,R) = bot_bot(set(product_prod(C,C))) ) ) ).

% dom_ran_disj_comp
tff(fact_5240_wf__max,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( wf(C,converse(C,C,R))
     => ( ( R != bot_bot(set(product_prod(C,C))) )
       => ~ ! [M4: C] : ~ member2(C,M4,minus_minus(set(C),range(C,C,R),domain(C,C,R))) ) ) ).

% wf_max
tff(fact_5241_Domain__empty,axiom,
    ! [D: $tType,C: $tType] : domain(C,D,bot_bot(set(product_prod(C,D)))) = bot_bot(set(C)) ).

% Domain_empty
tff(fact_5242_Domain__empty__iff,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,D))] :
      ( ( domain(C,D,R3) = bot_bot(set(C)) )
    <=> ( R3 = bot_bot(set(product_prod(C,D))) ) ) ).

% Domain_empty_iff
tff(fact_5243_Domain__Int__subset,axiom,
    ! [D: $tType,C: $tType,A4: set(product_prod(C,D)),B3: set(product_prod(C,D))] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),domain(C,D,aa(set(product_prod(C,D)),set(product_prod(C,D)),aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),set(product_prod(C,D))),inf_inf(set(product_prod(C,D))),A4),B3))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),domain(C,D,A4)),domain(C,D,B3))) ).

% Domain_Int_subset
tff(fact_5244_for__in__RI,axiom,
    ! [D: $tType,C: $tType,X: C,R: set(product_prod(C,D))] :
      ( member2(C,X,domain(C,D,R))
     => member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),fun_of_rel(C,D,R,X)),R) ) ).

% for_in_RI
tff(fact_5245_Domain__rel__restrict,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A4: set(C)] : aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),domain(C,C,rel_restrict(C,R,A4))),minus_minus(set(C),domain(C,C,R),A4)) ).

% Domain_rel_restrict
tff(fact_5246_wf__no__path,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),domain(C,C,R)),range(C,C,R)) = bot_bot(set(C)) )
     => wf(C,R) ) ).

% wf_no_path
tff(fact_5247_wf__min,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( wf(C,R)
     => ( ( R != bot_bot(set(product_prod(C,C))) )
       => ~ ! [M4: C] : ~ member2(C,M4,minus_minus(set(C),domain(C,C,R),range(C,C,R))) ) ) ).

% wf_min
tff(fact_5248_wf__Un,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),S4: set(product_prod(C,C))] :
      ( wf(C,R3)
     => ( wf(C,S4)
       => ( ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),domain(C,C,R3)),range(C,C,S4)) = bot_bot(set(C)) )
         => wf(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),R3),S4)) ) ) ) ).

% wf_Un
tff(fact_5249_wf__Union,axiom,
    ! [C: $tType,R: set(set(product_prod(C,C)))] :
      ( ! [X2: set(product_prod(C,C))] :
          ( member2(set(product_prod(C,C)),X2,R)
         => wf(C,X2) )
     => ( ! [X2: set(product_prod(C,C))] :
            ( member2(set(product_prod(C,C)),X2,R)
           => ! [Xa4: set(product_prod(C,C))] :
                ( member2(set(product_prod(C,C)),Xa4,R)
               => ( ( X2 != Xa4 )
                 => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),domain(C,C,X2)),range(C,C,Xa4)) = bot_bot(set(C)) ) ) ) )
       => wf(C,aa(set(set(product_prod(C,C))),set(product_prod(C,C)),complete_Sup_Sup(set(product_prod(C,C))),R)) ) ) ).

% wf_Union
tff(fact_5250_and_Omonoid__axioms,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => monoid(C,bit_se5824344872417868541ns_and(C),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% and.monoid_axioms
tff(fact_5251_folding__insort__key_Oaxioms_I2_J,axiom,
    ! [C: $tType,D: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),S: set(D),F: fun(D,C)] :
      ( folding_insort_key(C,D,Less_eq,Less,S,F)
     => foldin3648464208017769352axioms(D,C,S,F) ) ).

% folding_insort_key.axioms(2)
tff(fact_5252_pure__assn__raw_Oelims_I3_J,axiom,
    ! [D: $tType,C: $tType,X: $o,Xa: product_prod(C,set(D))] :
      ( ~ aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(X)),Xa)
     => ~ ! [H2: C,As: set(D)] :
            ( ( Xa = aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As) )
           => ( ( As = bot_bot(set(D)) )
              & (X) ) ) ) ).

% pure_assn_raw.elims(3)
tff(fact_5253_monoid_Oleft__neutral,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,A3: C] :
      ( monoid(C,F,Z2)
     => ( aa(C,C,aa(C,fun(C,C),F,Z2),A3) = A3 ) ) ).

% monoid.left_neutral
tff(fact_5254_monoid_Oright__neutral,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,A3: C] :
      ( monoid(C,F,Z2)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),Z2) = A3 ) ) ).

% monoid.right_neutral
tff(fact_5255_add_Omonoid__axioms,axiom,
    ! [C: $tType] :
      ( monoid_add(C)
     => monoid(C,plus_plus(C),zero_zero(C)) ) ).

% add.monoid_axioms
tff(fact_5256_mult_Omonoid__axioms,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => monoid(C,times_times(C),one_one(C)) ) ).

% mult.monoid_axioms
tff(fact_5257_append_Omonoid__axioms,axiom,
    ! [C: $tType] : monoid(list(C),append(C),nil(C)) ).

% append.monoid_axioms
tff(fact_5258_sup__bot_Omonoid__axioms,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => monoid(C,sup_sup(C),bot_bot(C)) ) ).

% sup_bot.monoid_axioms
tff(fact_5259_inf__top_Omonoid__axioms,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => monoid(C,inf_inf(C),top_top(C)) ) ).

% inf_top.monoid_axioms
tff(fact_5260_folding__insort__key__axioms_Ointro,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),S: set(C)] :
      ( inj_on(C,D,F,S)
     => foldin3648464208017769352axioms(C,D,S,F) ) ).

% folding_insort_key_axioms.intro
tff(fact_5261_folding__insort__key__axioms__def,axiom,
    ! [D: $tType,C: $tType,S: set(C),F: fun(C,D)] :
      ( foldin3648464208017769352axioms(C,D,S,F)
    <=> inj_on(C,D,F,S) ) ).

% folding_insort_key_axioms_def
tff(fact_5262_pure__assn__raw_Osimps,axiom,
    ! [D: $tType,C: $tType,B2: $o,H: C,As2: set(D)] :
      ( aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(B2)),aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H),As2))
    <=> ( ( As2 = bot_bot(set(D)) )
        & (B2) ) ) ).

% pure_assn_raw.simps
tff(fact_5263_pure__assn__raw_Oelims_I1_J,axiom,
    ! [D: $tType,C: $tType,X: $o,Xa: product_prod(C,set(D)),Y: $o] :
      ( ( aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(X)),Xa)
      <=> (Y) )
     => ~ ! [H2: C,As: set(D)] :
            ( ( Xa = aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As) )
           => ( (Y)
            <=> ~ ( ( As = bot_bot(set(D)) )
                  & (X) ) ) ) ) ).

% pure_assn_raw.elims(1)
tff(fact_5264_pure__assn__raw_Oelims_I2_J,axiom,
    ! [D: $tType,C: $tType,X: $o,Xa: product_prod(C,set(D))] :
      ( aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(X)),Xa)
     => ~ ! [H2: C,As: set(D)] :
            ( ( Xa = aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As) )
           => ~ ( ( As = bot_bot(set(D)) )
                & (X) ) ) ) ).

% pure_assn_raw.elims(2)
tff(fact_5265_disjoint__image__subset,axiom,
    ! [C: $tType,A15: set(set(C)),F: fun(set(C),set(C))] :
      ( pairwise(set(C),disjnt(C),A15)
     => ( ! [X10: set(C)] :
            ( member2(set(C),X10,A15)
           => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),F,X10)),X10) )
       => pairwise(set(C),disjnt(C),aa(set(set(C)),set(set(C)),image2(set(C),set(C),F),A15)) ) ) ).

% disjoint_image_subset
tff(fact_5266_mergesort__by__rel__split_Opelims,axiom,
    ! [C: $tType,X: product_prod(list(C),list(C)),Xa: list(C),Y: product_prod(list(C),list(C))] :
      ( ( merges295452479951948502_split(C,X,Xa) = Y )
     => ( accp(product_prod(product_prod(list(C),list(C)),list(C)),merges7066485432131860899it_rel(C),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),X),Xa))
       => ( ! [Xs12: list(C),Xs22: list(C)] :
              ( ( X = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
             => ( ( Xa = nil(C) )
               => ( ( Y = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
                 => ~ accp(product_prod(product_prod(list(C),list(C)),list(C)),merges7066485432131860899it_rel(C),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22)),nil(C))) ) ) )
         => ( ! [Xs12: list(C),Xs22: list(C)] :
                ( ( X = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
               => ! [X2: C] :
                    ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)) )
                   => ( ( Y = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs12)),Xs22) )
                     => ~ accp(product_prod(product_prod(list(C),list(C)),list(C)),merges7066485432131860899it_rel(C),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),nil(C)))) ) ) )
           => ~ ! [Xs12: list(C),Xs22: list(C)] :
                  ( ( X = aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22) )
                 => ! [X1: C,X23: C,Xs2: list(C)] :
                      ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs2)) )
                     => ( ( Y = merges295452479951948502_split(C,aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),Xs12)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs22)),Xs2) )
                       => ~ accp(product_prod(product_prod(list(C),list(C)),list(C)),merges7066485432131860899it_rel(C),aa(list(C),product_prod(product_prod(list(C),list(C)),list(C)),aa(product_prod(list(C),list(C)),fun(list(C),product_prod(product_prod(list(C),list(C)),list(C))),product_Pair(product_prod(list(C),list(C)),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Xs12),Xs22)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X1),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X23),Xs2)))) ) ) ) ) ) ) ) ).

% mergesort_by_rel_split.pelims
tff(fact_5267_max__of__antimono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_antimono(C,D,F)
         => ( aa(D,D,aa(D,fun(D,D),ord_max(D),aa(C,D,F,X)),aa(C,D,F,Y)) = aa(C,D,F,aa(C,C,aa(C,fun(C,C),ord_min(C),X),Y)) ) ) ) ).

% max_of_antimono
tff(fact_5268_pairwise__trivial,axiom,
    ! [C: $tType,I5: set(C)] : pairwise(C,aTP_Lamp_fn(C,fun(C,$o)),I5) ).

% pairwise_trivial
tff(fact_5269_pairwise__def,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),S: set(C)] :
      ( pairwise(C,R,S)
    <=> ! [X4: C] :
          ( member2(C,X4,S)
         => ! [Xa2: C] :
              ( member2(C,Xa2,S)
             => ( ( X4 != Xa2 )
               => aa(C,$o,aa(C,fun(C,$o),R,X4),Xa2) ) ) ) ) ).

% pairwise_def
tff(fact_5270_pairwiseI,axiom,
    ! [C: $tType,S: set(C),R: fun(C,fun(C,$o))] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,S)
         => ( member2(C,Y2,S)
           => ( ( X2 != Y2 )
             => aa(C,$o,aa(C,fun(C,$o),R,X2),Y2) ) ) )
     => pairwise(C,R,S) ) ).

% pairwiseI
tff(fact_5271_pairwiseD,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),S: set(C),X: C,Y: C] :
      ( pairwise(C,R,S)
     => ( member2(C,X,S)
       => ( member2(C,Y,S)
         => ( ( X != Y )
           => aa(C,$o,aa(C,fun(C,$o),R,X),Y) ) ) ) ) ).

% pairwiseD
tff(fact_5272_pairwise__insert,axiom,
    ! [C: $tType,R3: fun(C,fun(C,$o)),X: C,S4: set(C)] :
      ( pairwise(C,R3,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),S4))
    <=> ( ! [Y3: C] :
            ( ( member2(C,Y3,S4)
              & ( Y3 != X ) )
           => ( aa(C,$o,aa(C,fun(C,$o),R3,X),Y3)
              & aa(C,$o,aa(C,fun(C,$o),R3,Y3),X) ) )
        & pairwise(C,R3,S4) ) ) ).

% pairwise_insert
tff(fact_5273_pairwise__subset,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),S: set(C),T: set(C)] :
      ( pairwise(C,Pa,S)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),T),S)
       => pairwise(C,Pa,T) ) ) ).

% pairwise_subset
tff(fact_5274_pairwise__mono,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),A4: set(C),Q: fun(C,fun(C,$o)),B3: set(C)] :
      ( pairwise(C,Pa,A4)
     => ( ! [X2: C,Y2: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Pa,X2),Y2)
           => aa(C,$o,aa(C,fun(C,$o),Q,X2),Y2) )
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),A4)
         => pairwise(C,Q,B3) ) ) ) ).

% pairwise_mono
tff(fact_5275_pairwise__empty,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o))] : pairwise(C,Pa,bot_bot(set(C))) ).

% pairwise_empty
tff(fact_5276_pairwise__imageI,axiom,
    ! [D: $tType,C: $tType,A4: set(C),F: fun(C,D),Pa: fun(D,fun(D,$o))] :
      ( ! [X2: C,Y2: C] :
          ( member2(C,X2,A4)
         => ( member2(C,Y2,A4)
           => ( ( X2 != Y2 )
             => ( ( aa(C,D,F,X2) != aa(C,D,F,Y2) )
               => aa(D,$o,aa(D,fun(D,$o),Pa,aa(C,D,F,X2)),aa(C,D,F,Y2)) ) ) ) )
     => pairwise(D,Pa,aa(set(C),set(D),image2(C,D,F),A4)) ) ).

% pairwise_imageI
tff(fact_5277_pairwise__image,axiom,
    ! [C: $tType,D: $tType,R3: fun(C,fun(C,$o)),F: fun(D,C),S4: set(D)] :
      ( pairwise(C,R3,aa(set(D),set(C),image2(D,C,F),S4))
    <=> pairwise(D,aa(fun(D,C),fun(D,fun(D,$o)),aTP_Lamp_rn(fun(C,fun(C,$o)),fun(fun(D,C),fun(D,fun(D,$o))),R3),F),S4) ) ).

% pairwise_image
tff(fact_5278_antimono__def,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D)] :
          ( order_antimono(C,D,F)
        <=> ! [X4: C,Y3: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),Y3)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,Y3)),aa(C,D,F,X4)) ) ) ) ).

% antimono_def
tff(fact_5279_antimonoI,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D)] :
          ( ! [X2: C,Y2: C] :
              ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Y2)
             => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,Y2)),aa(C,D,F,X2)) )
         => order_antimono(C,D,F) ) ) ).

% antimonoI
tff(fact_5280_antimonoE,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_antimono(C,D,F)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,Y)),aa(C,D,F,X)) ) ) ) ).

% antimonoE
tff(fact_5281_antimonoD,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_antimono(C,D,F)
         => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X),Y)
           => aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,F,Y)),aa(C,D,F,X)) ) ) ) ).

% antimonoD
tff(fact_5282_pairwise__disjnt__iff,axiom,
    ! [C: $tType,A15: set(set(C))] :
      ( pairwise(set(C),disjnt(C),A15)
    <=> ! [X4: C] : uniq(set(C),aa(C,fun(set(C),$o),aTP_Lamp_ro(set(set(C)),fun(C,fun(set(C),$o)),A15),X4)) ) ).

% pairwise_disjnt_iff
tff(fact_5283_pairwise__singleton,axiom,
    ! [C: $tType,Pa: fun(C,fun(C,$o)),A4: C] : pairwise(C,Pa,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A4),bot_bot(set(C)))) ).

% pairwise_singleton
tff(fact_5284_pairwise__alt,axiom,
    ! [C: $tType,R: fun(C,fun(C,$o)),S: set(C)] :
      ( pairwise(C,R,S)
    <=> ! [X4: C] :
          ( member2(C,X4,S)
         => ! [Xa2: C] :
              ( member2(C,Xa2,minus_minus(set(C),S,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),bot_bot(set(C)))))
             => aa(C,$o,aa(C,fun(C,$o),R,X4),Xa2) ) ) ) ).

% pairwise_alt
tff(fact_5285_min__of__antimono,axiom,
    ! [D: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(D) )
     => ! [F: fun(C,D),X: C,Y: C] :
          ( order_antimono(C,D,F)
         => ( aa(D,D,aa(D,fun(D,D),ord_min(D),aa(C,D,F,X)),aa(C,D,F,Y)) = aa(C,D,F,aa(C,C,aa(C,fun(C,C),ord_max(C),X),Y)) ) ) ) ).

% min_of_antimono
tff(fact_5286_in__chain__finite,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [A4: set(C)] :
          ( comple1602240252501008431_chain(C,ord_less_eq(C),A4)
         => ( aa(set(C),$o,finite_finite2(C),A4)
           => ( ( A4 != bot_bot(set(C)) )
             => member2(C,aa(set(C),C,complete_Sup_Sup(C),A4),A4) ) ) ) ) ).

% in_chain_finite
tff(fact_5287_drop__bit__of__1,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [N: nat] : bit_se4197421643247451524op_bit(C,N,one_one(C)) = aa($o,C,zero_neq_one_of_bool(C),N = zero_zero(nat)) ) ).

% drop_bit_of_1
tff(fact_5288_bit__double__iff,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [A3: C,N: nat] :
          ( bit_se5641148757651400278ts_bit(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),A3),N)
        <=> ( bit_se5641148757651400278ts_bit(C,A3,minus_minus(nat,N,one_one(nat)))
            & ( N != zero_zero(nat) )
            & bit_se6407376104438227557le_bit(C,type2(C),N) ) ) ) ).

% bit_double_iff
tff(fact_5289_bit__minus__1__iff,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [N: nat] :
          ( bit_se5641148757651400278ts_bit(C,aa(C,C,uminus_uminus(C),one_one(C)),N)
        <=> bit_se6407376104438227557le_bit(C,type2(C),N) ) ) ).

% bit_minus_1_iff
tff(fact_5290_chain__empty,axiom,
    ! [C: $tType,Ord: fun(C,fun(C,$o))] : comple1602240252501008431_chain(C,Ord,bot_bot(set(C))) ).

% chain_empty
tff(fact_5291_bit__minus__iff,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => ! [A3: C,N: nat] :
          ( bit_se5641148757651400278ts_bit(C,aa(C,C,uminus_uminus(C),A3),N)
        <=> ( bit_se6407376104438227557le_bit(C,type2(C),N)
            & ~ bit_se5641148757651400278ts_bit(C,minus_minus(C,A3,one_one(C)),N) ) ) ) ).

% bit_minus_iff
tff(fact_5292_ccpo__Sup__mono,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [A4: set(C),B3: set(C)] :
          ( comple1602240252501008431_chain(C,ord_less_eq(C),A4)
         => ( comple1602240252501008431_chain(C,ord_less_eq(C),B3)
           => ( ! [X2: C] :
                  ( member2(C,X2,A4)
                 => ? [Xa3: C] :
                      ( member2(C,Xa3,B3)
                      & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X2),Xa3) ) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(C),C,complete_Sup_Sup(C),A4)),aa(set(C),C,complete_Sup_Sup(C),B3)) ) ) ) ) ).

% ccpo_Sup_mono
tff(fact_5293_drop__bit__exp__eq,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [M2: nat,N: nat] :
          bit_se4197421643247451524op_bit(C,M2,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),N)) = aa(C,C,
            aa(C,fun(C,C),times_times(C),
              aa($o,C,zero_neq_one_of_bool(C),
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M2),N)
                & bit_se6407376104438227557le_bit(C,type2(C),N) ))),
            aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),minus_minus(nat,N,M2))) ) ).

% drop_bit_exp_eq
tff(fact_5294_chain__singleton,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [X: C] : comple1602240252501008431_chain(C,ord_less_eq(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))) ) ).

% chain_singleton
tff(fact_5295_div__push__bit__of__1__eq__drop__bit,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C,N: nat] : divide_divide(C,A3,bit_se4730199178511100633sh_bit(C,N,one_one(C))) = bit_se4197421643247451524op_bit(C,N,A3) ) ).

% div_push_bit_of_1_eq_drop_bit
tff(fact_5296_bit__iff__and__drop__bit__eq__1,axiom,
    ! [C: $tType] :
      ( bit_se359711467146920520ations(C)
     => ! [A3: C,N: nat] :
          ( bit_se5641148757651400278ts_bit(C,A3,N)
        <=> ( aa(C,C,aa(C,fun(C,C),bit_se5824344872417868541ns_and(C),bit_se4197421643247451524op_bit(C,N,A3)),one_one(C)) = one_one(C) ) ) ) ).

% bit_iff_and_drop_bit_eq_1
tff(fact_5297_bit__mask__sub__iff,axiom,
    ! [C: $tType] :
      ( bit_semiring_bits(C)
     => ! [M2: nat,N: nat] :
          ( bit_se5641148757651400278ts_bit(C,minus_minus(C,aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(num,C,numeral_numeral(C),bit0(one2))),M2),one_one(C)),N)
        <=> ( bit_se6407376104438227557le_bit(C,type2(C),N)
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M2) ) ) ) ).

% bit_mask_sub_iff
tff(fact_5298_list__ex1__simps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      ( list_ex1(C,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> $ite(aa(C,$o,Pa,X),aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),aa(C,fun(C,$o),aTP_Lamp_rp(fun(C,$o),fun(C,fun(C,$o)),Pa),X)),Xs),list_ex1(C,Pa,Xs)) ) ).

% list_ex1_simps(2)
tff(fact_5299_list__ex__iff__not__all__inverval__int,axiom,
    ! [Pa: fun(int,$o),I: int,J: int] :
      ( aa(list(int),$o,aa(fun(int,$o),fun(list(int),$o),list_ex(int),Pa),upto(I,J))
    <=> ~ all_interval_int(comp($o,$o,int,fNot,Pa),I,J) ) ).

% list_ex_iff_not_all_inverval_int
tff(fact_5300_all__interval__int__def,axiom,
    ! [Pa: fun(int,$o),I: int,J: int] :
      ( all_interval_int(Pa,I,J)
    <=> ! [X4: int] :
          ( member2(int,X4,set_or1337092689740270186AtMost(int,I,J))
         => aa(int,$o,Pa,X4) ) ) ).

% all_interval_int_def
tff(fact_5301_list_Opred__inject_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),A3: C,Aa2: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),Aa2))
    <=> ( aa(C,$o,Pa,A3)
        & aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Aa2) ) ) ).

% list.pred_inject(2)
tff(fact_5302_list__all__simps_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> ( aa(C,$o,Pa,X)
        & aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Xs) ) ) ).

% list_all_simps(1)
tff(fact_5303_list__all__simps_I2_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),nil(C)) ).

% list_all_simps(2)
tff(fact_5304_list__all__append,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Xs)
        & aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Ys) ) ) ).

% list_all_append
tff(fact_5305_list__all__rev,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),aa(list(C),list(C),rev(C),Xs))
    <=> aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Xs) ) ).

% list_all_rev
tff(fact_5306_list_Opred__mono__strong,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: list(C),Paa: fun(C,$o)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),X)
     => ( ! [Z4: C] :
            ( member2(C,Z4,aa(list(C),set(C),set2(C),X))
           => ( aa(C,$o,Pa,Z4)
             => aa(C,$o,Paa,Z4) ) )
       => aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Paa),X) ) ) ).

% list.pred_mono_strong
tff(fact_5307_list__all__cong,axiom,
    ! [C: $tType,X: list(C),Ya: list(C),Pa: fun(C,$o),Paa: fun(C,$o)] :
      ( ( X = Ya )
     => ( ! [Z4: C] :
            ( member2(C,Z4,aa(list(C),set(C),set2(C),Ya))
           => ( aa(C,$o,Pa,Z4)
            <=> aa(C,$o,Paa,Z4) ) )
       => ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),X)
        <=> aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Paa),Ya) ) ) ) ).

% list_all_cong
tff(fact_5308_list_Opred__True,axiom,
    ! [C: $tType,X3: list(C)] : aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),aTP_Lamp_ku(C,$o)),X3) ).

% list.pred_True
tff(fact_5309_list__all__iff__all__interval__int,axiom,
    ! [Pa: fun(int,$o),I: int,J: int] :
      ( aa(list(int),$o,aa(fun(int,$o),fun(list(int),$o),list_all(int),Pa),upto(I,J))
    <=> all_interval_int(Pa,I,J) ) ).

% list_all_iff_all_interval_int
tff(fact_5310_list_Opred__inject_I1_J,axiom,
    ! [C: $tType,Pa: fun(C,$o)] : aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),nil(C)) ).

% list.pred_inject(1)
tff(fact_5311_list_Omap__cong__pred,axiom,
    ! [D: $tType,C: $tType,X: list(C),Ya: list(C),F: fun(C,D),G: fun(C,D)] :
      ( ( X = Ya )
     => ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),aa(fun(C,D),fun(C,$o),aTP_Lamp_rq(fun(C,D),fun(fun(C,D),fun(C,$o)),F),G)),Ya)
       => ( aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),X) = aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),G),Ya) ) ) ) ).

% list.map_cong_pred
tff(fact_5312_list_Opred__mono,axiom,
    ! [C: $tType,Pa: fun(C,$o),Paa: fun(C,$o)] :
      ( aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less_eq(fun(C,$o)),Pa),Paa)
     => aa(fun(list(C),$o),$o,aa(fun(list(C),$o),fun(fun(list(C),$o),$o),ord_less_eq(fun(list(C),$o)),aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa)),aa(fun(C,$o),fun(list(C),$o),list_all(C),Paa)) ) ).

% list.pred_mono
tff(fact_5313_prop__matchD,axiom,
    ! [C: $tType,Al: list(C),E4: C,Bl: list(C),Al2: list(C),E3: C,Bl2: list(C),Pa: fun(C,$o)] :
      ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),Bl)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E3),Bl2)) )
     => ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Al)
       => ( ~ aa(C,$o,Pa,E4)
         => ( ~ aa(C,$o,Pa,E3)
           => ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Bl)
             => ( ( Al = Al2 )
                & ( E4 = E3 )
                & ( Bl = Bl2 ) ) ) ) ) ) ) ).

% prop_matchD
tff(fact_5314_prop__match,axiom,
    ! [C: $tType,Pa: fun(C,$o),Al: list(C),E4: C,E3: C,Bl: list(C),Al2: list(C),Bl2: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Al)
     => ( ~ aa(C,$o,Pa,E4)
       => ( ~ aa(C,$o,Pa,E3)
         => ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Bl)
           => ( ( aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E4),Bl)) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Al2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E3),Bl2)) )
            <=> ( ( Al = Al2 )
                & ( E4 = E3 )
                & ( Bl = Bl2 ) ) ) ) ) ) ) ).

% prop_match
tff(fact_5315_Ball__set__list__all,axiom,
    ! [C: $tType,Xs: list(C),Pa: fun(C,$o)] :
      ( ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,Pa,X4) )
    <=> aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Xs) ) ).

% Ball_set_list_all
tff(fact_5316_list__all__iff,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),X)
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),X))
         => aa(C,$o,Pa,X4) ) ) ).

% list_all_iff
tff(fact_5317_list_Opred__set,axiom,
    ! [C: $tType,Pa: fun(C,$o),X3: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),X3)
    <=> ! [Xa2: C] :
          ( member2(C,Xa2,aa(list(C),set(C),set2(C),X3))
         => aa(C,$o,Pa,Xa2) ) ) ).

% list.pred_set
tff(fact_5318_list_Opred__map,axiom,
    ! [C: $tType,D: $tType,Q: fun(C,$o),F: fun(D,C),X: list(D)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Q),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),F),X))
    <=> aa(list(D),$o,aa(fun(D,$o),fun(list(D),$o),list_all(D),comp(C,$o,D,Q,F)),X) ) ).

% list.pred_map
tff(fact_5319_list__all__length,axiom,
    ! [C: $tType,Pa: fun(C,$o),Xs: list(C)] :
      ( aa(list(C),$o,aa(fun(C,$o),fun(list(C),$o),list_all(C),Pa),Xs)
    <=> ! [N3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(C),nat,size_size(list(C)),Xs))
         => aa(C,$o,Pa,aa(nat,C,nth(C,Xs),N3)) ) ) ).

% list_all_length
tff(fact_5320_If__the__inv__into__in__Func,axiom,
    ! [D: $tType,C: $tType,G: fun(C,D),C4: set(C),B3: set(C),X: C] :
      ( inj_on(C,D,G,C4)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C4),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))
       => member2(fun(D,C),aa(C,fun(D,C),aa(set(C),fun(C,fun(D,C)),aTP_Lamp_rr(fun(C,D),fun(set(C),fun(C,fun(D,C))),G),C4),X),bNF_Wellorder_Func(D,C,top_top(set(D)),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ).

% If_the_inv_into_in_Func
tff(fact_5321_is__num_Osimps,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [A3: C] :
          ( neg_numeral_is_num(C,A3)
        <=> ( ( A3 = one_one(C) )
            | ? [X4: C] :
                ( ( A3 = aa(C,C,uminus_uminus(C),X4) )
                & neg_numeral_is_num(C,X4) )
            | ? [X4: C,Y3: C] :
                ( ( A3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),X4),Y3) )
                & neg_numeral_is_num(C,X4)
                & neg_numeral_is_num(C,Y3) ) ) ) ) ).

% is_num.simps
tff(fact_5322_Func__is__emp,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ( bNF_Wellorder_Func(C,D,A4,B3) = bot_bot(set(fun(C,D))) )
    <=> ( ( A4 != bot_bot(set(C)) )
        & ( B3 = bot_bot(set(D)) ) ) ) ).

% Func_is_emp
tff(fact_5323_Func__non__emp,axiom,
    ! [C: $tType,D: $tType,B3: set(C),A4: set(D)] :
      ( ( B3 != bot_bot(set(C)) )
     => ( bNF_Wellorder_Func(D,C,A4,B3) != bot_bot(set(fun(D,C))) ) ) ).

% Func_non_emp
tff(fact_5324_is__num__normalize_I4_J,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => neg_numeral_is_num(C,one_one(C)) ) ).

% is_num_normalize(4)
tff(fact_5325_Func__empty,axiom,
    ! [D: $tType,C: $tType,B3: set(D)] : bNF_Wellorder_Func(C,D,bot_bot(set(C)),B3) = aa(set(fun(C,D)),set(fun(C,D)),aa(fun(C,D),fun(set(fun(C,D)),set(fun(C,D))),insert2(fun(C,D)),aTP_Lamp_rs(C,D)),bot_bot(set(fun(C,D)))) ).

% Func_empty
tff(fact_5326_is__num_Ocases,axiom,
    ! [C: $tType] :
      ( neg_numeral(C)
     => ! [A3: C] :
          ( neg_numeral_is_num(C,A3)
         => ( ( A3 != one_one(C) )
           => ( ! [X2: C] :
                  ( ( A3 = aa(C,C,uminus_uminus(C),X2) )
                 => ~ neg_numeral_is_num(C,X2) )
             => ~ ! [X2: C,Y2: C] :
                    ( ( A3 = aa(C,C,aa(C,fun(C,C),plus_plus(C),X2),Y2) )
                   => ( neg_numeral_is_num(C,X2)
                     => ~ neg_numeral_is_num(C,Y2) ) ) ) ) ) ) ).

% is_num.cases
tff(fact_5327_Func__map__surj,axiom,
    ! [E2: $tType,C: $tType,F4: $tType,D: $tType,F1: fun(D,C),A14: set(D),B17: set(C),F22: fun(E2,F4),B24: set(E2),A24: set(F4)] :
      ( ( aa(set(D),set(C),image2(D,C,F1),A14) = B17 )
     => ( inj_on(E2,F4,F22,B24)
       => ( aa(set(F4),$o,aa(set(F4),fun(set(F4),$o),ord_less_eq(set(F4)),aa(set(E2),set(F4),image2(E2,F4,F22),B24)),A24)
         => ( ( ( B24 = bot_bot(set(E2)) )
             => ( A24 = bot_bot(set(F4)) ) )
           => ( bNF_Wellorder_Func(E2,C,B24,B17) = aa(set(fun(F4,D)),set(fun(E2,C)),image2(fun(F4,D),fun(E2,C),bNF_We4925052301507509544nc_map(E2,D,C,F4,B24,F1,F22)),bNF_Wellorder_Func(F4,D,A24,A14)) ) ) ) ) ) ).

% Func_map_surj
tff(fact_5328_mult__one__div__unit__factor,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),A3),divide_divide(C,one_one(C),unit_f5069060285200089521factor(C,B2))) = divide_divide(C,A3,unit_f5069060285200089521factor(C,B2)) ) ).

% mult_one_div_unit_factor
tff(fact_5329_unit__factor__mult__unit__left,axiom,
    ! [C: $tType] :
      ( semido2269285787275462019factor(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( unit_f5069060285200089521factor(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),A3),unit_f5069060285200089521factor(C,B2)) ) ) ) ).

% unit_factor_mult_unit_left
tff(fact_5330_unit__factor__1,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ( unit_f5069060285200089521factor(C,one_one(C)) = one_one(C) ) ) ).

% unit_factor_1
tff(fact_5331_inv__unit__factor__eq__0__iff,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] :
          ( ( divide_divide(C,one_one(C),unit_f5069060285200089521factor(C,A3)) = zero_zero(C) )
        <=> ( A3 = zero_zero(C) ) ) ) ).

% inv_unit_factor_eq_0_iff
tff(fact_5332_unit__factor__mult__unit__right,axiom,
    ! [C: $tType] :
      ( semido2269285787275462019factor(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( unit_f5069060285200089521factor(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)) = aa(C,C,aa(C,fun(C,C),times_times(C),unit_f5069060285200089521factor(C,B2)),A3) ) ) ) ).

% unit_factor_mult_unit_right
tff(fact_5333_unit__factor__mult,axiom,
    ! [C: $tType] :
      ( normal6328177297339901930cative(C)
     => ! [A3: C,B2: C] : unit_f5069060285200089521factor(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),unit_f5069060285200089521factor(C,A3)),unit_f5069060285200089521factor(C,B2)) ) ).

% unit_factor_mult
tff(fact_5334_is__unit__unit__factor,axiom,
    ! [C: $tType] :
      ( semido2269285787275462019factor(C)
     => ! [A3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( unit_f5069060285200089521factor(C,A3) = A3 ) ) ) ).

% is_unit_unit_factor
tff(fact_5335_mult__gcd__left,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),C3),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),unit_f5069060285200089521factor(C,C3)),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))) ) ).

% mult_gcd_left
tff(fact_5336_mult__gcd__right,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))),unit_f5069060285200089521factor(C,C3)) ) ).

% mult_gcd_right
tff(fact_5337_gcd__mult__distrib,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [K: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),K),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),K),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),K),B2))),unit_f5069060285200089521factor(C,K)) ) ).

% gcd_mult_distrib
tff(fact_5338_unit__factor__is__unit,axiom,
    ! [C: $tType] :
      ( semido2269285787275462019factor(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => dvd_dvd(C,unit_f5069060285200089521factor(C,A3),one_one(C)) ) ) ).

% unit_factor_is_unit
tff(fact_5339_unit__factor__gcd,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          unit_f5069060285200089521factor(C,aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) = $ite(
            ( ( A3 = zero_zero(C) )
            & ( B2 = zero_zero(C) ) ),
            zero_zero(C),
            one_one(C) ) ) ).

% unit_factor_gcd
tff(fact_5340_unit__factor__Gcd,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] :
          unit_f5069060285200089521factor(C,gcd_Gcd(C,A4)) = $ite(gcd_Gcd(C,A4) = zero_zero(C),zero_zero(C),one_one(C)) ) ).

% unit_factor_Gcd
tff(fact_5341_Gcd__fin_Obounded__quasi__semilattice__set__axioms,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => bounde6485984586167503788ce_set(C,gcd_gcd(C),zero_zero(C),one_one(C),normal6383669964737779283malize(C)) ) ).

% Gcd_fin.bounded_quasi_semilattice_set_axioms
tff(fact_5342_Lcm__no__units,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] : gcd_Lcm(C,A4) = gcd_Lcm(C,minus_minus(set(C),A4,collect(C,aTP_Lamp_rt(C,$o)))) ) ).

% Lcm_no_units
tff(fact_5343_list__all__iff__all__interval__nat,axiom,
    ! [Pa: fun(nat,$o),I: nat,J: nat] :
      ( aa(list(nat),$o,aa(fun(nat,$o),fun(list(nat),$o),list_all(nat),Pa),upt(I,J))
    <=> all_interval_nat(Pa,I,J) ) ).

% list_all_iff_all_interval_nat
tff(fact_5344_normalize__mult__normalize__left,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C,B2: C] : aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),A3)),B2)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ).

% normalize_mult_normalize_left
tff(fact_5345_normalize__mult__normalize__right,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C,B2: C] : aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,normal6383669964737779283malize(C),B2))) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ).

% normalize_mult_normalize_right
tff(fact_5346_normalize__1,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ( aa(C,C,normal6383669964737779283malize(C),one_one(C)) = one_one(C) ) ) ).

% normalize_1
tff(fact_5347_gcd_Onormalize__bottom,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ( aa(C,C,normal6383669964737779283malize(C),one_one(C)) = one_one(C) ) ) ).

% gcd.normalize_bottom
tff(fact_5348_Lcm__empty,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ( gcd_Lcm(C,bot_bot(set(C))) = one_one(C) ) ) ).

% Lcm_empty
tff(fact_5349_Lcm__1__iff,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] :
          ( ( gcd_Lcm(C,A4) = one_one(C) )
        <=> ! [X4: C] :
              ( member2(C,X4,A4)
             => dvd_dvd(C,X4,one_one(C)) ) ) ) ).

% Lcm_1_iff
tff(fact_5350_unit__factor__mult__normalize,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),unit_f5069060285200089521factor(C,A3)),aa(C,C,normal6383669964737779283malize(C),A3)) = A3 ) ).

% unit_factor_mult_normalize
tff(fact_5351_normalize__mult__unit__factor,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),A3)),unit_f5069060285200089521factor(C,A3)) = A3 ) ).

% normalize_mult_unit_factor
tff(fact_5352_normalize__mult__unit__left,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,normal6383669964737779283malize(C),B2) ) ) ) ).

% normalize_mult_unit_left
tff(fact_5353_normalize__mult__unit__right,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => ( aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,normal6383669964737779283malize(C),A3) ) ) ) ).

% normalize_mult_unit_right
tff(fact_5354_unit__factor__normalize,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( unit_f5069060285200089521factor(C,aa(C,C,normal6383669964737779283malize(C),A3)) = one_one(C) ) ) ) ).

% unit_factor_normalize
tff(fact_5355_normalize__unit__factor,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] :
          ( ( A3 != zero_zero(C) )
         => ( aa(C,C,normal6383669964737779283malize(C),unit_f5069060285200089521factor(C,A3)) = one_one(C) ) ) ) ).

% normalize_unit_factor
tff(fact_5356_Lcm__singleton,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A3: C] : gcd_Lcm(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) = aa(C,C,normal6383669964737779283malize(C),A3) ) ).

% Lcm_singleton
tff(fact_5357_normalize__div,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] : divide_divide(C,aa(C,C,normal6383669964737779283malize(C),A3),A3) = divide_divide(C,one_one(C),unit_f5069060285200089521factor(C,A3)) ) ).

% normalize_div
tff(fact_5358_Gcd__singleton,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A3: C] : gcd_Gcd(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))) = aa(C,C,normal6383669964737779283malize(C),A3) ) ).

% Gcd_singleton
tff(fact_5359_Lcm__mult,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C),C3: C] :
          ( ( A4 != bot_bot(set(C)) )
         => ( gcd_Lcm(C,aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),times_times(C),C3)),A4)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),gcd_Lcm(C,A4))) ) ) ) ).

% Lcm_mult
tff(fact_5360_gcd__mult__left,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2))) ) ).

% gcd_mult_left
tff(fact_5361_gcd__mult__right,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] : aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),B2),A3)),C3)) ) ).

% gcd_mult_right
tff(fact_5362_gcd__mult__distrib_H,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),C3)),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ).

% gcd_mult_distrib'
tff(fact_5363_normalize__mult,axiom,
    ! [C: $tType] :
      ( normal6328177297339901930cative(C)
     => ! [A3: C,B2: C] : aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),A3)),aa(C,C,normal6383669964737779283malize(C),B2)) ) ).

% normalize_mult
tff(fact_5364_associated__unit,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,normal6383669964737779283malize(C),A3) = aa(C,C,normal6383669964737779283malize(C),B2) )
         => ( dvd_dvd(C,A3,one_one(C))
           => dvd_dvd(C,B2,one_one(C)) ) ) ) ).

% associated_unit
tff(fact_5365_normalize__1__iff,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] :
          ( ( aa(C,C,normal6383669964737779283malize(C),A3) = one_one(C) )
        <=> dvd_dvd(C,A3,one_one(C)) ) ) ).

% normalize_1_iff
tff(fact_5366_is__unit__normalize,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,normal6383669964737779283malize(C),A3) = one_one(C) ) ) ) ).

% is_unit_normalize
tff(fact_5367_normalize__idem__imp__is__unit__iff,axiom,
    ! [C: $tType] :
      ( normal8620421768224518004emidom(C)
     => ! [A3: C] :
          ( ( aa(C,C,normal6383669964737779283malize(C),A3) = A3 )
         => ( dvd_dvd(C,A3,one_one(C))
          <=> ( A3 = one_one(C) ) ) ) ) ).

% normalize_idem_imp_is_unit_iff
tff(fact_5368_Gcd__mult,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [C3: C,A4: set(C)] : gcd_Gcd(C,aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),times_times(C),C3)),A4)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),gcd_Gcd(C,A4))) ) ).

% Gcd_mult
tff(fact_5369_unit__factor__Lcm,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] :
          unit_f5069060285200089521factor(C,gcd_Lcm(C,A4)) = $ite(gcd_Lcm(C,A4) = zero_zero(C),zero_zero(C),one_one(C)) ) ).

% unit_factor_Lcm
tff(fact_5370_all__interval__nat__def,axiom,
    ! [Pa: fun(nat,$o),I: nat,J: nat] :
      ( all_interval_nat(Pa,I,J)
    <=> ! [X4: nat] :
          ( member2(nat,X4,set_or7035219750837199246ssThan(nat,I,J))
         => aa(nat,$o,Pa,X4) ) ) ).

% all_interval_nat_def
tff(fact_5371_Gcd__fin__mult,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C),B2: C] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( aa(set(C),C,semiring_gcd_Gcd_fin(C),aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),times_times(C),B2)),A4)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),aa(set(C),C,semiring_gcd_Gcd_fin(C),A4))) ) ) ) ).

% Gcd_fin_mult
tff(fact_5372_list__ex__iff__not__all__inverval__nat,axiom,
    ! [Pa: fun(nat,$o),I: nat,J: nat] :
      ( aa(list(nat),$o,aa(fun(nat,$o),fun(list(nat),$o),list_ex(nat),Pa),upt(I,J))
    <=> ~ all_interval_nat(comp($o,$o,nat,fNot,Pa),I,J) ) ).

% list_ex_iff_not_all_inverval_nat
tff(fact_5373_gcd_Obounded__quasi__semilattice__axioms,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => bounde8507323023520639062attice(C,gcd_gcd(C),zero_zero(C),one_one(C),normal6383669964737779283malize(C)) ) ).

% gcd.bounded_quasi_semilattice_axioms
tff(fact_5374_Lcm__coprime,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A4: set(C)] :
          ( aa(set(C),$o,finite_finite2(C),A4)
         => ( ( A4 != bot_bot(set(C)) )
           => ( ! [A5: C,B4: C] :
                  ( member2(C,A5,A4)
                 => ( member2(C,B4,A4)
                   => ( ( A5 != B4 )
                     => algebr8660921524188924756oprime(C,A5,B4) ) ) )
             => ( gcd_Lcm(C,A4) = aa(C,C,normal6383669964737779283malize(C),aa(set(C),C,aa(fun(C,C),fun(set(C),C),groups7121269368397514597t_prod(C,C),aTP_Lamp_ru(C,C)),A4)) ) ) ) ) ) ).

% Lcm_coprime
tff(fact_5375_Lcm__fin__mult,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C),B2: C] :
          ( ( A4 != bot_bot(set(C)) )
         => ( aa(set(C),C,semiring_gcd_Lcm_fin(C),aa(set(C),set(C),image2(C,C,aa(C,fun(C,C),times_times(C),B2)),A4)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),aa(set(C),C,semiring_gcd_Lcm_fin(C),A4))) ) ) ) ).

% Lcm_fin_mult
tff(fact_5376_coprime__mult__right__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [C3: C,A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,C3,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2))
        <=> ( algebr8660921524188924756oprime(C,C3,A3)
            & algebr8660921524188924756oprime(C,C3,B2) ) ) ) ).

% coprime_mult_right_iff
tff(fact_5377_coprime__mult__left__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( algebr8660921524188924756oprime(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3)
        <=> ( algebr8660921524188924756oprime(C,A3,C3)
            & algebr8660921524188924756oprime(C,B2,C3) ) ) ) ).

% coprime_mult_left_iff
tff(fact_5378_coprime__self,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] :
          ( algebr8660921524188924756oprime(C,A3,A3)
        <=> dvd_dvd(C,A3,one_one(C)) ) ) ).

% coprime_self
tff(fact_5379_coprime__imp__gcd__eq__1,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,B2)
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) = one_one(C) ) ) ) ).

% coprime_imp_gcd_eq_1
tff(fact_5380_Lcm__fin_Oempty,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ( aa(set(C),C,semiring_gcd_Lcm_fin(C),bot_bot(set(C))) = one_one(C) ) ) ).

% Lcm_fin.empty
tff(fact_5381_is__unit__Lcm__fin__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          ( dvd_dvd(C,aa(set(C),C,semiring_gcd_Lcm_fin(C),A4),one_one(C))
        <=> ( aa(set(C),C,semiring_gcd_Lcm_fin(C),A4) = one_one(C) ) ) ) ).

% is_unit_Lcm_fin_iff
tff(fact_5382_coprime__0__right__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] :
          ( algebr8660921524188924756oprime(C,A3,zero_zero(C))
        <=> dvd_dvd(C,A3,one_one(C)) ) ) ).

% coprime_0_right_iff
tff(fact_5383_coprime__0__left__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] :
          ( algebr8660921524188924756oprime(C,zero_zero(C),A3)
        <=> dvd_dvd(C,A3,one_one(C)) ) ) ).

% coprime_0_left_iff
tff(fact_5384_coprime__mult__self__right__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,C3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
        <=> ( dvd_dvd(C,C3,one_one(C))
            & algebr8660921524188924756oprime(C,A3,B2) ) ) ) ).

% coprime_mult_self_right_iff
tff(fact_5385_coprime__mult__self__left__iff,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
        <=> ( dvd_dvd(C,C3,one_one(C))
            & algebr8660921524188924756oprime(C,A3,B2) ) ) ) ).

% coprime_mult_self_left_iff
tff(fact_5386_is__unit__gcd,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2),one_one(C))
        <=> algebr8660921524188924756oprime(C,A3,B2) ) ) ).

% is_unit_gcd
tff(fact_5387_mult__mod__cancel__right,axiom,
    ! [C: $tType] :
      ( ( euclid8851590272496341667cancel(C)
        & semiring_gcd(C) )
     => ! [A3: C,N: C,M2: C,B2: C] :
          ( ( modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),N),M2) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),B2),N),M2) )
         => ( algebr8660921524188924756oprime(C,M2,N)
           => ( modulo_modulo(C,A3,M2) = modulo_modulo(C,B2,M2) ) ) ) ) ).

% mult_mod_cancel_right
tff(fact_5388_mult__mod__cancel__left,axiom,
    ! [C: $tType] :
      ( ( euclid8851590272496341667cancel(C)
        & semiring_gcd(C) )
     => ! [N: C,A3: C,M2: C,B2: C] :
          ( ( modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),N),A3),M2) = modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),N),B2),M2) )
         => ( algebr8660921524188924756oprime(C,M2,N)
           => ( modulo_modulo(C,A3,M2) = modulo_modulo(C,B2,M2) ) ) ) ) ).

% mult_mod_cancel_left
tff(fact_5389_is__unit__right__imp__coprime,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [B2: C,A3: C] :
          ( dvd_dvd(C,B2,one_one(C))
         => algebr8660921524188924756oprime(C,A3,B2) ) ) ).

% is_unit_right_imp_coprime
tff(fact_5390_is__unit__left__imp__coprime,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => algebr8660921524188924756oprime(C,A3,B2) ) ) ).

% is_unit_left_imp_coprime
tff(fact_5391_coprime__common__divisor,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C,C3: C] :
          ( algebr8660921524188924756oprime(C,A3,B2)
         => ( dvd_dvd(C,C3,A3)
           => ( dvd_dvd(C,C3,B2)
             => dvd_dvd(C,C3,one_one(C)) ) ) ) ) ).

% coprime_common_divisor
tff(fact_5392_coprime__absorb__right,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [Y: C,X: C] :
          ( dvd_dvd(C,Y,X)
         => ( algebr8660921524188924756oprime(C,X,Y)
          <=> dvd_dvd(C,Y,one_one(C)) ) ) ) ).

% coprime_absorb_right
tff(fact_5393_coprime__imp__coprime,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,D3: C,A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,C3,D3)
         => ( ! [E: C] :
                ( ~ dvd_dvd(C,E,one_one(C))
               => ( dvd_dvd(C,E,A3)
                 => ( dvd_dvd(C,E,B2)
                   => dvd_dvd(C,E,C3) ) ) )
           => ( ! [E: C] :
                  ( ~ dvd_dvd(C,E,one_one(C))
                 => ( dvd_dvd(C,E,A3)
                   => ( dvd_dvd(C,E,B2)
                     => dvd_dvd(C,E,D3) ) ) )
             => algebr8660921524188924756oprime(C,A3,B2) ) ) ) ) ).

% coprime_imp_coprime
tff(fact_5394_coprime__absorb__left,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [X: C,Y: C] :
          ( dvd_dvd(C,X,Y)
         => ( algebr8660921524188924756oprime(C,X,Y)
          <=> dvd_dvd(C,X,one_one(C)) ) ) ) ).

% coprime_absorb_left
tff(fact_5395_not__coprimeI,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [C3: C,A3: C,B2: C] :
          ( dvd_dvd(C,C3,A3)
         => ( dvd_dvd(C,C3,B2)
           => ( ~ dvd_dvd(C,C3,one_one(C))
             => ~ algebr8660921524188924756oprime(C,A3,B2) ) ) ) ) ).

% not_coprimeI
tff(fact_5396_not__coprimeE,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( ~ algebr8660921524188924756oprime(C,A3,B2)
         => ~ ! [C2: C] :
                ( dvd_dvd(C,C2,A3)
               => ( dvd_dvd(C,C2,B2)
                 => dvd_dvd(C,C2,one_one(C)) ) ) ) ) ).

% not_coprimeE
tff(fact_5397_coprime__def,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,B2)
        <=> ! [C6: C] :
              ( dvd_dvd(C,C6,A3)
             => ( dvd_dvd(C,C6,B2)
               => dvd_dvd(C,C6,one_one(C)) ) ) ) ) ).

% coprime_def
tff(fact_5398_coprimeI,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C,B2: C] :
          ( ! [C2: C] :
              ( dvd_dvd(C,C2,A3)
             => ( dvd_dvd(C,C2,B2)
               => dvd_dvd(C,C2,one_one(C)) ) )
         => algebr8660921524188924756oprime(C,A3,B2) ) ) ).

% coprimeI
tff(fact_5399_coprime__1__left,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] : algebr8660921524188924756oprime(C,one_one(C),A3) ) ).

% coprime_1_left
tff(fact_5400_coprime__1__right,axiom,
    ! [C: $tType] :
      ( algebraic_semidom(C)
     => ! [A3: C] : algebr8660921524188924756oprime(C,A3,one_one(C)) ) ).

% coprime_1_right
tff(fact_5401_coprime__doff__one__right,axiom,
    ! [C: $tType] :
      ( ring_gcd(C)
     => ! [A3: C] : algebr8660921524188924756oprime(C,A3,minus_minus(C,A3,one_one(C))) ) ).

% coprime_doff_one_right
tff(fact_5402_coprime__diff__one__left,axiom,
    ! [C: $tType] :
      ( ring_gcd(C)
     => ! [A3: C] : algebr8660921524188924756oprime(C,minus_minus(C,A3,one_one(C)),A3) ) ).

% coprime_diff_one_left
tff(fact_5403_coprime__add__one__right,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C] : algebr8660921524188924756oprime(C,A3,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C))) ) ).

% coprime_add_one_right
tff(fact_5404_coprime__add__one__left,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C] : algebr8660921524188924756oprime(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),one_one(C)),A3) ) ).

% coprime_add_one_left
tff(fact_5405_coprime__dvd__mult__right__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,C3)
         => ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))
          <=> dvd_dvd(C,A3,B2) ) ) ) ).

% coprime_dvd_mult_right_iff
tff(fact_5406_coprime__dvd__mult__left__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,C3)
         => ( dvd_dvd(C,A3,aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))
          <=> dvd_dvd(C,A3,B2) ) ) ) ).

% coprime_dvd_mult_left_iff
tff(fact_5407_divides__mult,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] :
          ( dvd_dvd(C,A3,C3)
         => ( dvd_dvd(C,B2,C3)
           => ( algebr8660921524188924756oprime(C,A3,B2)
             => dvd_dvd(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) ) ) ) ) ).

% divides_mult
tff(fact_5408_gcd__mult__left__left__cancel,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [B2: C,C3: C,A3: C] :
          ( algebr8660921524188924756oprime(C,B2,C3)
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),B2) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) ) ) ) ).

% gcd_mult_left_left_cancel
tff(fact_5409_gcd__mult__left__right__cancel,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [B2: C,C3: C,A3: C] :
          ( algebr8660921524188924756oprime(C,B2,C3)
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),B2) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) ) ) ) ).

% gcd_mult_left_right_cancel
tff(fact_5410_gcd__mult__right__left__cancel,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,C3)
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) ) ) ) ).

% gcd_mult_right_left_cancel
tff(fact_5411_gcd__mult__right__right__cancel,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,C3)
         => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) ) ) ) ).

% gcd_mult_right_right_cancel
tff(fact_5412_gcd__eq__1__imp__coprime,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) = one_one(C) )
         => algebr8660921524188924756oprime(C,A3,B2) ) ) ).

% gcd_eq_1_imp_coprime
tff(fact_5413_coprime__iff__gcd__eq__1,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,B2)
        <=> ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) = one_one(C) ) ) ) ).

% coprime_iff_gcd_eq_1
tff(fact_5414_coprime__crossproduct,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,D3: C,B2: C,C3: C] :
          ( algebr8660921524188924756oprime(C,A3,D3)
         => ( algebr8660921524188924756oprime(C,B2,C3)
           => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),A3)),aa(C,C,normal6383669964737779283malize(C),C3)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),B2)),aa(C,C,normal6383669964737779283malize(C),D3)) )
            <=> ( ( aa(C,C,normal6383669964737779283malize(C),A3) = aa(C,C,normal6383669964737779283malize(C),B2) )
                & ( aa(C,C,normal6383669964737779283malize(C),C3) = aa(C,C,normal6383669964737779283malize(C),D3) ) ) ) ) ) ) ).

% coprime_crossproduct
tff(fact_5415_invertible__coprime,axiom,
    ! [C: $tType] :
      ( euclid8851590272496341667cancel(C)
     => ! [A3: C,B2: C,C3: C] :
          ( ( modulo_modulo(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),C3) = one_one(C) )
         => algebr8660921524188924756oprime(C,A3,C3) ) ) ).

% invertible_coprime
tff(fact_5416_gcd__coprime,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,A10: C,B8: C] :
          ( ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) != zero_zero(C) )
         => ( ( A3 = aa(C,C,aa(C,fun(C,C),times_times(C),A10),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) )
           => ( ( B2 = aa(C,C,aa(C,fun(C,C),times_times(C),B8),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) )
             => algebr8660921524188924756oprime(C,A10,B8) ) ) ) ) ).

% gcd_coprime
tff(fact_5417_gcd__coprime__exists,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) != zero_zero(C) )
         => ? [A16: C,B10: C] :
              ( ( A3 = aa(C,C,aa(C,fun(C,C),times_times(C),A16),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) )
              & ( B2 = aa(C,C,aa(C,fun(C,C),times_times(C),B10),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) )
              & algebr8660921524188924756oprime(C,A16,B10) ) ) ) ).

% gcd_coprime_exists
tff(fact_5418_coprime__crossproduct_H,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [B2: C,D3: C,A3: C,C3: C] :
          ( ( B2 != zero_zero(C) )
         => ( ( unit_f5069060285200089521factor(C,B2) = unit_f5069060285200089521factor(C,D3) )
           => ( algebr8660921524188924756oprime(C,A3,B2)
             => ( algebr8660921524188924756oprime(C,C3,D3)
               => ( ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),D3) = aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3) )
                <=> ( ( A3 = C3 )
                    & ( B2 = D3 ) ) ) ) ) ) ) ) ).

% coprime_crossproduct'
tff(fact_5419_Lcm__fin__1__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          ( ( aa(set(C),C,semiring_gcd_Lcm_fin(C),A4) = one_one(C) )
        <=> ( ! [X4: C] :
                ( member2(C,X4,A4)
               => dvd_dvd(C,X4,one_one(C)) )
            & aa(set(C),$o,finite_finite2(C),A4) ) ) ) ).

% Lcm_fin_1_iff
tff(fact_5420_Lcm__fin_Oeq__fold,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A4: set(C)] :
          aa(set(C),C,semiring_gcd_Lcm_fin(C),A4) = $ite(aa(set(C),$o,finite_finite2(C),A4),finite_fold(C,C,gcd_lcm(C),one_one(C),A4),zero_zero(C)) ) ).

% Lcm_fin.eq_fold
tff(fact_5421_gcd__lcm,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( ( A3 != zero_zero(C) )
         => ( ( B2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2) = aa(C,C,normal6383669964737779283malize(C),divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2))) ) ) ) ) ).

% gcd_lcm
tff(fact_5422_Lcm__fin__def,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ( semiring_gcd_Lcm_fin(C) = bounde2362111253966948842tice_F(C,gcd_lcm(C),one_one(C),zero_zero(C)) ) ) ).

% Lcm_fin_def
tff(fact_5423_lcm__eq__1__iff,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( ( aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2) = one_one(C) )
        <=> ( dvd_dvd(C,A3,one_one(C))
            & dvd_dvd(C,B2,one_one(C)) ) ) ) ).

% lcm_eq_1_iff
tff(fact_5424_lcm_Otop__left__normalize,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),gcd_lcm(C),one_one(C)),A3) = aa(C,C,normal6383669964737779283malize(C),A3) ) ).

% lcm.top_left_normalize
tff(fact_5425_lcm_Otop__right__normalize,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C] : aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),one_one(C)) = aa(C,C,normal6383669964737779283malize(C),A3) ) ).

% lcm.top_right_normalize
tff(fact_5426_unit__factor__lcm,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          unit_f5069060285200089521factor(C,aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)) = $ite(
            ( ( A3 = zero_zero(C) )
            | ( B2 = zero_zero(C) ) ),
            zero_zero(C),
            one_one(C) ) ) ).

% unit_factor_lcm
tff(fact_5427_gcd__mult__lcm,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),A3)),aa(C,C,normal6383669964737779283malize(C),B2)) ) ).

% gcd_mult_lcm
tff(fact_5428_lcm__mult__gcd,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),A3)),aa(C,C,normal6383669964737779283malize(C),B2)) ) ).

% lcm_mult_gcd
tff(fact_5429_Lcm__2,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [A3: C,B2: C] : gcd_Lcm(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),B2),bot_bot(set(C))))) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2) ) ).

% Lcm_2
tff(fact_5430_lcm__mult__left,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2))) ) ).

% lcm_mult_left
tff(fact_5431_lcm__mult__right,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,C3: C,B2: C] : aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),A3)),C3)) ) ).

% lcm_mult_right
tff(fact_5432_lcm__mult__distrib_H,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,normal6383669964737779283malize(C),C3)),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2)) ) ).

% lcm_mult_distrib'
tff(fact_5433_lcm__mult__distrib,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [K: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),K),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),K),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),K),B2))),unit_f5069060285200089521factor(C,K)) ) ).

% lcm_mult_distrib
tff(fact_5434_mult__lcm__right,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [A3: C,B2: C,C3: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C3)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C3))),unit_f5069060285200089521factor(C,C3)) ) ).

% mult_lcm_right
tff(fact_5435_mult__lcm__left,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [C3: C,A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),C3),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),unit_f5069060285200089521factor(C,C3)),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)),aa(C,C,aa(C,fun(C,C),times_times(C),C3),B2))) ) ).

% mult_lcm_left
tff(fact_5436_lcm__mult__unit1,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_lcm(C),aa(C,C,aa(C,fun(C,C),times_times(C),B2),A3)),C3) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),C3) ) ) ) ).

% lcm_mult_unit1
tff(fact_5437_lcm__mult__unit2,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),aa(C,C,aa(C,fun(C,C),times_times(C),C3),A3)) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),C3) ) ) ) ).

% lcm_mult_unit2
tff(fact_5438_lcm__div__unit1,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_lcm(C),divide_divide(C,B2,A3)),C3) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),C3) ) ) ) ).

% lcm_div_unit1
tff(fact_5439_lcm__div__unit2,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C,C3: C] :
          ( dvd_dvd(C,A3,one_one(C))
         => ( aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),divide_divide(C,C3,A3)) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),B2),C3) ) ) ) ).

% lcm_div_unit2
tff(fact_5440_lcm__gcd__prod,axiom,
    ! [C: $tType] :
      ( semiri6843258321239162965malize(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2)),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2)) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ).

% lcm_gcd_prod
tff(fact_5441_lcm__coprime,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] :
          ( algebr8660921524188924756oprime(C,A3,B2)
         => ( aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2) = aa(C,C,normal6383669964737779283malize(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2)) ) ) ) ).

% lcm_coprime
tff(fact_5442_lcm__gcd,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,B2: C] : aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),B2) = aa(C,C,normal6383669964737779283malize(C),divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),A3),B2),aa(C,C,aa(C,fun(C,C),gcd_gcd(C),A3),B2))) ) ).

% lcm_gcd
tff(fact_5443_Lcm__fin_Oremove,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,A4: set(C)] :
          ( member2(C,A3,A4)
         => ( aa(set(C),C,semiring_gcd_Lcm_fin(C),A4) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),aa(set(C),C,semiring_gcd_Lcm_fin(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ) ) ).

% Lcm_fin.remove
tff(fact_5444_Lcm__fin_Oinsert__remove,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [A3: C,A4: set(C)] : aa(set(C),C,semiring_gcd_Lcm_fin(C),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),A4)) = aa(C,C,aa(C,fun(C,C),gcd_lcm(C),A3),aa(set(C),C,semiring_gcd_Lcm_fin(C),minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A3),bot_bot(set(C)))))) ) ).

% Lcm_fin.insert_remove
tff(fact_5445_Lcm__set__eq__fold,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [Xs: list(C)] : gcd_Lcm(C,aa(list(C),set(C),set2(C),Xs)) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),gcd_lcm(C)),Xs),one_one(C)) ) ).

% Lcm_set_eq_fold
tff(fact_5446_lcm_Obounded__quasi__semilattice__axioms,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => bounde8507323023520639062attice(C,gcd_lcm(C),one_one(C),zero_zero(C),normal6383669964737779283malize(C)) ) ).

% lcm.bounded_quasi_semilattice_axioms
tff(fact_5447_Lcm__fin_Oset__eq__fold,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => ! [Xs: list(C)] : aa(set(C),C,semiring_gcd_Lcm_fin(C),aa(list(C),set(C),set2(C),Xs)) = aa(C,C,aa(list(C),fun(C,C),aa(fun(C,fun(C,C)),fun(list(C),fun(C,C)),fold(C,C),gcd_lcm(C)),Xs),one_one(C)) ) ).

% Lcm_fin.set_eq_fold
tff(fact_5448_Lcm__fin_Obounded__quasi__semilattice__set__axioms,axiom,
    ! [C: $tType] :
      ( semiring_gcd(C)
     => bounde6485984586167503788ce_set(C,gcd_lcm(C),one_one(C),zero_zero(C),normal6383669964737779283malize(C)) ) ).

% Lcm_fin.bounded_quasi_semilattice_set_axioms
tff(fact_5449_acyclic__insert__cyclic,axiom,
    ! [C: $tType,G: set(product_prod(C,C)),X: C,Y: C] :
      ( transitive_acyclic(C,G)
     => ( ~ transitive_acyclic(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(product_prod(C,C),fun(set(product_prod(C,C)),set(product_prod(C,C))),insert2(product_prod(C,C)),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X),Y)),G))
       => member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y),X),aa(set(product_prod(C,C)),set(product_prod(C,C)),transitive_rtrancl(C),G)) ) ) ).

% acyclic_insert_cyclic
tff(fact_5450_FI__RESULT__def,axiom,
    ! [M: list(product_prod(assn,assn)),UP: assn,UQ: assn,F2: assn] :
      ( fI_RESULT(M,UP,UQ,F2)
    <=> ( ! [X4: product_prod(assn,assn)] :
            ( member2(product_prod(assn,assn),X4,aa(list(product_prod(assn,assn)),set(product_prod(assn,assn)),set2(product_prod(assn,assn)),M))
           => aa(product_prod(assn,assn),$o,product_case_prod(assn,assn,$o,entails),X4) )
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(list(assn),fun(assn,assn),aa(fun(assn,fun(assn,assn)),fun(list(assn),fun(assn,assn)),foldr(assn,assn),times_times(assn)),aa(list(product_prod(assn,assn)),list(assn),aa(fun(product_prod(assn,assn),assn),fun(list(product_prod(assn,assn)),list(assn)),map(product_prod(assn,assn),assn),product_fst(assn,assn)),M)),one_one(assn))),UP)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(list(assn),fun(assn,assn),aa(fun(assn,fun(assn,assn)),fun(list(assn),fun(assn,assn)),foldr(assn,assn),times_times(assn)),aa(list(product_prod(assn,assn)),list(assn),aa(fun(product_prod(assn,assn),assn),fun(list(product_prod(assn,assn)),list(assn)),map(product_prod(assn,assn),assn),product_snd(assn,assn)),M)),one_one(assn))),UQ)),F2)) ) ) ).

% FI_RESULT_def
tff(fact_5451_listsp__mono,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o)] :
      ( aa(fun(C,$o),$o,aa(fun(C,$o),fun(fun(C,$o),$o),ord_less_eq(fun(C,$o)),A4),B3)
     => aa(fun(list(C),$o),$o,aa(fun(list(C),$o),fun(fun(list(C),$o),$o),ord_less_eq(fun(list(C),$o)),listsp(C,A4)),listsp(C,B3)) ) ).

% listsp_mono
tff(fact_5452_listsp__conj__eq,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o),X3: list(C)] :
      ( aa(list(C),$o,listsp(C,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bu(fun(C,$o),fun(fun(C,$o),fun(C,$o)),A4),B3)),X3)
    <=> ( aa(list(C),$o,listsp(C,A4),X3)
        & aa(list(C),$o,listsp(C,B3),X3) ) ) ).

% listsp_conj_eq
tff(fact_5453_listsp__simps_I1_J,axiom,
    ! [C: $tType,A4: fun(C,$o)] : aa(list(C),$o,listsp(C,A4),nil(C)) ).

% listsp_simps(1)
tff(fact_5454_in__listspI,axiom,
    ! [C: $tType,Xs: list(C),A4: fun(C,$o)] :
      ( ! [X2: C] :
          ( member2(C,X2,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,A4,X2) )
     => aa(list(C),$o,listsp(C,A4),Xs) ) ).

% in_listspI
tff(fact_5455_append__in__listsp__conv,axiom,
    ! [C: $tType,A4: fun(C,$o),Xs: list(C),Ys: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xs),Ys))
    <=> ( aa(list(C),$o,listsp(C,A4),Xs)
        & aa(list(C),$o,listsp(C,A4),Ys) ) ) ).

% append_in_listsp_conv
tff(fact_5456_acyclic__empty,axiom,
    ! [C: $tType] : transitive_acyclic(C,bot_bot(set(product_prod(C,C)))) ).

% acyclic_empty
tff(fact_5457_listsp__inf__eq,axiom,
    ! [C: $tType,A4: fun(C,$o),B3: fun(C,$o)] : listsp(C,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),A4),B3)) = aa(fun(list(C),$o),fun(list(C),$o),aa(fun(list(C),$o),fun(fun(list(C),$o),fun(list(C),$o)),inf_inf(fun(list(C),$o)),listsp(C,A4)),listsp(C,B3)) ).

% listsp_inf_eq
tff(fact_5458_ent__pure__pre__iff,axiom,
    ! [Pa: assn,B2: $o,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),pure_assn((B2)))),Q)
    <=> ( (B2)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q) ) ) ).

% ent_pure_pre_iff
tff(fact_5459_ent__pure__pre__iff__sng,axiom,
    ! [B2: $o,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,pure_assn((B2))),Q)
    <=> ( (B2)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,one_one(assn)),Q) ) ) ).

% ent_pure_pre_iff_sng
tff(fact_5460_cyclic__subset,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),S: set(product_prod(C,C))] :
      ( ~ transitive_acyclic(C,R)
     => ( aa(set(product_prod(C,C)),$o,aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),$o),ord_less_eq(set(product_prod(C,C))),R),S)
       => ~ transitive_acyclic(C,S) ) ) ).

% cyclic_subset
tff(fact_5461_lists__def,axiom,
    ! [C: $tType,X3: set(C)] : aa(set(C),set(list(C)),lists(C),X3) = collect(list(C),listsp(C,aTP_Lamp_a(set(C),fun(C,$o),X3))) ).

% lists_def
tff(fact_5462_listsp__lists__eq,axiom,
    ! [C: $tType,A4: set(C),X3: list(C)] :
      ( aa(list(C),$o,listsp(C,aTP_Lamp_a(set(C),fun(C,$o),A4)),X3)
    <=> member2(list(C),X3,aa(set(C),set(list(C)),lists(C),A4)) ) ).

% listsp_lists_eq
tff(fact_5463_listsp__infI,axiom,
    ! [C: $tType,A4: fun(C,$o),La: list(C),B3: fun(C,$o)] :
      ( aa(list(C),$o,listsp(C,A4),La)
     => ( aa(list(C),$o,listsp(C,B3),La)
       => aa(list(C),$o,listsp(C,aa(fun(C,$o),fun(C,$o),aa(fun(C,$o),fun(fun(C,$o),fun(C,$o)),inf_inf(fun(C,$o)),A4),B3)),La) ) ) ).

% listsp_infI
tff(fact_5464_ent__conjI,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),B3)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),C4)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),B3),C4)) ) ) ).

% ent_conjI
tff(fact_5465_ent__conjE1,axiom,
    ! [A4: assn,C4: assn,B3: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),C4)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),A4),B3)),C4) ) ).

% ent_conjE1
tff(fact_5466_ent__conjE2,axiom,
    ! [B3: assn,C4: assn,A4: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,B3),C4)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),A4),B3)),C4) ) ).

% ent_conjE2
tff(fact_5467_in__listsp__conv__set,axiom,
    ! [C: $tType,A4: fun(C,$o),Xs: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),Xs)
    <=> ! [X4: C] :
          ( member2(C,X4,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,A4,X4) ) ) ).

% in_listsp_conv_set
tff(fact_5468_in__listspD,axiom,
    ! [C: $tType,A4: fun(C,$o),Xs: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),Xs)
     => ! [X3: C] :
          ( member2(C,X3,aa(list(C),set(C),set2(C),Xs))
         => aa(C,$o,A4,X3) ) ) ).

% in_listspD
tff(fact_5469_listspE,axiom,
    ! [C: $tType,A4: fun(C,$o),X: C,La: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),La))
     => ~ ( aa(C,$o,A4,X)
         => ~ aa(list(C),$o,listsp(C,A4),La) ) ) ).

% listspE
tff(fact_5470_listsp_OCons,axiom,
    ! [C: $tType,A4: fun(C,$o),A3: C,La: list(C)] :
      ( aa(C,$o,A4,A3)
     => ( aa(list(C),$o,listsp(C,A4),La)
       => aa(list(C),$o,listsp(C,A4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),La)) ) ) ).

% listsp.Cons
tff(fact_5471_listsp__simps_I2_J,axiom,
    ! [C: $tType,A4: fun(C,$o),X: C,Xs: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs))
    <=> ( aa(C,$o,A4,X)
        & aa(list(C),$o,listsp(C,A4),Xs) ) ) ).

% listsp_simps(2)
tff(fact_5472_listsp_ONil,axiom,
    ! [C: $tType,A4: fun(C,$o)] : aa(list(C),$o,listsp(C,A4),nil(C)) ).

% listsp.Nil
tff(fact_5473_ent__trans,axiom,
    ! [Pa: assn,Q: assn,R: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Q),R)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),R) ) ) ).

% ent_trans
tff(fact_5474_ent__refl,axiom,
    ! [Pa: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Pa) ).

% ent_refl
tff(fact_5475_ent__iffI,axiom,
    ! [A4: assn,B3: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),B3)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,B3),A4)
       => ( A4 = B3 ) ) ) ).

% ent_iffI
tff(fact_5476_is__entails,axiom,
    ! [Pa: assn,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q) ) ).

% is_entails
tff(fact_5477_ent__star__mono,axiom,
    ! [Pa: assn,P5: assn,Q: assn,Q5: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),P5)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Q),Q5)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),Q)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),P5),Q5)) ) ) ).

% ent_star_mono
tff(fact_5478_ent__frame__fwd,axiom,
    ! [Pa: assn,R: assn,Ps3: assn,F2: assn,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),R)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Ps3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),F2))
       => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),R),F2)),Q)
         => aa(assn,$o,aa(assn,fun(assn,$o),entails,Ps3),Q) ) ) ) ).

% ent_frame_fwd
tff(fact_5479_fr__rot__rhs,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),C4))
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),C4),B3)) ) ).

% fr_rot_rhs
tff(fact_5480_fr__refl,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),B3)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),C4)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),C4)) ) ).

% fr_refl
tff(fact_5481_fr__rot,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),B3)),C4)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),A4)),C4) ) ).

% fr_rot
tff(fact_5482_ent__true,axiom,
    ! [Pa: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),top_top(assn)) ).

% ent_true
tff(fact_5483_acyclic__union_I1_J,axiom,
    ! [C: $tType,A4: set(product_prod(C,C)),B3: set(product_prod(C,C))] :
      ( transitive_acyclic(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),A4),B3))
     => transitive_acyclic(C,A4) ) ).

% acyclic_union(1)
tff(fact_5484_acyclic__union_I2_J,axiom,
    ! [C: $tType,A4: set(product_prod(C,C)),B3: set(product_prod(C,C))] :
      ( transitive_acyclic(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),sup_sup(set(product_prod(C,C))),A4),B3))
     => transitive_acyclic(C,B3) ) ).

% acyclic_union(2)
tff(fact_5485_ent__disjI2__direct,axiom,
    ! [B3: assn,A4: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,B3),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)) ).

% ent_disjI2_direct
tff(fact_5486_ent__disjI1__direct,axiom,
    ! [A4: assn,B3: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)) ).

% ent_disjI1_direct
tff(fact_5487_ent__disjI2_H,axiom,
    ! [A4: assn,C4: assn,B3: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),C4)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),B3),C4)) ) ).

% ent_disjI2'
tff(fact_5488_ent__disjI1_H,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),B3)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),B3),C4)) ) ).

% ent_disjI1'
tff(fact_5489_ent__disjI2,axiom,
    ! [Pa: assn,Q: assn,R: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Pa),Q)),R)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Q),R) ) ).

% ent_disjI2
tff(fact_5490_ent__disjI1,axiom,
    ! [Pa: assn,Q: assn,R: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Pa),Q)),R)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),R) ) ).

% ent_disjI1
tff(fact_5491_ent__disjE,axiom,
    ! [A4: assn,C4: assn,B3: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),C4)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,B3),C4)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)),C4) ) ) ).

% ent_disjE
tff(fact_5492_ent__false,axiom,
    ! [Pa: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,bot_bot(assn)),Pa) ).

% ent_false
tff(fact_5493_ent__star__mono__true,axiom,
    ! [A4: assn,A12: assn,B3: assn,B15: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A12),top_top(assn)))
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,B3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B15),top_top(assn)))
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),B3)),top_top(assn))),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A12),B15)),top_top(assn))) ) ) ).

% ent_star_mono_true
tff(fact_5494_ent__refl__true,axiom,
    ! [A4: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),top_top(assn))) ).

% ent_refl_true
tff(fact_5495_ent__true__drop_I1_J,axiom,
    ! [Pa: assn,Q: assn,R: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),top_top(assn)))
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),R)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),top_top(assn))) ) ).

% ent_true_drop(1)
tff(fact_5496_ent__true__drop_I2_J,axiom,
    ! [Pa: assn,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),top_top(assn))) ) ).

% ent_true_drop(2)
tff(fact_5497_listsp_Ocases,axiom,
    ! [C: $tType,A4: fun(C,$o),A3: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),A3)
     => ( ( A3 != nil(C) )
       => ~ ! [A5: C,L: list(C)] :
              ( ( A3 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),L) )
             => ( aa(C,$o,A4,A5)
               => ~ aa(list(C),$o,listsp(C,A4),L) ) ) ) ) ).

% listsp.cases
tff(fact_5498_listsp_Osimps,axiom,
    ! [C: $tType,A4: fun(C,$o),A3: list(C)] :
      ( aa(list(C),$o,listsp(C,A4),A3)
    <=> ( ( A3 = nil(C) )
        | ? [A6: C,L3: list(C)] :
            ( ( A3 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A6),L3) )
            & aa(C,$o,A4,A6)
            & aa(list(C),$o,listsp(C,A4),L3) ) ) ) ).

% listsp.simps
tff(fact_5499_fi__match__entails,axiom,
    ! [M2: list(product_prod(assn,assn))] :
      ( ! [X2: product_prod(assn,assn)] :
          ( member2(product_prod(assn,assn),X2,aa(list(product_prod(assn,assn)),set(product_prod(assn,assn)),set2(product_prod(assn,assn)),M2))
         => aa(product_prod(assn,assn),$o,product_case_prod(assn,assn,$o,entails),X2) )
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(list(assn),fun(assn,assn),aa(fun(assn,fun(assn,assn)),fun(list(assn),fun(assn,assn)),foldr(assn,assn),times_times(assn)),aa(list(product_prod(assn,assn)),list(assn),aa(fun(product_prod(assn,assn),assn),fun(list(product_prod(assn,assn)),list(assn)),map(product_prod(assn,assn),assn),product_fst(assn,assn)),M2)),one_one(assn))),aa(assn,assn,aa(list(assn),fun(assn,assn),aa(fun(assn,fun(assn,assn)),fun(list(assn),fun(assn,assn)),foldr(assn,assn),times_times(assn)),aa(list(product_prod(assn,assn)),list(assn),aa(fun(product_prod(assn,assn),assn),fun(list(product_prod(assn,assn)),list(assn)),map(product_prod(assn,assn),assn),product_snd(assn,assn)),M2)),one_one(assn))) ) ).

% fi_match_entails
tff(fact_5500_FI__QUERY__def,axiom,
    ! [Pa: assn,Q: assn,F2: assn] :
      ( fI_QUERY(Pa,Q,F2)
    <=> aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),F2)) ) ).

% FI_QUERY_def
tff(fact_5501_frame__inference__init,axiom,
    ! [Pa: assn,Q: assn,F2: assn] :
      ( fI_QUERY(Pa,Q,F2)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),F2)) ) ).

% frame_inference_init
tff(fact_5502_cyclicE,axiom,
    ! [C: $tType,G: set(product_prod(C,C))] :
      ( ~ transitive_acyclic(C,G)
     => ~ ! [X2: C] : ~ member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X2),X2),transitive_trancl(C,G)) ) ).

% cyclicE
tff(fact_5503_entails__solve__init_I2_J,axiom,
    ! [Pa: assn,Q: assn] :
      ( fI_QUERY(Pa,Q,one_one(assn))
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q) ) ).

% entails_solve_init(2)
tff(fact_5504_wf__set,axiom,
    ! [C: $tType,Xs: list(product_prod(C,C))] :
      ( wf(C,aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),Xs))
    <=> transitive_acyclic(C,aa(list(product_prod(C,C)),set(product_prod(C,C)),set2(product_prod(C,C)),Xs)) ) ).

% wf_set
tff(fact_5505_entails__solve__init_I1_J,axiom,
    ! [Pa: assn,Q: assn] :
      ( fI_QUERY(Pa,Q,top_top(assn))
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),top_top(assn))) ) ).

% entails_solve_init(1)
tff(fact_5506_FI__match,axiom,
    ! [P3: assn,Q2: assn,M2: list(product_prod(assn,assn)),Ps: assn,Up: assn,Qs: assn,Uq: assn,F: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,P3),Q2)
     => ( fi(aa(list(product_prod(assn,assn)),list(product_prod(assn,assn)),aa(product_prod(assn,assn),fun(list(product_prod(assn,assn)),list(product_prod(assn,assn))),cons(product_prod(assn,assn)),aa(assn,product_prod(assn,assn),aa(assn,fun(assn,product_prod(assn,assn)),product_Pair(assn,assn),P3),Q2)),M2),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Ps),Up),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Qs),Uq),sln,sln,F)
       => fi(M2,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Ps),P3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Qs),Q2),Up,Uq,F) ) ) ).

% FI_match
tff(fact_5507_FI__def,axiom,
    ! [M2: list(product_prod(assn,assn)),P3: assn,Q2: assn,Up: assn,Uq: assn,F: assn] :
      ( fi(M2,P3,Q2,Up,Uq,F)
    <=> ( ! [X4: product_prod(assn,assn)] :
            ( member2(product_prod(assn,assn),X4,aa(list(product_prod(assn,assn)),set(product_prod(assn,assn)),set2(product_prod(assn,assn)),M2))
           => aa(product_prod(assn,assn),$o,product_case_prod(assn,assn,$o,entails),X4) )
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(list(assn),fun(assn,assn),aa(fun(assn,fun(assn,assn)),fun(list(assn),fun(assn,assn)),foldr(assn,assn),times_times(assn)),aa(list(product_prod(assn,assn)),list(assn),aa(fun(product_prod(assn,assn),assn),fun(list(product_prod(assn,assn)),list(assn)),map(product_prod(assn,assn),assn),product_fst(assn,assn)),M2)),one_one(assn))),P3)),Up)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(assn,assn,aa(list(assn),fun(assn,assn),aa(fun(assn,fun(assn,assn)),fun(list(assn),fun(assn,assn)),foldr(assn,assn),times_times(assn)),aa(list(product_prod(assn,assn)),list(assn),aa(fun(product_prod(assn,assn),assn),fun(list(product_prod(assn,assn)),list(assn)),map(product_prod(assn,assn),assn),product_snd(assn,assn)),M2)),one_one(assn))),Q2)),Uq)),F)) ) ) ).

% FI_def
tff(fact_5508_ent__wand__frameI,axiom,
    ! [Q: assn,R: assn,F2: assn,S: assn,Pa: assn,X5: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),wand_assn(Q,R)),F2)),S)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),F2),X5))
       => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),X5)),R)
         => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),S) ) ) ) ).

% ent_wand_frameI
tff(fact_5509_ent__wandI,axiom,
    ! [Q: assn,Pa: assn,R: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),Pa)),R)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),wand_assn(Q,R)) ) ).

% ent_wandI
tff(fact_5510_ent__mp,axiom,
    ! [Pa: assn,Q: assn] : aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),wand_assn(Pa,Q))),Q) ).

% ent_mp
tff(fact_5511_prec__frame,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,fun(D,assn)),R12: assn,R22: assn,H: product_prod(heap_ext(product_unit),set(nat)),X: C,P3: D,F12: assn,Y: C,F23: assn] :
      ( precise(C,D,Pa)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),R12),R22)),H)
       => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,R12),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),Pa,X),P3)),F12))
         => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,R22),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),Pa,Y),P3)),F23))
           => ( X = Y ) ) ) ) ) ).

% prec_frame
tff(fact_5512_prod_H__def,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ( groups1962203154675924110t_prod(C,D) = groups_comm_monoid_G(D,C,times_times(D),one_one(D)) ) ) ).

% prod'_def
tff(fact_5513_prod_Ocomm__monoid__list__set__axioms,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => groups4802862169904069756st_set(C,times_times(C),one_one(C)) ) ).

% prod.comm_monoid_list_set_axioms
tff(fact_5514_Rep__assn__inject,axiom,
    ! [X: assn,Y: assn] :
      ( ( aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,X) = aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Y) )
    <=> ( X = Y ) ) ).

% Rep_assn_inject
tff(fact_5515_mod__or__dist,axiom,
    ! [Pa: assn,Q: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Pa),Q)),H)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
        | aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),H) ) ) ).

% mod_or_dist
tff(fact_5516_mod__h__bot__iff_I5_J,axiom,
    ! [Pa: assn,Q: assn,H: heap_ext(product_unit)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),Q)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_iff(5)
tff(fact_5517_mod__pure__star__dist,axiom,
    ! [Pa: assn,B2: $o,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),pure_assn((B2)))),H)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
        & (B2) ) ) ).

% mod_pure_star_dist
tff(fact_5518_mod__h__bot__normalize,axiom,
    ! [C: $tType,H: heap_ext(product_unit),Pa: assn] :
      ( syntax7388354845996824322omatch(C,heap_ext(product_unit),undefined(C),H)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
      <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),undefined(heap_ext(product_unit))),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_normalize
tff(fact_5519_mod__h__bot__iff_I7_J,axiom,
    ! [Pa: assn,Q: assn,H: heap_ext(product_unit)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Pa),Q)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
        | aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_iff(7)
tff(fact_5520_mod__h__bot__iff_I6_J,axiom,
    ! [Pa: assn,Q: assn,H: heap_ext(product_unit)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),Q)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_iff(6)
tff(fact_5521_mod__pure,axiom,
    ! [B2: $o,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,pure_assn((B2))),H)
    <=> ( ( aa(product_prod(heap_ext(product_unit),set(nat)),set(nat),product_snd(heap_ext(product_unit),set(nat)),H) = bot_bot(set(nat)) )
        & (B2) ) ) ).

% mod_pure
tff(fact_5522_mod__h__bot__iff_I1_J,axiom,
    ! [B2: $o,H: heap_ext(product_unit)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,pure_assn((B2))),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
    <=> (B2) ) ).

% mod_h_bot_iff(1)
tff(fact_5523_ent__false__iff,axiom,
    ! [Pa: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),bot_bot(assn))
    <=> ! [H3: product_prod(heap_ext(product_unit),set(nat))] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H3) ) ).

% ent_false_iff
tff(fact_5524_mod__h__bot__iff_I4_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Q2: array(C),Y: list(C),H: heap_ext(product_unit)] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,snga_assn(C,Q2,Y)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ) ).

% mod_h_bot_iff(4)
tff(fact_5525_mod__h__bot__iff_I3_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [P3: ref(C),X: C,H: heap_ext(product_unit)] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,sngr_assn(C,P3,X)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ) ).

% mod_h_bot_iff(3)
tff(fact_5526_ent__pure__post__iff,axiom,
    ! [Pa: assn,Q: assn,B2: $o] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),pure_assn((B2))))
    <=> ( ! [H3: product_prod(heap_ext(product_unit),set(nat))] :
            ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H3)
           => (B2) )
        & aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q) ) ) ).

% ent_pure_post_iff
tff(fact_5527_ent__pure__post__iff__sng,axiom,
    ! [Pa: assn,B2: $o] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),pure_assn((B2)))
    <=> ( ! [H3: product_prod(heap_ext(product_unit),set(nat))] :
            ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H3)
           => (B2) )
        & aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),one_one(assn)) ) ) ).

% ent_pure_post_iff_sng
tff(fact_5528_mod__h__bot__indep,axiom,
    ! [Pa: assn,H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
    <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),bot_bot(set(nat)))) ) ).

% mod_h_bot_indep
tff(fact_5529_mod__and__dist,axiom,
    ! [Pa: assn,Q: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),Q)),H)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),H) ) ) ).

% mod_and_dist
tff(fact_5530_mod__starD,axiom,
    ! [A4: assn,B3: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),B3)),H)
     => ? [H1: product_prod(heap_ext(product_unit),set(nat)),H22: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,A4),H1)
          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,B3),H22) ) ) ).

% mod_starD
tff(fact_5531_mod__starE,axiom,
    ! [A3: assn,B2: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A3),B2)),H)
     => ~ ( ? [X_1: product_prod(heap_ext(product_unit),set(nat))] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,A3),X_1)
         => ! [H_2: product_prod(heap_ext(product_unit),set(nat))] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,B2),H_2) ) ) ).

% mod_starE
tff(fact_5532_mod__false,axiom,
    ! [H: product_prod(heap_ext(product_unit),set(nat))] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,bot_bot(assn)),H) ).

% mod_false
tff(fact_5533_ent__fwd,axiom,
    ! [Pa: assn,H: product_prod(heap_ext(product_unit),set(nat)),Q: assn] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),H) ) ) ).

% ent_fwd
tff(fact_5534_entailsD,axiom,
    ! [Pa: assn,Q: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),H) ) ) ).

% entailsD
tff(fact_5535_entailsI,axiom,
    ! [Pa: assn,Q: assn] :
      ( ! [H2: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H2)
         => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),H2) )
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q) ) ).

% entailsI
tff(fact_5536_entails__def,axiom,
    ! [Pa: assn,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
    <=> ! [H3: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H3)
         => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),H3) ) ) ).

% entails_def
tff(fact_5537_mod__frame__fwd,axiom,
    ! [Ps3: assn,H: product_prod(heap_ext(product_unit),set(nat)),Pa: assn,R: assn,F2: assn] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Ps3),H)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),R)
       => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Ps3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),F2))
         => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),R),F2)),H) ) ) ) ).

% mod_frame_fwd
tff(fact_5538_star__assnI,axiom,
    ! [Pa: assn,H: heap_ext(product_unit),As2: set(nat),Q: assn,As4: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As4))
       => ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As2),As4) = bot_bot(set(nat)) )
         => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),Q)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As4))) ) ) ) ).

% star_assnI
tff(fact_5539_mod__star__conv,axiom,
    ! [A4: assn,B3: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),B3)),H)
    <=> ? [Hr: heap_ext(product_unit),As1: set(nat),As22: set(nat)] :
          ( ( H = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),Hr),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As1),As22)) )
          & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As1),As22) = bot_bot(set(nat)) )
          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,A4),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),Hr),As1))
          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,B3),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),Hr),As22)) ) ) ).

% mod_star_conv
tff(fact_5540_mod__star__trueE_H,axiom,
    ! [Pa: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),top_top(assn))),H)
     => ~ ! [H5: product_prod(heap_ext(product_unit),set(nat))] :
            ( ( aa(product_prod(heap_ext(product_unit),set(nat)),heap_ext(product_unit),product_fst(heap_ext(product_unit),set(nat)),H5) = aa(product_prod(heap_ext(product_unit),set(nat)),heap_ext(product_unit),product_fst(heap_ext(product_unit),set(nat)),H) )
           => ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),aa(product_prod(heap_ext(product_unit),set(nat)),set(nat),product_snd(heap_ext(product_unit),set(nat)),H5)),aa(product_prod(heap_ext(product_unit),set(nat)),set(nat),product_snd(heap_ext(product_unit),set(nat)),H))
             => ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H5) ) ) ) ).

% mod_star_trueE'
tff(fact_5541_mod__star__trueI,axiom,
    ! [Pa: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),top_top(assn))),H) ) ).

% mod_star_trueI
tff(fact_5542_mod__star__trueE,axiom,
    ! [Pa: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),top_top(assn))),H)
     => ~ ! [H5: product_prod(heap_ext(product_unit),set(nat))] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H5) ) ).

% mod_star_trueE
tff(fact_5543_mod__h__bot__iff_I2_J,axiom,
    ! [H: heap_ext(product_unit)] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,top_top(assn)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ).

% mod_h_bot_iff(2)
tff(fact_5544_mod__emp,axiom,
    ! [H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,one_one(assn)),H)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),set(nat),product_snd(heap_ext(product_unit),set(nat)),H) = bot_bot(set(nat)) ) ) ).

% mod_emp
tff(fact_5545_mod__emp__simp,axiom,
    ! [H: heap_ext(product_unit)] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,one_one(assn)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ).

% mod_emp_simp
tff(fact_5546_preciseD_H,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,assn)),A3: C,P3: D,F2: assn,H: product_prod(heap_ext(product_unit),set(nat)),A10: C,F7: assn] :
      ( precise(C,D,R)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A3),P3)),F2)),H)
       => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A10),P3)),F7)),H)
         => ( A3 = A10 ) ) ) ) ).

% preciseD'
tff(fact_5547_prec__frame_H,axiom,
    ! [C: $tType,Pa: fun(C,assn),X: C,F12: assn,Y: C,F23: assn,H: product_prod(heap_ext(product_unit),set(nat)),R12: assn,R22: assn] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,X)),F12)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,Y)),F23))),H)
       => ( X = Y ) )
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),R12),R22)),H)
       => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,R12),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,X)),F12))
         => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,R22),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,Y)),F23))
           => ( X = Y ) ) ) ) ) ).

% prec_frame'
tff(fact_5548_prec__frame__expl,axiom,
    ! [C: $tType,Pa: fun(C,assn),F12: assn,F23: assn,H: product_prod(heap_ext(product_unit),set(nat)),R12: assn,R22: assn,X: C,Y: C] :
      ( ! [X2: C,Y2: C] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,X2)),F12)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,Y2)),F23))),H)
         => ( X2 = Y2 ) )
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),R12),R22)),H)
       => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,R12),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,X)),F12))
         => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,R22),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Pa,Y)),F23))
           => ( X = Y ) ) ) ) ) ).

% prec_frame_expl
tff(fact_5549_preciseD,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,assn)),A3: C,P3: D,F2: assn,A10: C,F7: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( precise(C,D,R)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A3),P3)),F2)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A10),P3)),F7))),H)
       => ( A3 = A10 ) ) ) ).

% preciseD
tff(fact_5550_preciseI,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,assn))] :
      ( ! [A5: C,A16: C,H2: product_prod(heap_ext(product_unit),set(nat)),P6: D,F3: assn,F8: assn] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A5),P6)),F3)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A16),P6)),F8))),H2)
         => ( A5 = A16 ) )
     => precise(C,D,R) ) ).

% preciseI
tff(fact_5551_precise__def,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,assn))] :
      ( precise(C,D,R)
    <=> ! [A6: C,A17: C,H3: product_prod(heap_ext(product_unit),set(nat)),P4: D,F9: assn,F10: assn] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A6),P4)),F9)),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),R,A17),P4)),F10))),H3)
         => ( A6 = A17 ) ) ) ).

% precise_def
tff(fact_5552_comm__monoid__list__set_Oset__conv__list,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,G: fun(D,C),Xs: list(D)] :
      ( groups4802862169904069756st_set(C,F,Z2)
     => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(list(D),set(D),set2(D),Xs)) = aa(list(C),C,groups_monoid_F(C,F,Z2),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),aa(list(D),list(D),remdups(D),Xs))) ) ) ).

% comm_monoid_list_set.set_conv_list
tff(fact_5553_comm__monoid__list__set_Odistinct__set__conv__list,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,Xs: list(D),G: fun(D,C)] :
      ( groups4802862169904069756st_set(C,F,Z2)
     => ( aa(list(D),$o,distinct(D),Xs)
       => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(list(D),set(D),set2(D),Xs)) = aa(list(C),C,groups_monoid_F(C,F,Z2),aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),G),Xs)) ) ) ) ).

% comm_monoid_list_set.distinct_set_conv_list
tff(fact_5554_mod__not__dist,axiom,
    ! [Pa: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(assn,assn,uminus_uminus(assn),Pa)),H)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,H)
        & ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H) ) ) ).

% mod_not_dist
tff(fact_5555_in__range__empty,axiom,
    ! [H: heap_ext(product_unit)] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ).

% in_range_empty
tff(fact_5556_mod__true,axiom,
    ! [H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,top_top(assn)),H)
    <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,H) ) ).

% mod_true
tff(fact_5557_in__range__dist__union,axiom,
    ! [H: heap_ext(product_unit),As2: set(nat),As4: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As4)))
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As4)) ) ) ).

% in_range_dist_union
tff(fact_5558_models__in__range,axiom,
    ! [Pa: assn,H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),H)
     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,H) ) ).

% models_in_range
tff(fact_5559_in__range__subset,axiom,
    ! [As2: set(nat),As4: set(nat),H: heap_ext(product_unit)] :
      ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),As2),As4)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As4))
       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2)) ) ) ).

% in_range_subset
tff(fact_5560_one__assn__raw_Ocases,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ~ ! [H2: heap_ext(product_unit),As: set(nat)] : X != aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) ).

% one_assn_raw.cases
tff(fact_5561_snga__assn__raw_Ocases,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))] :
          ~ ! [R5: array(C),X2: list(C),H2: heap_ext(product_unit),As: set(nat)] : X != aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),R5),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),X2),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))) ) ).

% snga_assn_raw.cases
tff(fact_5562_sngr__assn__raw_Ocases,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))] :
          ~ ! [R5: ref(C),X2: C,H2: heap_ext(product_unit),As: set(nat)] : X != aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),R5),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),X2),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))) ) ).

% sngr_assn_raw.cases
tff(fact_5563_times__assn__raw_Ocases,axiom,
    ! [X: product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))] :
      ~ ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q6: fun(product_prod(heap_ext(product_unit),set(nat)),$o),H2: heap_ext(product_unit),As: set(nat)] : X != aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),P),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Q6),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))) ).

% times_assn_raw.cases
tff(fact_5564_comm__monoid__mult__class_Oprod__def,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ( groups7121269368397514597t_prod(C,D) = groups_comm_monoid_F(D,C,times_times(D),one_one(D)) ) ) ).

% comm_monoid_mult_class.prod_def
tff(fact_5565_wand__assnI,axiom,
    ! [H: heap_ext(product_unit),As2: set(nat),Q: assn,R: assn] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
     => ( ! [H5: heap_ext(product_unit),As5: set(nat)] :
            ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As2),As5) = bot_bot(set(nat)) )
           => ( relH(As2,H,H5)
             => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As2))
               => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As5))
                 => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,R),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As5))) ) ) ) )
       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,wand_assn(Q,R)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2)) ) ) ).

% wand_assnI
tff(fact_5566_times__assn__raw_Osimps,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o),H: heap_ext(product_unit),As2: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(Pa,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
    <=> ? [As1: set(nat),As22: set(nat)] :
          ( ( As2 = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As1),As22) )
          & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As1),As22) = bot_bot(set(nat)) )
          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As1))
          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Q,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As22)) ) ) ).

% times_assn_raw.simps
tff(fact_5567_times__assn__raw_Oelims_I1_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(X,Xa),Xb)
      <=> (Y) )
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( (Y)
            <=> ~ ? [As1: set(nat),As22: set(nat)] :
                    ( ( As = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As1),As22) )
                    & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As1),As22) = bot_bot(set(nat)) )
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As1))
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As22)) ) ) ) ) ).

% times_assn_raw.elims(1)
tff(fact_5568_relH__dist__union,axiom,
    ! [As2: set(nat),As4: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( relH(aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As4),H,H4)
    <=> ( relH(As2,H,H4)
        & relH(As4,H,H4) ) ) ).

% relH_dist_union
tff(fact_5569_relH__subset,axiom,
    ! [Bs: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit),As2: set(nat)] :
      ( relH(Bs,H,H4)
     => ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),As2),Bs)
       => relH(As2,H,H4) ) ) ).

% relH_subset
tff(fact_5570_relH__trans,axiom,
    ! [As2: set(nat),H12: heap_ext(product_unit),H23: heap_ext(product_unit),H32: heap_ext(product_unit)] :
      ( relH(As2,H12,H23)
     => ( relH(As2,H23,H32)
       => relH(As2,H12,H32) ) ) ).

% relH_trans
tff(fact_5571_relH__sym,axiom,
    ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( relH(As2,H,H4)
     => relH(As2,H4,H) ) ).

% relH_sym
tff(fact_5572_mod__relH,axiom,
    ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit),Pa: assn] :
      ( relH(As2,H,H4)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
      <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2)) ) ) ).

% mod_relH
tff(fact_5573_relH__refl,axiom,
    ! [H: heap_ext(product_unit),As2: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
     => relH(As2,H,H) ) ).

% relH_refl
tff(fact_5574_relH__in__rangeI_I1_J,axiom,
    ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( relH(As2,H,H4)
     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2)) ) ).

% relH_in_rangeI(1)
tff(fact_5575_relH__in__rangeI_I2_J,axiom,
    ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( relH(As2,H,H4)
     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2)) ) ).

% relH_in_rangeI(2)
tff(fact_5576_times__assn__raw_Oelims_I3_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(X,Xa),Xb)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ? [As12: set(nat),As23: set(nat)] :
                ( ( As = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As12),As23) )
                & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As12),As23) = bot_bot(set(nat)) )
                & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As12))
                & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As23)) ) ) ) ).

% times_assn_raw.elims(3)
tff(fact_5577_times__assn__raw_Oelims_I2_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(X,Xa),Xb)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ~ ? [As13: set(nat),As24: set(nat)] :
                  ( ( As = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As13),As24) )
                  & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As13),As24) = bot_bot(set(nat)) )
                  & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As13))
                  & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As24)) ) ) ) ).

% times_assn_raw.elims(2)
tff(fact_5578_times__assn__raw_Opelims_I3_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(X,Xa),Xb)
     => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),times_assn_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),times_assn_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
               => ? [As12: set(nat),As23: set(nat)] :
                    ( ( As = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As12),As23) )
                    & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As12),As23) = bot_bot(set(nat)) )
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As12))
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As23)) ) ) ) ) ) ).

% times_assn_raw.pelims(3)
tff(fact_5579_times__assn__raw_Opelims_I2_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(X,Xa),Xb)
     => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),times_assn_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),times_assn_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
               => ~ ? [As13: set(nat),As24: set(nat)] :
                      ( ( As = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As13),As24) )
                      & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As13),As24) = bot_bot(set(nat)) )
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As13))
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As24)) ) ) ) ) ) ).

% times_assn_raw.pelims(2)
tff(fact_5580_times__assn__raw_Opelims_I1_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,times_assn_raw(X,Xa),Xb)
      <=> (Y) )
     => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),times_assn_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( ( (Y)
                <=> ? [As1: set(nat),As22: set(nat)] :
                      ( ( As = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As1),As22) )
                      & ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As1),As22) = bot_bot(set(nat)) )
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As1))
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As22)) ) )
               => ~ accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),times_assn_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)))) ) ) ) ) ).

% times_assn_raw.pelims(1)
tff(fact_5581_wand__raw_Oelims_I3_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(X,Xa),Xb)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
              & ! [H5: heap_ext(product_unit),As5: set(nat)] :
                  ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As),As5) = bot_bot(set(nat)) )
                    & relH(As,H2,H5)
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As))
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As5)) )
                 => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As5))) ) ) ) ) ).

% wand_raw.elims(3)
tff(fact_5582_wand__raw_Oelims_I2_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(X,Xa),Xb)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ~ ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
                & ! [H6: heap_ext(product_unit),As6: set(nat)] :
                    ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As),As6) = bot_bot(set(nat)) )
                      & relH(As,H2,H6)
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H6),As))
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H6),As6)) )
                   => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H6),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As6))) ) ) ) ) ).

% wand_raw.elims(2)
tff(fact_5583_wand__raw_Oelims_I1_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(X,Xa),Xb)
      <=> (Y) )
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( (Y)
            <=> ~ ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
                  & ! [H7: heap_ext(product_unit),As7: set(nat)] :
                      ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As),As7) = bot_bot(set(nat)) )
                        & relH(As,H2,H7)
                        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As))
                        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As7)) )
                     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As7))) ) ) ) ) ) ).

% wand_raw.elims(1)
tff(fact_5584_wand__raw_Osimps,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o),H: heap_ext(product_unit),As2: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(Pa,Q),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
        & ! [H7: heap_ext(product_unit),As7: set(nat)] :
            ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As2),As7) = bot_bot(set(nat)) )
              & relH(As2,H,H7)
              & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As2))
              & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As7)) )
           => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Q,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As7))) ) ) ) ).

% wand_raw.simps
tff(fact_5585_wand__raw_Opelims_I3_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(X,Xa),Xb)
     => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),wand_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),wand_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
               => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
                  & ! [H5: heap_ext(product_unit),As5: set(nat)] :
                      ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As),As5) = bot_bot(set(nat)) )
                        & relH(As,H2,H5)
                        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As))
                        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As5)) )
                     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As5))) ) ) ) ) ) ) ).

% wand_raw.pelims(3)
tff(fact_5586_wand__raw_Opelims_I2_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(X,Xa),Xb)
     => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),wand_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),wand_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
               => ~ ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
                    & ! [H6: heap_ext(product_unit),As6: set(nat)] :
                        ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As),As6) = bot_bot(set(nat)) )
                          & relH(As,H2,H6)
                          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H6),As))
                          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H6),As6)) )
                       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H6),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As6))) ) ) ) ) ) ) ).

% wand_raw.pelims(2)
tff(fact_5587_wand__raw_Opelims_I1_J,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,wand_raw(X,Xa),Xb)
      <=> (Y) )
     => ( accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),wand_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( ( (Y)
                <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
                    & ! [H7: heap_ext(product_unit),As7: set(nat)] :
                        ( ( ( aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),inf_inf(set(nat)),As),As7) = bot_bot(set(nat)) )
                          & relH(As,H2,H7)
                          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As))
                          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,X,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As7)) )
                       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Xa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As7))) ) ) )
               => ~ accp(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),wand_raw_rel,aa(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(fun(product_prod(heap_ext(product_unit),set(nat)),$o),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)))) ) ) ) ) ).

% wand_raw.pelims(1)
tff(fact_5588_uminus__assn__def,axiom,
    ! [Pa: assn] : aa(assn,assn,uminus_uminus(assn),Pa) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,aTP_Lamp_rv(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pa)) ).

% uminus_assn_def
tff(fact_5589_comm__monoid__set_OUnion__disjoint,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,C4: set(set(D)),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( ! [X2: set(D)] :
            ( member2(set(D),X2,C4)
           => aa(set(D),$o,finite_finite2(D),X2) )
       => ( ! [X2: set(D)] :
              ( member2(set(D),X2,C4)
             => ! [Xa4: set(D)] :
                  ( member2(set(D),Xa4,C4)
                 => ( ( X2 != Xa4 )
                   => ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),X2),Xa4) = bot_bot(set(D)) ) ) ) )
         => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),C4)) = aa(set(set(D)),C,aa(fun(D,C),fun(set(set(D)),C),comp(fun(set(D),C),fun(set(set(D)),C),fun(D,C),groups_comm_monoid_F(C,set(D),F,Z2),groups_comm_monoid_F(C,D,F,Z2)),G),C4) ) ) ) ) ).

% comm_monoid_set.Union_disjoint
tff(fact_5590_comm__monoid__set_OUNION__disjoint,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,I5: set(D),A4: fun(D,set(E2)),G: fun(E2,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),I5)
       => ( ! [X2: D] :
              ( member2(D,X2,I5)
             => aa(set(E2),$o,finite_finite2(E2),aa(D,set(E2),A4,X2)) )
         => ( ! [X2: D] :
                ( member2(D,X2,I5)
               => ! [Xa4: D] :
                    ( member2(D,Xa4,I5)
                   => ( ( X2 != Xa4 )
                     => ( aa(set(E2),set(E2),aa(set(E2),fun(set(E2),set(E2)),inf_inf(set(E2)),aa(D,set(E2),A4,X2)),aa(D,set(E2),A4,Xa4)) = bot_bot(set(E2)) ) ) ) )
           => ( aa(set(E2),C,aa(fun(E2,C),fun(set(E2),C),groups_comm_monoid_F(C,E2,F,Z2),G),aa(set(set(E2)),set(E2),complete_Sup_Sup(set(E2)),aa(set(D),set(set(E2)),image2(D,set(E2),A4),I5))) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),aa(fun(E2,C),fun(D,C),aa(fun(D,set(E2)),fun(fun(E2,C),fun(D,C)),aa(C,fun(fun(D,set(E2)),fun(fun(E2,C),fun(D,C))),aTP_Lamp_rw(fun(C,fun(C,C)),fun(C,fun(fun(D,set(E2)),fun(fun(E2,C),fun(D,C)))),F),Z2),A4),G)),I5) ) ) ) ) ) ).

% comm_monoid_set.UNION_disjoint
tff(fact_5591_Rep__assn__inverse,axiom,
    ! [X: assn] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,X)) = X ).

% Rep_assn_inverse
tff(fact_5592_comm__monoid__set_Oempty,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(C,C)),Z2: C,G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),bot_bot(set(D))) = Z2 ) ) ).

% comm_monoid_set.empty
tff(fact_5593_pure__assn__def,axiom,
    ! [B2: $o] : pure_assn((B2)) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,pure_assn_raw(heap_ext(product_unit),nat,(B2))) ).

% pure_assn_def
tff(fact_5594_prod_Ocomm__monoid__set__axioms,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => groups778175481326437816id_set(C,times_times(C),one_one(C)) ) ).

% prod.comm_monoid_set_axioms
tff(fact_5595_comm__monoid__set_Oempty_H,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(C,C)),Z2: C,P3: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_G(C,D,F,Z2),P3),bot_bot(set(D))) = Z2 ) ) ).

% comm_monoid_set.empty'
tff(fact_5596_Abs__assn__eqI_I2_J,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pr: assn] :
      ( ! [H2: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,H2)
        <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pr),H2) )
     => ( Pr = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,Pa) ) ) ).

% Abs_assn_eqI(2)
tff(fact_5597_Abs__assn__eqI_I1_J,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pr: assn] :
      ( ! [H2: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,H2)
        <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pr),H2) )
     => ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,Pa) = Pr ) ) ).

% Abs_assn_eqI(1)
tff(fact_5598_bot__assn__def,axiom,
    bot_bot(assn) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,aTP_Lamp_rx(product_prod(heap_ext(product_unit),set(nat)),$o)) ).

% bot_assn_def
tff(fact_5599_comm__monoid__set_Ointer__restrict,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),G: fun(D,C),B3: set(D)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3)) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),aa(set(D),fun(D,C),aa(fun(D,C),fun(set(D),fun(D,C)),aTP_Lamp_ry(C,fun(fun(D,C),fun(set(D),fun(D,C))),Z2),G),B3)),A4) ) ) ) ).

% comm_monoid_set.inter_restrict
tff(fact_5600_top__assn__def,axiom,
    top_top(assn) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,in_range) ).

% top_assn_def
tff(fact_5601_sup__assn__def,axiom,
    ! [Pa: assn,Q: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Pa),Q) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_rz(assn,fun(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Pa),Q)) ).

% sup_assn_def
tff(fact_5602_inf__assn__def,axiom,
    ! [Pa: assn,Q: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Pa),Q) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_sa(assn,fun(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Pa),Q)) ).

% inf_assn_def
tff(fact_5603_comm__monoid__set_Ounion__inter,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),B3: set(D),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),$o,finite_finite2(D),B3)
         => ( aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3))) = aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),A4)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),B3)) ) ) ) ) ).

% comm_monoid_set.union_inter
tff(fact_5604_comm__monoid__set_Ounion__inter__neutral,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),B3: set(D),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),$o,finite_finite2(D),B3)
         => ( ! [X2: D] :
                ( member2(D,X2,aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3))
               => ( aa(D,C,G,X2) = Z2 ) )
           => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3)) = aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),A4)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),B3)) ) ) ) ) ) ).

% comm_monoid_set.union_inter_neutral
tff(fact_5605_comm__monoid__set_Omono__neutral__cong,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,T: set(D),S: set(D),H: fun(D,C),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),T)
       => ( aa(set(D),$o,finite_finite2(D),S)
         => ( ! [I3: D] :
                ( member2(D,I3,minus_minus(set(D),T,S))
               => ( aa(D,C,H,I3) = Z2 ) )
           => ( ! [I3: D] :
                  ( member2(D,I3,minus_minus(set(D),S,T))
                 => ( aa(D,C,G,I3) = Z2 ) )
             => ( ! [X2: D] :
                    ( member2(D,X2,aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),S),T))
                   => ( aa(D,C,G,X2) = aa(D,C,H,X2) ) )
               => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),S) = aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),H),T) ) ) ) ) ) ) ) ).

% comm_monoid_set.mono_neutral_cong
tff(fact_5606_comm__monoid__set_OInt__Diff,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),G: fun(D,C),B3: set(D)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),A4) = aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),minus_minus(set(D),A4,B3))) ) ) ) ).

% comm_monoid_set.Int_Diff
tff(fact_5607_comm__monoid__set_OIf__cases,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),Pa: fun(D,$o),H: fun(D,C),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),aTP_Lamp_al(fun(D,$o),fun(fun(D,C),fun(fun(D,C),fun(D,C))),Pa),H),G)),A4) = aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),H),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),collect(D,Pa)))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),aa(set(D),set(D),uminus_uminus(set(D)),collect(D,Pa))))) ) ) ) ).

% comm_monoid_set.If_cases
tff(fact_5608_comm__monoid__set_Oinsert__remove,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),G: fun(D,C),X: D] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),A4)) = aa(C,C,aa(C,fun(C,C),F,aa(D,C,G,X)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),minus_minus(set(D),A4,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D)))))) ) ) ) ).

% comm_monoid_set.insert_remove
tff(fact_5609_comm__monoid__set_Oremove,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),X: D,G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( member2(D,X,A4)
         => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),A4) = aa(C,C,aa(C,fun(C,C),F,aa(D,C,G,X)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),minus_minus(set(D),A4,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D)))))) ) ) ) ) ).

% comm_monoid_set.remove
tff(fact_5610_comm__monoid__set_Ounion__disjoint,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),B3: set(D),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),$o,finite_finite2(D),B3)
         => ( ( aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3) = bot_bot(set(D)) )
           => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3)) = aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),A4)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),B3)) ) ) ) ) ) ).

% comm_monoid_set.union_disjoint
tff(fact_5611_comm__monoid__set_Ounion__diff2,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(D),B3: set(D),G: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),A4)
       => ( aa(set(D),$o,finite_finite2(D),B3)
         => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),sup_sup(set(D)),A4),B3)) = aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),minus_minus(set(D),A4,B3))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),minus_minus(set(D),B3,A4)))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),G),aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),A4),B3))) ) ) ) ) ).

% comm_monoid_set.union_diff2
tff(fact_5612_comm__monoid__set_Odelta__remove,axiom,
    ! [C: $tType,D: $tType,F: fun(C,fun(C,C)),Z2: C,S: set(D),A3: D,B2: fun(D,C),C3: fun(D,C)] :
      ( groups778175481326437816id_set(C,F,Z2)
     => ( aa(set(D),$o,finite_finite2(D),S)
       => ( aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),aTP_Lamp_sb(D,fun(fun(D,C),fun(fun(D,C),fun(D,C))),A3),B2),C3)),S) = $ite(member2(D,A3,S),aa(C,C,aa(C,fun(C,C),F,aa(D,C,B2,A3)),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),C3),minus_minus(set(D),S,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D)))))),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups_comm_monoid_F(C,D,F,Z2),C3),minus_minus(set(D),S,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),A3),bot_bot(set(D)))))) ) ) ) ).

% comm_monoid_set.delta_remove
tff(fact_5613_times__assn__def,axiom,
    ! [Pa: assn,Q: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),Q) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,times_assn_raw(aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q))) ).

% times_assn_def
tff(fact_5614_wand__assn__def,axiom,
    ! [Pa: assn,Q: assn] : wand_assn(Pa,Q) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,wand_raw(aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Pa),aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Q))) ).

% wand_assn_def
tff(fact_5615_mod__h__bot__iff_I8_J,axiom,
    ! [C: $tType,R: fun(C,assn),H: heap_ext(product_unit)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,ex_assn(C,R)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat))))
    <=> ? [X4: C] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(C,assn,R,X4)),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),bot_bot(set(nat)))) ) ).

% mod_h_bot_iff(8)
tff(fact_5616_sngr__assn__def,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: ref(C),X: C] : sngr_assn(C,R3,X) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,sngr_assn_raw(C,R3,X)) ) ).

% sngr_assn_def
tff(fact_5617_snga__assn__def,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: array(C),A3: list(C)] : snga_assn(C,R3,A3) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,snga_assn_raw(C,R3,A3)) ) ).

% snga_assn_def
tff(fact_5618_ex__assn__const,axiom,
    ! [C: $tType,C3: assn] : ex_assn(C,aTP_Lamp_sc(assn,fun(C,assn),C3)) = C3 ).

% ex_assn_const
tff(fact_5619_norm__assertion__simps_I17_J,axiom,
    ! [C: $tType,R: assn,Q: fun(C,assn)] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),R),ex_assn(C,Q)) = ex_assn(C,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sd(assn,fun(fun(C,assn),fun(C,assn)),R),Q)) ).

% norm_assertion_simps(17)
tff(fact_5620_norm__assertion__simps_I16_J,axiom,
    ! [C: $tType,Q: fun(C,assn),R: assn] : aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),ex_assn(C,Q)),R) = ex_assn(C,aa(assn,fun(C,assn),aTP_Lamp_se(fun(C,assn),fun(assn,fun(C,assn)),Q),R)) ).

% norm_assertion_simps(16)
tff(fact_5621_mod__ex__dist,axiom,
    ! [C: $tType,Pa: fun(C,assn),H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,ex_assn(C,Pa)),H)
    <=> ? [X4: C] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(C,assn,Pa,X4)),H) ) ).

% mod_ex_dist
tff(fact_5622_triv__exI,axiom,
    ! [C: $tType,Q: fun(C,assn),X: C] : aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(C,assn,Q,X)),ex_assn(C,Q)) ).

% triv_exI
tff(fact_5623_norm__assertion__simps_I21_J,axiom,
    ! [C: $tType,Q: assn,Pa: fun(C,assn)] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Q),ex_assn(C,Pa)) = ex_assn(C,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sf(assn,fun(fun(C,assn),fun(C,assn)),Q),Pa)) ).

% norm_assertion_simps(21)
tff(fact_5624_norm__assertion__simps_I20_J,axiom,
    ! [C: $tType,Q: fun(C,assn),Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),ex_assn(C,Q)),Pa) = ex_assn(C,aa(assn,fun(C,assn),aTP_Lamp_sg(fun(C,assn),fun(assn,fun(C,assn)),Q),Pa)) ).

% norm_assertion_simps(20)
tff(fact_5625_norm__assertion__simps_I18_J,axiom,
    ! [C: $tType,Q: fun(C,assn),Pa: assn] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),ex_assn(C,Q)),Pa) = ex_assn(C,aa(assn,fun(C,assn),aTP_Lamp_sh(fun(C,assn),fun(assn,fun(C,assn)),Q),Pa)) ).

% norm_assertion_simps(18)
tff(fact_5626_norm__assertion__simps_I19_J,axiom,
    ! [C: $tType,Q: assn,Pa: fun(C,assn)] : aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Q),ex_assn(C,Pa)) = ex_assn(C,aa(fun(C,assn),fun(C,assn),aTP_Lamp_si(assn,fun(fun(C,assn),fun(C,assn)),Q),Pa)) ).

% norm_assertion_simps(19)
tff(fact_5627_ex__one__point__gen,axiom,
    ! [C: $tType,Pa: fun(C,assn),V: C] :
      ( ! [H2: product_prod(heap_ext(product_unit),set(nat)),X2: C] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(C,assn,Pa,X2)),H2)
         => ( X2 = V ) )
     => ( ex_assn(C,Pa) = aa(C,assn,Pa,V) ) ) ).

% ex_one_point_gen
tff(fact_5628_mod__exI,axiom,
    ! [C: $tType,Pa: fun(C,assn),H: product_prod(heap_ext(product_unit),set(nat))] :
      ( ? [X3: C] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(C,assn,Pa,X3)),H)
     => aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,ex_assn(C,Pa)),H) ) ).

% mod_exI
tff(fact_5629_mod__exE,axiom,
    ! [C: $tType,Pa: fun(C,assn),H: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,ex_assn(C,Pa)),H)
     => ~ ! [X2: C] : ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(C,assn,Pa,X2)),H) ) ).

% mod_exE
tff(fact_5630_ent__ex__postI,axiom,
    ! [C: $tType,Pa: assn,Q: fun(C,assn),X: C] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(C,assn,Q,X))
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),ex_assn(C,Q)) ) ).

% ent_ex_postI
tff(fact_5631_ent__ex__preI,axiom,
    ! [C: $tType,Pa: fun(C,assn),Q: assn] :
      ( ! [X2: C] : aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(C,assn,Pa,X2)),Q)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,ex_assn(C,Pa)),Q) ) ).

% ent_ex_preI
tff(fact_5632_enorm__exI_H,axiom,
    ! [C: $tType,Z6: fun(C,$o),Pa: assn,Q: fun(C,assn)] :
      ( ! [X2: C] :
          ( aa(C,$o,Z6,X2)
         => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(C,assn,Q,X2)) )
     => ( ? [X_13: C] : aa(C,$o,Z6,X_13)
       => aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),ex_assn(C,Q)) ) ) ).

% enorm_exI'
tff(fact_5633_ex__distrib__star,axiom,
    ! [C: $tType,Pa: fun(C,assn),Q: assn] : ex_assn(C,aa(assn,fun(C,assn),aTP_Lamp_se(fun(C,assn),fun(assn,fun(C,assn)),Pa),Q)) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),ex_assn(C,Pa)),Q) ).

% ex_distrib_star
tff(fact_5634_ex__distrib__and,axiom,
    ! [C: $tType,Pa: fun(C,assn),Q: assn] : ex_assn(C,aa(assn,fun(C,assn),aTP_Lamp_sh(fun(C,assn),fun(assn,fun(C,assn)),Pa),Q)) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),ex_assn(C,Pa)),Q) ).

% ex_distrib_and
tff(fact_5635_ex__join__or,axiom,
    ! [C: $tType,Pa: fun(C,assn),Q: fun(C,assn)] : ex_assn(C,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sj(fun(C,assn),fun(fun(C,assn),fun(C,assn)),Pa),Q)) = ex_assn(C,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sk(fun(C,assn),fun(fun(C,assn),fun(C,assn)),Pa),Q)) ).

% ex_join_or
tff(fact_5636_ex__distrib__or,axiom,
    ! [C: $tType,Pa: fun(C,assn),Q: assn] : ex_assn(C,aa(assn,fun(C,assn),aTP_Lamp_sg(fun(C,assn),fun(assn,fun(C,assn)),Pa),Q)) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),ex_assn(C,Pa)),Q) ).

% ex_distrib_or
tff(fact_5637_ex__assn__def,axiom,
    ! [C: $tType,Pa: fun(C,assn)] : ex_assn(C,Pa) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,aTP_Lamp_sl(fun(C,assn),fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pa)) ).

% ex_assn_def
tff(fact_5638_one__assn__def,axiom,
    one_one(assn) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,one_assn_raw) ).

% one_assn_def
tff(fact_5639_one__assn__raw_Osimps,axiom,
    ! [H: heap_ext(product_unit),As2: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
    <=> ( As2 = bot_bot(set(nat)) ) ) ).

% one_assn_raw.simps
tff(fact_5640_one__assn__raw_Oelims_I1_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,X)
      <=> (Y) )
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( (Y)
            <=> ( As != bot_bot(set(nat)) ) ) ) ) ).

% one_assn_raw.elims(1)
tff(fact_5641_one__assn__raw_Oelims_I3_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,X)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( As = bot_bot(set(nat)) ) ) ) ).

% one_assn_raw.elims(3)
tff(fact_5642_one__assn__raw_Oelims_I2_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,X)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( As != bot_bot(set(nat)) ) ) ) ).

% one_assn_raw.elims(2)
tff(fact_5643_properI,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( ! [As: set(nat),H2: heap_ext(product_unit)] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
         => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)) )
     => ( ! [As: set(nat),H2: heap_ext(product_unit),H5: heap_ext(product_unit)] :
            ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
           => ( relH(As,H2,H5)
             => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As))
               => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H5),As)) ) ) )
       => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa) ) ) ).

% properI
tff(fact_5644_properD2,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),H: heap_ext(product_unit),As2: set(nat),H4: heap_ext(product_unit)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
       => ( relH(As2,H,H4)
         => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2))
           => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2)) ) ) ) ) ).

% properD2
tff(fact_5645_proper__def,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
    <=> ! [H3: heap_ext(product_unit),H7: heap_ext(product_unit),As8: set(nat)] :
          ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H3),As8))
           => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H3),As8)) )
          & ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H3),As8))
              & relH(As8,H3,H7)
              & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As8)) )
           => aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H7),As8)) ) ) ) ).

% proper_def
tff(fact_5646_bool__assn__proper_I4_J,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Q)
       => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_sm(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Pa),Q)) ) ) ).

% bool_assn_proper(4)
tff(fact_5647_bool__assn__proper_I3_J,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Q)
       => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_sn(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Pa),Q)) ) ) ).

% bool_assn_proper(3)
tff(fact_5648_bool__assn__proper_I2_J,axiom,
    aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,aTP_Lamp_rx(product_prod(heap_ext(product_unit),set(nat)),$o)) ).

% bool_assn_proper(2)
tff(fact_5649_bool__assn__proper_I1_J,axiom,
    aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,in_range) ).

% bool_assn_proper(1)
tff(fact_5650_ex__assn__proper,axiom,
    ! [C: $tType,Pa: fun(C,fun(product_prod(heap_ext(product_unit),set(nat)),$o))] :
      ( ! [X2: C] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pa,X2))
     => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,aTP_Lamp_so(fun(C,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pa)) ) ).

% ex_assn_proper
tff(fact_5651_snga__assn__proper,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: array(C),X: list(C)] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,snga_assn_raw(C,R3,X)) ) ).

% snga_assn_proper
tff(fact_5652_sngr__assn__proper,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: ref(C),X: C] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,sngr_assn_raw(C,R3,X)) ) ).

% sngr_assn_proper
tff(fact_5653_times__assn__proper,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Q)
       => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,times_assn_raw(Pa,Q)) ) ) ).

% times_assn_proper
tff(fact_5654_wand__proper,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,wand_raw(Pa,Q)) ).

% wand_proper
tff(fact_5655_one__assn__proper,axiom,
    aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,one_assn_raw) ).

% one_assn_proper
tff(fact_5656_bool__assn__proper_I5_J,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,aTP_Lamp_sp(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pa)) ) ).

% bool_assn_proper(5)
tff(fact_5657_pure__assn__proper,axiom,
    ! [B2: $o] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,pure_assn_raw(heap_ext(product_unit),nat,(B2))) ).

% pure_assn_proper
tff(fact_5658_Abs__assn__inject,axiom,
    ! [X: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),X,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper))
     => ( member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper))
       => ( ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,X) = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,Y) )
        <=> ( X = Y ) ) ) ) ).

% Abs_assn_inject
tff(fact_5659_Abs__assn__induct,axiom,
    ! [Pa: fun(assn,$o),X: assn] :
      ( ! [Y2: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
          ( member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y2,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper))
         => aa(assn,$o,Pa,aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,Y2)) )
     => aa(assn,$o,Pa,X) ) ).

% Abs_assn_induct
tff(fact_5660_Abs__assn__cases,axiom,
    ! [X: assn] :
      ~ ! [Y2: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
          ( ( X = aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,Y2) )
         => ~ member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y2,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper)) ) ).

% Abs_assn_cases
tff(fact_5661_Rep__assn__induct,axiom,
    ! [Y: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Pa: fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o)] :
      ( member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper))
     => ( ! [X2: assn] : aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,Pa,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,X2))
       => aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,Pa,Y) ) ) ).

% Rep_assn_induct
tff(fact_5662_Rep__assn__cases,axiom,
    ! [Y: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper))
     => ~ ! [X2: assn] : Y != aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,X2) ) ).

% Rep_assn_cases
tff(fact_5663_Rep__assn,axiom,
    ! [X: assn] : member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,X),collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper)) ).

% Rep_assn
tff(fact_5664_properD1,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),H: heap_ext(product_unit),As2: set(nat)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
       => aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2)) ) ) ).

% properD1
tff(fact_5665_Abs__assn__inverse,axiom,
    ! [Y: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( member2(fun(product_prod(heap_ext(product_unit),set(nat)),$o),Y,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper))
     => ( aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),assn,abs_assn,Y)) = Y ) ) ).

% Abs_assn_inverse
tff(fact_5666_proper__iff,axiom,
    ! [Pa: fun(product_prod(heap_ext(product_unit),set(nat)),$o),As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),$o,proper,Pa)
     => ( relH(As2,H,H4)
       => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2))
         => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
          <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,Pa,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2)) ) ) ) ) ).

% proper_iff
tff(fact_5667_and_Ocomm__monoid__axioms,axiom,
    ! [C: $tType] :
      ( bit_ri3973907225187159222ations(C)
     => comm_monoid(C,bit_se5824344872417868541ns_and(C),aa(C,C,uminus_uminus(C),one_one(C))) ) ).

% and.comm_monoid_axioms
tff(fact_5668_wo__rel_Osuc__greater,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C),B2: C] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( order_AboveS(C,R3,B3) != bot_bot(set(C)) )
         => ( member2(C,B2,B3)
           => ( ( bNF_Wellorder_wo_suc(C,R3,B3) != B2 )
              & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),bNF_Wellorder_wo_suc(C,R3,B3)),R3) ) ) ) ) ) ).

% wo_rel.suc_greater
tff(fact_5669_monoid__list_ONil,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( groups_monoid_list(C,F,Z2)
     => ( aa(list(C),C,groups_monoid_F(C,F,Z2),nil(C)) = Z2 ) ) ).

% monoid_list.Nil
tff(fact_5670_comm__monoid_Ocomm__neutral,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,A3: C] :
      ( comm_monoid(C,F,Z2)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),Z2) = A3 ) ) ).

% comm_monoid.comm_neutral
tff(fact_5671_semilattice__neutr_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( semilattice_neutr(C,F,Z2)
     => comm_monoid(C,F,Z2) ) ).

% semilattice_neutr.axioms(2)
tff(fact_5672_add_Ocomm__monoid__axioms,axiom,
    ! [C: $tType] :
      ( comm_monoid_add(C)
     => comm_monoid(C,plus_plus(C),zero_zero(C)) ) ).

% add.comm_monoid_axioms
tff(fact_5673_mult_Ocomm__monoid__axioms,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => comm_monoid(C,times_times(C),one_one(C)) ) ).

% mult.comm_monoid_axioms
tff(fact_5674_sup__bot_Ocomm__monoid__axioms,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => comm_monoid(C,sup_sup(C),bot_bot(C)) ) ).

% sup_bot.comm_monoid_axioms
tff(fact_5675_inf__top_Ocomm__monoid__axioms,axiom,
    ! [C: $tType] :
      ( bounde4346867609351753570nf_top(C)
     => comm_monoid(C,inf_inf(C),top_top(C)) ) ).

% inf_top.comm_monoid_axioms
tff(fact_5676_wo__rel_Osuc__inField,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C)] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( order_AboveS(C,R3,B3) != bot_bot(set(C)) )
         => member2(C,bNF_Wellorder_wo_suc(C,R3,B3),field2(C,R3)) ) ) ) ).

% wo_rel.suc_inField
tff(fact_5677_wo__rel_Osuc__AboveS,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),B3: set(C)] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B3),field2(C,R3))
       => ( ( order_AboveS(C,R3,B3) != bot_bot(set(C)) )
         => member2(C,bNF_Wellorder_wo_suc(C,R3,B3),order_AboveS(C,R3,B3)) ) ) ) ).

% wo_rel.suc_AboveS
tff(fact_5678_wo__rel_Osuc__ofilter__in,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),A4: set(C),B2: C] :
      ( bNF_Wellorder_wo_rel(C,R3)
     => ( order_ofilter(C,R3,A4)
       => ( ( order_AboveS(C,R3,A4) != bot_bot(set(C)) )
         => ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),bNF_Wellorder_wo_suc(C,R3,A4)),R3)
           => ( ( B2 != bNF_Wellorder_wo_suc(C,R3,A4) )
             => member2(C,B2,A4) ) ) ) ) ) ).

% wo_rel.suc_ofilter_in
tff(fact_5679_prod__list_Omonoid__list__axioms,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => groups_monoid_list(C,times_times(C),one_one(C)) ) ).

% prod_list.monoid_list_axioms
tff(fact_5680_AboveS__disjoint,axiom,
    ! [C: $tType,A4: set(C),R3: set(product_prod(C,C))] : aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),order_AboveS(C,R3,A4)) = bot_bot(set(C)) ).

% AboveS_disjoint
tff(fact_5681_monoid__list_OCons,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,X: C,Xs: list(C)] :
      ( groups_monoid_list(C,F,Z2)
     => ( aa(list(C),C,groups_monoid_F(C,F,Z2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X),Xs)) = aa(C,C,aa(C,fun(C,C),F,X),aa(list(C),C,groups_monoid_F(C,F,Z2),Xs)) ) ) ).

% monoid_list.Cons
tff(fact_5682_max_Osemilattice__order__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => semilattice_order(C,ord_max(C),aTP_Lamp_ao(C,fun(C,$o)),aTP_Lamp_sq(C,fun(C,$o))) ) ).

% max.semilattice_order_axioms
tff(fact_5683_prod__mset__def,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ( comm_m9189036328036947845d_mset(C) = comm_monoid_F(C,times_times(C),one_one(C)) ) ) ).

% prod_mset_def
tff(fact_5684_sup_Osemilattice__order__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => semilattice_order(C,sup_sup(C),aTP_Lamp_sr(C,fun(C,$o)),aTP_Lamp_ss(C,fun(C,$o))) ) ).

% sup.semilattice_order_axioms
tff(fact_5685_semilattice__order_Omono,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,C3: C,B2: C,D3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),C3)
       => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),D3)
         => aa(C,$o,aa(C,fun(C,$o),Less_eq,aa(C,C,aa(C,fun(C,C),F,A3),B2)),aa(C,C,aa(C,fun(C,C),F,C3),D3)) ) ) ) ).

% semilattice_order.mono
tff(fact_5686_semilattice__order_OorderE,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
       => ( A3 = aa(C,C,aa(C,fun(C,C),F,A3),B2) ) ) ) ).

% semilattice_order.orderE
tff(fact_5687_semilattice__order_OorderI,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( ( A3 = aa(C,C,aa(C,fun(C,C),F,A3),B2) )
       => aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2) ) ) ).

% semilattice_order.orderI
tff(fact_5688_semilattice__order_Oabsorb1,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
       => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = A3 ) ) ) ).

% semilattice_order.absorb1
tff(fact_5689_semilattice__order_Oabsorb2,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),B2: C,A3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),A3)
       => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = B2 ) ) ) ).

% semilattice_order.absorb2
tff(fact_5690_semilattice__order_Oabsorb3,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
       => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = A3 ) ) ) ).

% semilattice_order.absorb3
tff(fact_5691_semilattice__order_Oabsorb4,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),B2: C,A3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,B2),A3)
       => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = B2 ) ) ) ).

% semilattice_order.absorb4
tff(fact_5692_semilattice__order_OboundedE,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3))
       => ~ ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
           => ~ aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),C3) ) ) ) ).

% semilattice_order.boundedE
tff(fact_5693_semilattice__order_OboundedI,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
       => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),C3)
         => aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3)) ) ) ) ).

% semilattice_order.boundedI
tff(fact_5694_semilattice__order_Oorder__iff,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
      <=> ( A3 = aa(C,C,aa(C,fun(C,C),F,A3),B2) ) ) ) ).

% semilattice_order.order_iff
tff(fact_5695_semilattice__order_Ocobounded1,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => aa(C,$o,aa(C,fun(C,$o),Less_eq,aa(C,C,aa(C,fun(C,C),F,A3),B2)),A3) ) ).

% semilattice_order.cobounded1
tff(fact_5696_semilattice__order_Ocobounded2,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => aa(C,$o,aa(C,fun(C,$o),Less_eq,aa(C,C,aa(C,fun(C,C),F,A3),B2)),B2) ) ).

% semilattice_order.cobounded2
tff(fact_5697_semilattice__order_Oabsorb__iff1,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
      <=> ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = A3 ) ) ) ).

% semilattice_order.absorb_iff1
tff(fact_5698_semilattice__order_Oabsorb__iff2,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),B2: C,A3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),A3)
      <=> ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = B2 ) ) ) ).

% semilattice_order.absorb_iff2
tff(fact_5699_semilattice__order_Obounded__iff,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3))
      <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
          & aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),C3) ) ) ) ).

% semilattice_order.bounded_iff
tff(fact_5700_semilattice__order_OcoboundedI1,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,C3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),C3)
       => aa(C,$o,aa(C,fun(C,$o),Less_eq,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) ) ) ).

% semilattice_order.coboundedI1
tff(fact_5701_semilattice__order_OcoboundedI2,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),B2: C,C3: C,A3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),C3)
       => aa(C,$o,aa(C,fun(C,$o),Less_eq,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) ) ) ).

% semilattice_order.coboundedI2
tff(fact_5702_semilattice__order_Ostrict__boundedE,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3))
       => ~ ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
           => ~ aa(C,$o,aa(C,fun(C,$o),Less,A3),C3) ) ) ) ).

% semilattice_order.strict_boundedE
tff(fact_5703_semilattice__order_Ostrict__order__iff,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
      <=> ( ( A3 = aa(C,C,aa(C,fun(C,C),F,A3),B2) )
          & ( A3 != B2 ) ) ) ) ).

% semilattice_order.strict_order_iff
tff(fact_5704_semilattice__order_Ostrict__coboundedI1,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,C3: C,B2: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),C3)
       => aa(C,$o,aa(C,fun(C,$o),Less,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) ) ) ).

% semilattice_order.strict_coboundedI1
tff(fact_5705_semilattice__order_Ostrict__coboundedI2,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),B2: C,C3: C,A3: C] :
      ( semilattice_order(C,F,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,B2),C3)
       => aa(C,$o,aa(C,fun(C,$o),Less,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) ) ) ).

% semilattice_order.strict_coboundedI2
tff(fact_5706_semilattice__neutr__order_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semila1105856199041335345_order(C,F,Z2,Less_eq,Less)
     => semilattice_order(C,F,Less_eq,Less) ) ).

% semilattice_neutr_order.axioms(2)
tff(fact_5707_semilattice__neutr__order__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semila1105856199041335345_order(C,F,Z2,Less_eq,Less)
    <=> ( semilattice_neutr(C,F,Z2)
        & semilattice_order(C,F,Less_eq,Less) ) ) ).

% semilattice_neutr_order_def
tff(fact_5708_semilattice__neutr__order_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semilattice_neutr(C,F,Z2)
     => ( semilattice_order(C,F,Less_eq,Less)
       => semila1105856199041335345_order(C,F,Z2,Less_eq,Less) ) ) ).

% semilattice_neutr_order.intro
tff(fact_5709_inf_Osemilattice__order__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => semilattice_order(C,inf_inf(C),ord_less_eq(C),ord_less(C)) ) ).

% inf.semilattice_order_axioms
tff(fact_5710_min_Osemilattice__order__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => semilattice_order(C,ord_min(C),ord_less_eq(C),ord_less(C)) ) ).

% min.semilattice_order_axioms
tff(fact_5711_entt__def__true,axiom,
    ! [Pa: assn,Q: assn] :
      ( entailst(Pa,Q)
    <=> aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),top_top(assn))),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),top_top(assn))) ) ).

% entt_def_true
tff(fact_5712_entailst__def,axiom,
    ! [A4: assn,B3: assn] :
      ( entailst(A4,B3)
    <=> aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),top_top(assn))) ) ).

% entailst_def
tff(fact_5713_enttI__true,axiom,
    ! [Pa: assn,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),top_top(assn))),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),top_top(assn)))
     => entailst(Pa,Q) ) ).

% enttI_true
tff(fact_5714_entt__refl,axiom,
    ! [A4: assn] : entailst(A4,A4) ).

% entt_refl
tff(fact_5715_entt__true,axiom,
    ! [A4: assn] : entailst(A4,top_top(assn)) ).

% entt_true
tff(fact_5716_entt__emp,axiom,
    ! [A4: assn] : entailst(A4,one_one(assn)) ).

% entt_emp
tff(fact_5717_entt__star__true__simp_I2_J,axiom,
    ! [A4: assn,B3: assn] :
      ( entailst(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),top_top(assn)),B3)
    <=> entailst(A4,B3) ) ).

% entt_star_true_simp(2)
tff(fact_5718_entt__star__true__simp_I1_J,axiom,
    ! [A4: assn,B3: assn] :
      ( entailst(A4,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),top_top(assn)))
    <=> entailst(A4,B3) ) ).

% entt_star_true_simp(1)
tff(fact_5719_entt__disjI2__direct,axiom,
    ! [B3: assn,A4: assn] : entailst(B3,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)) ).

% entt_disjI2_direct
tff(fact_5720_entt__disjI1__direct,axiom,
    ! [A4: assn,B3: assn] : entailst(A4,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3)) ).

% entt_disjI1_direct
tff(fact_5721_entt__disjI2_H,axiom,
    ! [A4: assn,C4: assn,B3: assn] :
      ( entailst(A4,C4)
     => entailst(A4,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),B3),C4)) ) ).

% entt_disjI2'
tff(fact_5722_entt__disjI1_H,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( entailst(A4,B3)
     => entailst(A4,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),B3),C4)) ) ).

% entt_disjI1'
tff(fact_5723_entt__disjD2,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( entailst(aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3),C4)
     => entailst(B3,C4) ) ).

% entt_disjD2
tff(fact_5724_entt__disjD1,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( entailst(aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3),C4)
     => entailst(A4,C4) ) ).

% entt_disjD1
tff(fact_5725_entt__disjE,axiom,
    ! [A4: assn,M: assn,B3: assn] :
      ( entailst(A4,M)
     => ( entailst(B3,M)
       => entailst(aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),A4),B3),M) ) ) ).

% entt_disjE
tff(fact_5726_entt__frame__fwd,axiom,
    ! [Pa: assn,Q: assn,A4: assn,F2: assn,B3: assn] :
      ( entailst(Pa,Q)
     => ( entailst(A4,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),F2))
       => ( entailst(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Q),F2),B3)
         => entailst(A4,B3) ) ) ) ).

% entt_frame_fwd
tff(fact_5727_entt__star__mono,axiom,
    ! [A4: assn,B3: assn,C4: assn,D2: assn] :
      ( entailst(A4,B3)
     => ( entailst(C4,D2)
       => entailst(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),C4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),D2)) ) ) ).

% entt_star_mono
tff(fact_5728_entt__fr__refl,axiom,
    ! [F2: assn,F7: assn,A4: assn] :
      ( entailst(F2,F7)
     => entailst(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),F2),A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),F7),A4)) ) ).

% entt_fr_refl
tff(fact_5729_entt__fr__drop,axiom,
    ! [F2: assn,F7: assn,A4: assn] :
      ( entailst(F2,F7)
     => entailst(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),F2),A4),F7) ) ).

% entt_fr_drop
tff(fact_5730_entt__trans,axiom,
    ! [A4: assn,B3: assn,C4: assn] :
      ( entailst(A4,B3)
     => ( entailst(B3,C4)
       => entailst(A4,C4) ) ) ).

% entt_trans
tff(fact_5731_ent__imp__entt,axiom,
    ! [Pa: assn,Q: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),Q)
     => entailst(Pa,Q) ) ).

% ent_imp_entt
tff(fact_5732_enttD,axiom,
    ! [A4: assn,B3: assn] :
      ( entailst(A4,B3)
     => aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),top_top(assn))) ) ).

% enttD
tff(fact_5733_enttI,axiom,
    ! [A4: assn,B3: assn] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,A4),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),B3),top_top(assn)))
     => entailst(A4,B3) ) ).

% enttI
tff(fact_5734_comp__fun__commute_Ofoldr__conv__foldl,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(D,D)),Xs: list(C),A3: D] :
      ( finite6289374366891150609ommute(C,D,F)
     => ( aa(D,D,aa(list(C),fun(D,D),aa(fun(C,fun(D,D)),fun(list(C),fun(D,D)),foldr(C,D),F),Xs),A3) = aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),aTP_Lamp_st(fun(C,fun(D,D)),fun(D,fun(C,D)),F)),A3),Xs) ) ) ).

% comp_fun_commute.foldr_conv_foldl
tff(fact_5735_numeral__sqr,axiom,
    ! [C: $tType] :
      ( semiring_numeral(C)
     => ! [K: num] : aa(num,C,numeral_numeral(C),sqr(K)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),K)),aa(num,C,numeral_numeral(C),K)) ) ).

% numeral_sqr
tff(fact_5736_in__range_Oelims_I3_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,X)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ! [X2: nat] :
                ( member2(nat,X2,As)
               => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),lim(product_unit,H2)) ) ) ) ).

% in_range.elims(3)
tff(fact_5737_comp__fun__commute__insort,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => finite6289374366891150609ommute(C,list(C),linorder_insort_key(C,C,aTP_Lamp_az(C,C))) ) ).

% comp_fun_commute_insort
tff(fact_5738_comp__fun__commute_Ofoldl__f__commute,axiom,
    ! [D: $tType,C: $tType,F: fun(C,fun(D,D)),A3: C,B2: D,Xs: list(C)] :
      ( finite6289374366891150609ommute(C,D,F)
     => ( aa(D,D,aa(C,fun(D,D),F,A3),aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),aTP_Lamp_st(fun(C,fun(D,D)),fun(D,fun(C,D)),F)),B2),Xs)) = aa(list(C),D,aa(D,fun(list(C),D),aa(fun(D,fun(C,D)),fun(D,fun(list(C),D)),foldl(D,C),aTP_Lamp_st(fun(C,fun(D,D)),fun(D,fun(C,D)),F)),aa(D,D,aa(C,fun(D,D),F,A3),B2)),Xs) ) ) ).

% comp_fun_commute.foldl_f_commute
tff(fact_5739_in__range_Osimps,axiom,
    ! [H: heap_ext(product_unit),As2: set(nat)] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
    <=> ! [X4: nat] :
          ( member2(nat,X4,As2)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),lim(product_unit,H)) ) ) ).

% in_range.simps
tff(fact_5740_in__range_Oelims_I1_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,X)
      <=> (Y) )
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ( (Y)
            <=> ~ ! [X4: nat] :
                    ( member2(nat,X4,As)
                   => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),lim(product_unit,H2)) ) ) ) ) ).

% in_range.elims(1)
tff(fact_5741_in__range_Oelims_I2_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,X)
     => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
            ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
           => ~ ! [X3: nat] :
                  ( member2(nat,X3,As)
                 => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X3),lim(product_unit,H2)) ) ) ) ).

% in_range.elims(2)
tff(fact_5742_czeroE,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,C))] :
      ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),R3),bNF_Cardinal_czero(D)),bNF_Wellorder_ordIso(C,D))
     => ( field2(C,R3) = bot_bot(set(C)) ) ) ).

% czeroE
tff(fact_5743_type__definition__assn,axiom,
    type_definition(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,abs_assn,collect(fun(product_prod(heap_ext(product_unit),set(nat)),$o),proper)) ).

% type_definition_assn
tff(fact_5744_sngr__assn__raw_Oelims_I3_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: ref(C),Xa: C,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,X,Xa),Xb)
         => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
               => ( ( ref_get(C,H2,X) = Xa )
                  & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,X)),bot_bot(set(nat))) )
                  & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,X)),lim(product_unit,H2)) ) ) ) ) ).

% sngr_assn_raw.elims(3)
tff(fact_5745_relH__ref,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit),R3: ref(C)] :
          ( relH(As2,H,H4)
         => ( member2(nat,addr_of_ref(C,R3),As2)
           => ( ref_get(C,H,R3) = ref_get(C,H4,R3) ) ) ) ) ).

% relH_ref
tff(fact_5746_sngr__assn__raw_Osimps,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: ref(C),X: C,H: heap_ext(product_unit),As2: set(nat)] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,R3,X),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
        <=> ( ( ref_get(C,H,R3) = X )
            & ( As2 = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,R3)),bot_bot(set(nat))) )
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,R3)),lim(product_unit,H)) ) ) ) ).

% sngr_assn_raw.simps
tff(fact_5747_sngr__assn__raw_Oelims_I1_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: ref(C),Xa: C,Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,X,Xa),Xb)
          <=> (Y) )
         => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
               => ( (Y)
                <=> ~ ( ( ref_get(C,H2,X) = Xa )
                      & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,X)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,X)),lim(product_unit,H2)) ) ) ) ) ) ).

% sngr_assn_raw.elims(1)
tff(fact_5748_sngr__assn__raw_Oelims_I2_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: ref(C),Xa: C,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,X,Xa),Xb)
         => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
               => ~ ( ( ref_get(C,H2,X) = Xa )
                    & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,X)),bot_bot(set(nat))) )
                    & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,X)),lim(product_unit,H2)) ) ) ) ) ).

% sngr_assn_raw.elims(2)
tff(fact_5749_sngr__assn__raw_Opelims_I1_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: ref(C),Xa: C,Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,X,Xa),Xb)
          <=> (Y) )
         => ( accp(product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(C),aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                  ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
                 => ( ( (Y)
                    <=> ( ( ref_get(C,H2,X) = Xa )
                        & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,X)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,X)),lim(product_unit,H2)) ) )
                   => ~ accp(product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(C),aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)))) ) ) ) ) ) ).

% sngr_assn_raw.pelims(1)
tff(fact_5750_sngr__assn__raw_Opelims_I2_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: ref(C),Xa: C,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,X,Xa),Xb)
         => ( accp(product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(C),aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                  ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
                 => ( accp(product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(C),aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
                   => ~ ( ( ref_get(C,H2,X) = Xa )
                        & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,X)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,X)),lim(product_unit,H2)) ) ) ) ) ) ) ).

% sngr_assn_raw.pelims(2)
tff(fact_5751_sngr__assn__raw_Opelims_I3_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: ref(C),Xa: C,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,sngr_assn_raw(C,X,Xa),Xb)
         => ( accp(product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(C),aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                  ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
                 => ( accp(product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(C),aa(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(C),fun(product_prod(C,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(C),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat))),aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(C,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(C,product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
                   => ( ( ref_get(C,H2,X) = Xa )
                      & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_ref(C,X)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(C,X)),lim(product_unit,H2)) ) ) ) ) ) ) ).

% sngr_assn_raw.pelims(3)
tff(fact_5752_relH__set__ref,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: ref(C),As2: set(nat),H: heap_ext(product_unit),X: C] :
          ( ~ member2(nat,addr_of_ref(C,R3),As2)
         => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
           => relH(As2,H,ref_set(C,R3,X,H)) ) ) ) ).

% relH_set_ref
tff(fact_5753_Cnotzero__imp__not__empty,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( ( ~ member2(product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),product_Pair(set(product_prod(C,C)),set(product_prod(C,C))),R3),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(C,C))
        & bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3) )
     => ( field2(C,R3) != bot_bot(set(C)) ) ) ).

% Cnotzero_imp_not_empty
tff(fact_5754_czeroI,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
     => ( ( field2(C,R3) = bot_bot(set(C)) )
       => member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),R3),bNF_Cardinal_czero(D)),bNF_Wellorder_ordIso(C,D)) ) ) ).

% czeroI
tff(fact_5755_Card__order__iff__Restr__underS,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( order_well_order_on(C,field2(C,R3),R3)
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
      <=> ! [X4: C] :
            ( member2(C,X4,field2(C,R3))
           => member2(product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),product_Pair(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),product_Sigma(C,C,order_underS(C,R3,X4),aa(C,fun(C,set(C)),aTP_Lamp_qj(set(product_prod(C,C)),fun(C,fun(C,set(C))),R3),X4)))),bNF_Ca6860139660246222851ard_of(C,field2(C,R3))),bNF_We4044943003108391690rdLess(C,C)) ) ) ) ).

% Card_order_iff_Restr_underS
tff(fact_5756_cexp__mono2_H,axiom,
    ! [D: $tType,E2: $tType,C: $tType,P24: set(product_prod(C,C)),R2: set(product_prod(D,D)),Q2: set(product_prod(E2,E2))] :
      ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),P24),R2),bNF_Wellorder_ordLeq(C,D))
     => ( bNF_Ca8970107618336181345der_on(E2,field2(E2,Q2),Q2)
       => ( ( ( field2(C,P24) = bot_bot(set(C)) )
           => ( field2(D,R2) = bot_bot(set(D)) ) )
         => member2(product_prod(set(product_prod(fun(C,E2),fun(C,E2))),set(product_prod(fun(D,E2),fun(D,E2)))),aa(set(product_prod(fun(D,E2),fun(D,E2))),product_prod(set(product_prod(fun(C,E2),fun(C,E2))),set(product_prod(fun(D,E2),fun(D,E2)))),aa(set(product_prod(fun(C,E2),fun(C,E2))),fun(set(product_prod(fun(D,E2),fun(D,E2))),product_prod(set(product_prod(fun(C,E2),fun(C,E2))),set(product_prod(fun(D,E2),fun(D,E2))))),product_Pair(set(product_prod(fun(C,E2),fun(C,E2))),set(product_prod(fun(D,E2),fun(D,E2)))),bNF_Cardinal_cexp(E2,C,Q2,P24)),bNF_Cardinal_cexp(E2,D,Q2,R2)),bNF_Wellorder_ordLeq(fun(C,E2),fun(D,E2))) ) ) ) ).

% cexp_mono2'
tff(fact_5757_Card__order__Times__infinite,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(C,C)),P3: set(product_prod(D,D))] :
      ( ~ aa(set(C),$o,finite_finite2(C),field2(C,R3))
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
       => ( ( field2(D,P3) != bot_bot(set(D)) )
         => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),P3),R3),bNF_Wellorder_ordLeq(D,C))
           => ( member2(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,field2(C,R3),aTP_Lamp_su(set(product_prod(D,D)),fun(C,set(D)),P3)))),R3),bNF_Wellorder_ordIso(product_prod(C,D),C))
              & member2(product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),aa(set(product_prod(product_prod(D,C),product_prod(D,C))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,field2(D,P3),aTP_Lamp_sv(set(product_prod(C,C)),fun(D,set(C)),R3)))),R3),bNF_Wellorder_ordIso(product_prod(D,C),C)) ) ) ) ) ) ).

% Card_order_Times_infinite
tff(fact_5758_card__of__bool,axiom,
    ! [C: $tType,A1: C,A22: C] :
      ( ( A1 != A22 )
     => member2(product_prod(set(product_prod($o,$o)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod($o,$o)),set(product_prod(C,C))),aa(set(product_prod($o,$o)),fun(set(product_prod(C,C)),product_prod(set(product_prod($o,$o)),set(product_prod(C,C)))),product_Pair(set(product_prod($o,$o)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of($o,top_top(set($o)))),bNF_Ca6860139660246222851ard_of(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A1),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A22),bot_bot(set(C)))))),bNF_Wellorder_ordIso($o,C)) ) ).

% card_of_bool
tff(fact_5759_card__of__empty__ordIso,axiom,
    ! [D: $tType,C: $tType] : member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),bNF_Ca6860139660246222851ard_of(D,bot_bot(set(D)))),bNF_Wellorder_ordIso(C,D)) ).

% card_of_empty_ordIso
tff(fact_5760_card__of__empty2,axiom,
    ! [D: $tType,C: $tType,A4: set(C)] :
      ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(D,bot_bot(set(D)))),bNF_Wellorder_ordIso(C,D))
     => ( A4 = bot_bot(set(C)) ) ) ).

% card_of_empty2
tff(fact_5761_card__of__Times__infinite__simps_I4_J,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(D)] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ( ( B3 != bot_bot(set(D)) )
       => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(D,C))
         => member2(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,B3,aTP_Lamp_an(set(C),fun(D,set(C)),A4)))),bNF_Wellorder_ordIso(C,product_prod(D,C))) ) ) ) ).

% card_of_Times_infinite_simps(4)
tff(fact_5762_card__of__Times__infinite__simps_I3_J,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ( ( B3 != bot_bot(set(D)) )
       => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(D,C))
         => member2(product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),aa(set(product_prod(product_prod(D,C),product_prod(D,C))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,B3,aTP_Lamp_an(set(C),fun(D,set(C)),A4)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordIso(product_prod(D,C),C)) ) ) ) ).

% card_of_Times_infinite_simps(3)
tff(fact_5763_card__of__Times__infinite__simps_I2_J,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(D)] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ( ( B3 != bot_bot(set(D)) )
       => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(D,C))
         => member2(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Wellorder_ordIso(C,product_prod(C,D))) ) ) ) ).

% card_of_Times_infinite_simps(2)
tff(fact_5764_card__of__Times__infinite__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(D)] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ( ( B3 != bot_bot(set(D)) )
       => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(D,C))
         => member2(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordIso(product_prod(C,D),C)) ) ) ) ).

% card_of_Times_infinite_simps(1)
tff(fact_5765_card__of__Times__infinite,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ~ aa(set(C),$o,finite_finite2(C),A4)
     => ( ( B3 != bot_bot(set(D)) )
       => ( member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(D,C))
         => ( member2(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordIso(product_prod(C,D),C))
            & member2(product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),aa(set(product_prod(product_prod(D,C),product_prod(D,C))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(D,C),product_prod(D,C))),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,B3,aTP_Lamp_an(set(C),fun(D,set(C)),A4)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordIso(product_prod(D,C),C)) ) ) ) ) ).

% card_of_Times_infinite
tff(fact_5766_card__of__empty,axiom,
    ! [D: $tType,C: $tType,A4: set(D)] : member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),bNF_Ca6860139660246222851ard_of(D,A4)),bNF_Wellorder_ordLeq(C,D)) ).

% card_of_empty
tff(fact_5767_card__of__empty3,axiom,
    ! [D: $tType,C: $tType,A4: set(C)] :
      ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(D,bot_bot(set(D)))),bNF_Wellorder_ordLeq(C,D))
     => ( A4 = bot_bot(set(C)) ) ) ).

% card_of_empty3
tff(fact_5768_card__of__Times1,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => member2(product_prod(set(product_prod(D,D)),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(D,D)),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(D,D)),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(D,D)),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(D,D)),set(product_prod(product_prod(D,C),product_prod(D,C)))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,B3,aTP_Lamp_an(set(C),fun(D,set(C)),A4)))),bNF_Wellorder_ordLeq(D,product_prod(D,C))) ) ).

% card_of_Times1
tff(fact_5769_card__of__Times2,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => member2(product_prod(set(product_prod(D,D)),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(D,D)),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(D,D)),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(D,D)),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(D,D)),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Wellorder_ordLeq(D,product_prod(C,D))) ) ).

% card_of_Times2
tff(fact_5770_czero__def,axiom,
    ! [C: $tType] : bNF_Cardinal_czero(C) = bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C))) ).

% czero_def
tff(fact_5771_card__of__ordLeq2,axiom,
    ! [D: $tType,C: $tType,A4: set(C),B3: set(D)] :
      ( ( A4 != bot_bot(set(C)) )
     => ( ? [G3: fun(D,C)] : aa(set(D),set(C),image2(D,C,G3),B3) = A4
      <=> member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Wellorder_ordLeq(C,D)) ) ) ).

% card_of_ordLeq2
tff(fact_5772_card__of__singl__ordLeq,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B2: D] :
      ( ( A4 != bot_bot(set(C)) )
     => member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),B2),bot_bot(set(D))))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(D,C)) ) ).

% card_of_singl_ordLeq
tff(fact_5773_card__of__ordLess2,axiom,
    ! [C: $tType,D: $tType,B3: set(C),A4: set(D)] :
      ( ( B3 != bot_bot(set(C)) )
     => ( ~ ? [F6: fun(D,C)] : aa(set(D),set(C),image2(D,C,F6),A4) = B3
      <=> member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,A4)),bNF_Ca6860139660246222851ard_of(C,B3)),bNF_We4044943003108391690rdLess(D,C)) ) ) ).

% card_of_ordLess2
tff(fact_5774_Card__order__Times1,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,C)),B3: set(D)] :
      ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
     => ( ( B3 != bot_bot(set(D)) )
       => member2(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(C,D),product_prod(C,D)))),R3),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,field2(C,R3),aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Wellorder_ordLeq(C,product_prod(C,D))) ) ) ).

% Card_order_Times1
tff(fact_5775_Card__order__Times2,axiom,
    ! [D: $tType,C: $tType,R3: set(product_prod(C,C)),A4: set(D)] :
      ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
     => ( ( A4 != bot_bot(set(D)) )
       => member2(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(D,C),product_prod(D,C)))),R3),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,A4,aTP_Lamp_sv(set(product_prod(C,C)),fun(D,set(C)),R3)))),bNF_Wellorder_ordLeq(C,product_prod(D,C))) ) ) ).

% Card_order_Times2
tff(fact_5776_Card__order__empty,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
     => member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,bot_bot(set(D)))),R3),bNF_Wellorder_ordLeq(D,C)) ) ).

% Card_order_empty
tff(fact_5777_card__of__ordIso__czero__iff__empty,axiom,
    ! [D: $tType,C: $tType,A4: set(C)] :
      ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Cardinal_czero(D)),bNF_Wellorder_ordIso(C,D))
    <=> ( A4 = bot_bot(set(C)) ) ) ).

% card_of_ordIso_czero_iff_empty
tff(fact_5778_Card__order__singl__ordLeq,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(C,C)),B2: D] :
      ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
     => ( ( field2(C,R3) != bot_bot(set(C)) )
       => member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),B2),bot_bot(set(D))))),R3),bNF_Wellorder_ordLeq(D,C)) ) ) ).

% Card_order_singl_ordLeq
tff(fact_5779_card__of__empty1,axiom,
    ! [C: $tType,D: $tType,R3: set(product_prod(C,C))] :
      ( ( order_well_order_on(C,field2(C,R3),R3)
        | bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3) )
     => member2(product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C))),aa(set(product_prod(D,D)),fun(set(product_prod(C,C)),product_prod(set(product_prod(D,D)),set(product_prod(C,C)))),product_Pair(set(product_prod(D,D)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(D,bot_bot(set(D)))),R3),bNF_Wellorder_ordLeq(D,C)) ) ).

% card_of_empty1
tff(fact_5780_cexp__mono_H,axiom,
    ! [D: $tType,F4: $tType,C: $tType,E2: $tType,P13: set(product_prod(C,C)),R1: set(product_prod(D,D)),P24: set(product_prod(E2,E2)),R2: set(product_prod(F4,F4))] :
      ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),P13),R1),bNF_Wellorder_ordLeq(C,D))
     => ( member2(product_prod(set(product_prod(E2,E2)),set(product_prod(F4,F4))),aa(set(product_prod(F4,F4)),product_prod(set(product_prod(E2,E2)),set(product_prod(F4,F4))),aa(set(product_prod(E2,E2)),fun(set(product_prod(F4,F4)),product_prod(set(product_prod(E2,E2)),set(product_prod(F4,F4)))),product_Pair(set(product_prod(E2,E2)),set(product_prod(F4,F4))),P24),R2),bNF_Wellorder_ordLeq(E2,F4))
       => ( ( ( field2(E2,P24) = bot_bot(set(E2)) )
           => ( field2(F4,R2) = bot_bot(set(F4)) ) )
         => member2(product_prod(set(product_prod(fun(E2,C),fun(E2,C))),set(product_prod(fun(F4,D),fun(F4,D)))),aa(set(product_prod(fun(F4,D),fun(F4,D))),product_prod(set(product_prod(fun(E2,C),fun(E2,C))),set(product_prod(fun(F4,D),fun(F4,D)))),aa(set(product_prod(fun(E2,C),fun(E2,C))),fun(set(product_prod(fun(F4,D),fun(F4,D))),product_prod(set(product_prod(fun(E2,C),fun(E2,C))),set(product_prod(fun(F4,D),fun(F4,D))))),product_Pair(set(product_prod(fun(E2,C),fun(E2,C))),set(product_prod(fun(F4,D),fun(F4,D)))),bNF_Cardinal_cexp(C,E2,P13,P24)),bNF_Cardinal_cexp(D,F4,R1,R2)),bNF_Wellorder_ordLeq(fun(E2,C),fun(F4,D))) ) ) ) ).

% cexp_mono'
tff(fact_5781_card__of__Plus__Times__aux,axiom,
    ! [D: $tType,C: $tType,A1: C,A22: C,A4: set(C),B3: set(D)] :
      ( ( ( A1 != A22 )
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A1),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A22),bot_bot(set(C))))),A4) )
     => ( member2(product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D))),aa(set(product_prod(C,C)),fun(set(product_prod(D,D)),product_prod(set(product_prod(C,C)),set(product_prod(D,D)))),product_Pair(set(product_prod(C,C)),set(product_prod(D,D))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(D,B3)),bNF_Wellorder_ordLeq(C,D))
       => member2(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,A4,B3))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Wellorder_ordLeq(sum_sum(C,D),product_prod(C,D))) ) ) ).

% card_of_Plus_Times_aux
tff(fact_5782_card__of__Plus__Times,axiom,
    ! [D: $tType,C: $tType,A1: C,A22: C,A4: set(C),B1: D,B22: D,B3: set(D)] :
      ( ( ( A1 != A22 )
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A1),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A22),bot_bot(set(C))))),A4) )
     => ( ( ( B1 != B22 )
          & aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),B1),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),B22),bot_bot(set(D))))),B3) )
       => member2(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,A4,B3))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mb(set(D),fun(C,set(D)),B3)))),bNF_Wellorder_ordLeq(sum_sum(C,D),product_prod(C,D))) ) ) ).

% card_of_Plus_Times
tff(fact_5783_snga__assn__raw_Oelims_I3_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: array(C),Xa: list(C),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,X,Xa),Xb)
         => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
               => ( ( array_get(C,H2,X) = Xa )
                  & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,X)),bot_bot(set(nat))) )
                  & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,X)),lim(product_unit,H2)) ) ) ) ) ).

% snga_assn_raw.elims(3)
tff(fact_5784_card__of__Plus__empty2,axiom,
    ! [D: $tType,C: $tType,A4: set(C)] : member2(product_prod(set(product_prod(C,C)),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(C,C)),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(C,C)),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(C,C)),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(C,C)),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(sum_sum(D,C),sum_Plus(D,C,bot_bot(set(D)),A4))),bNF_Wellorder_ordIso(C,sum_sum(D,C))) ).

% card_of_Plus_empty2
tff(fact_5785_card__of__Plus__empty1,axiom,
    ! [D: $tType,C: $tType,A4: set(C)] : member2(product_prod(set(product_prod(C,C)),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(C,C)),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(C,C)),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(C,C)),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(C,C)),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,A4,bot_bot(set(D))))),bNF_Wellorder_ordIso(C,sum_sum(C,D))) ).

% card_of_Plus_empty1
tff(fact_5786_relH__array,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit),R3: array(C)] :
          ( relH(As2,H,H4)
         => ( member2(nat,addr_of_array(C,R3),As2)
           => ( array_get(C,H,R3) = array_get(C,H4,R3) ) ) ) ) ).

% relH_array
tff(fact_5787_snga__assn__raw_Osimps,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: array(C),X: list(C),H: heap_ext(product_unit),As2: set(nat)] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,R3,X),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
        <=> ( ( array_get(C,H,R3) = X )
            & ( As2 = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,R3)),bot_bot(set(nat))) )
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,R3)),lim(product_unit,H)) ) ) ) ).

% snga_assn_raw.simps
tff(fact_5788_snga__assn__raw_Oelims_I1_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: array(C),Xa: list(C),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,X,Xa),Xb)
          <=> (Y) )
         => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
               => ( (Y)
                <=> ~ ( ( array_get(C,H2,X) = Xa )
                      & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,X)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,X)),lim(product_unit,H2)) ) ) ) ) ) ).

% snga_assn_raw.elims(1)
tff(fact_5789_snga__assn__raw_Oelims_I2_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: array(C),Xa: list(C),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,X,Xa),Xb)
         => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
               => ~ ( ( array_get(C,H2,X) = Xa )
                    & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,X)),bot_bot(set(nat))) )
                    & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,X)),lim(product_unit,H2)) ) ) ) ) ).

% snga_assn_raw.elims(2)
tff(fact_5790_Plus__eq__empty__conv,axiom,
    ! [C: $tType,D: $tType,A4: set(C),B3: set(D)] :
      ( ( sum_Plus(C,D,A4,B3) = bot_bot(set(sum_sum(C,D))) )
    <=> ( ( A4 = bot_bot(set(C)) )
        & ( B3 = bot_bot(set(D)) ) ) ) ).

% Plus_eq_empty_conv
tff(fact_5791_snga__assn__raw_Opelims_I1_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: array(C),Xa: list(C),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,X,Xa),Xb)
          <=> (Y) )
         => ( accp(product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(C),aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                  ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
                 => ( ( (Y)
                    <=> ( ( array_get(C,H2,X) = Xa )
                        & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,X)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,X)),lim(product_unit,H2)) ) )
                   => ~ accp(product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(C),aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)))) ) ) ) ) ) ).

% snga_assn_raw.pelims(1)
tff(fact_5792_snga__assn__raw_Opelims_I2_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: array(C),Xa: list(C),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,X,Xa),Xb)
         => ( accp(product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(C),aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                  ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
                 => ( accp(product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(C),aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
                   => ~ ( ( array_get(C,H2,X) = Xa )
                        & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,X)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,X)),lim(product_unit,H2)) ) ) ) ) ) ) ).

% snga_assn_raw.pelims(2)
tff(fact_5793_snga__assn__raw_Opelims_I3_J,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: array(C),Xa: list(C),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,snga_assn_raw(C,X,Xa),Xb)
         => ( accp(product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(C),aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
                  ( ( Xb = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
                 => ( accp(product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(C),aa(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),aa(array(C),fun(product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(C),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),X),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat))),aa(list(C),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(C),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(C),product_prod(heap_ext(product_unit),set(nat))),Xa),aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))))
                   => ( ( array_get(C,H2,X) = Xa )
                      & ( As = aa(set(nat),set(nat),aa(nat,fun(set(nat),set(nat)),insert2(nat),addr_of_array(C,X)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(C,X)),lim(product_unit,H2)) ) ) ) ) ) ) ).

% snga_assn_raw.pelims(3)
tff(fact_5794_relH__set__array,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: array(C),As2: set(nat),H: heap_ext(product_unit),X: list(C)] :
          ( ~ member2(nat,addr_of_array(C,R3),As2)
         => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
           => relH(As2,H,array_set(C,R3,X,H)) ) ) ) ).

% relH_set_array
tff(fact_5795_pure__assn__raw_Opelims_I1_J,axiom,
    ! [C: $tType,D: $tType,X: $o,Xa: product_prod(C,set(D)),Y: $o] :
      ( ( aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(X)),Xa)
      <=> (Y) )
     => ( accp(product_prod($o,product_prod(C,set(D))),pure_assn_raw_rel(C,D),aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(X)),Xa))
       => ~ ! [H2: C,As: set(D)] :
              ( ( Xa = aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As) )
             => ( ( (Y)
                <=> ( ( As = bot_bot(set(D)) )
                    & (X) ) )
               => ~ accp(product_prod($o,product_prod(C,set(D))),pure_assn_raw_rel(C,D),aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(X)),aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As))) ) ) ) ) ).

% pure_assn_raw.pelims(1)
tff(fact_5796_pure__assn__raw_Opelims_I2_J,axiom,
    ! [D: $tType,C: $tType,X: $o,Xa: product_prod(C,set(D))] :
      ( aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(X)),Xa)
     => ( accp(product_prod($o,product_prod(C,set(D))),pure_assn_raw_rel(C,D),aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(X)),Xa))
       => ~ ! [H2: C,As: set(D)] :
              ( ( Xa = aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As) )
             => ( accp(product_prod($o,product_prod(C,set(D))),pure_assn_raw_rel(C,D),aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(X)),aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As)))
               => ~ ( ( As = bot_bot(set(D)) )
                    & (X) ) ) ) ) ) ).

% pure_assn_raw.pelims(2)
tff(fact_5797_pure__assn__raw_Opelims_I3_J,axiom,
    ! [D: $tType,C: $tType,X: $o,Xa: product_prod(C,set(D))] :
      ( ~ aa(product_prod(C,set(D)),$o,pure_assn_raw(C,D,(X)),Xa)
     => ( accp(product_prod($o,product_prod(C,set(D))),pure_assn_raw_rel(C,D),aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(X)),Xa))
       => ~ ! [H2: C,As: set(D)] :
              ( ( Xa = aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As) )
             => ( accp(product_prod($o,product_prod(C,set(D))),pure_assn_raw_rel(C,D),aa(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D))),aa($o,fun(product_prod(C,set(D)),product_prod($o,product_prod(C,set(D)))),product_Pair($o,product_prod(C,set(D))),(X)),aa(set(D),product_prod(C,set(D)),aa(C,fun(set(D),product_prod(C,set(D))),product_Pair(C,set(D)),H2),As)))
               => ( ( As = bot_bot(set(D)) )
                  & (X) ) ) ) ) ) ).

% pure_assn_raw.pelims(3)
tff(fact_5798_prod__list_Ocomm__monoid__list__axioms,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => groups1828464146339083142d_list(C,times_times(C),one_one(C)) ) ).

% prod_list.comm_monoid_list_axioms
tff(fact_5799_list__all__zip__alt,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),As2: list(C),Bs: list(D)] :
      ( list_all_zip(C,D,Pa,As2,Bs)
    <=> ( ( aa(list(C),nat,size_size(list(C)),As2) = aa(list(D),nat,size_size(list(D)),Bs) )
        & ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),As2))
           => aa(D,$o,aa(C,fun(D,$o),Pa,aa(nat,C,nth(C,As2),I2)),aa(nat,D,nth(D,Bs),I2)) ) ) ) ).

% list_all_zip_alt
tff(fact_5800_lazI,axiom,
    ! [C: $tType,D: $tType,A3: list(C),B2: list(D),Pa: fun(C,fun(D,$o))] :
      ( ( aa(list(C),nat,size_size(list(C)),A3) = aa(list(D),nat,size_size(list(D)),B2) )
     => ( ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(D),nat,size_size(list(D)),B2))
           => aa(D,$o,aa(C,fun(D,$o),Pa,aa(nat,C,nth(C,A3),I3)),aa(nat,D,nth(D,B2),I3)) )
       => list_all_zip(C,D,Pa,A3,B2) ) ) ).

% lazI
tff(fact_5801_laz__conj,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),Q: fun(C,fun(D,$o)),A3: list(C),B2: list(D)] :
      ( list_all_zip(C,D,aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aTP_Lamp_sw(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),Pa),Q),A3,B2)
    <=> ( list_all_zip(C,D,Pa,A3,B2)
        & list_all_zip(C,D,Q,A3,B2) ) ) ).

% laz_conj
tff(fact_5802_laz__weak__Pb,axiom,
    ! [C: $tType,D: $tType,Pa: fun(D,$o),A4: list(C),B3: list(D)] :
      ( list_all_zip(C,D,aTP_Lamp_sx(fun(D,$o),fun(C,fun(D,$o)),Pa),A4,B3)
    <=> ( ( aa(list(C),nat,size_size(list(C)),A4) = aa(list(D),nat,size_size(list(D)),B3) )
        & ! [X4: D] :
            ( member2(D,X4,aa(list(D),set(D),set2(D),B3))
           => aa(D,$o,Pa,X4) ) ) ) ).

% laz_weak_Pb
tff(fact_5803_laz__weak__Pa,axiom,
    ! [D: $tType,C: $tType,Pa: fun(C,$o),A4: list(C),B3: list(D)] :
      ( list_all_zip(C,D,aTP_Lamp_sy(fun(C,$o),fun(C,fun(D,$o)),Pa),A4,B3)
    <=> ( ( aa(list(C),nat,size_size(list(C)),A4) = aa(list(D),nat,size_size(list(D)),B3) )
        & ! [X4: C] :
            ( member2(C,X4,aa(list(C),set(C),set2(C),A4))
           => aa(C,$o,Pa,X4) ) ) ) ).

% laz_weak_Pa
tff(fact_5804_list__all__zip__map2,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Pa: fun(C,fun(D,$o)),As2: list(C),F: fun(E2,D),Bs: list(E2)] :
      ( list_all_zip(C,D,Pa,As2,aa(list(E2),list(D),aa(fun(E2,D),fun(list(E2),list(D)),map(E2,D),F),Bs))
    <=> list_all_zip(C,E2,aa(fun(E2,D),fun(C,fun(E2,$o)),aTP_Lamp_nt(fun(C,fun(D,$o)),fun(fun(E2,D),fun(C,fun(E2,$o))),Pa),F),As2,Bs) ) ).

% list_all_zip_map2
tff(fact_5805_list__all__zip__map1,axiom,
    ! [E2: $tType,C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),F: fun(E2,C),As2: list(E2),Bs: list(D)] :
      ( list_all_zip(C,D,Pa,aa(list(E2),list(C),aa(fun(E2,C),fun(list(E2),list(C)),map(E2,C),F),As2),Bs)
    <=> list_all_zip(E2,D,aa(fun(E2,C),fun(E2,fun(D,$o)),aTP_Lamp_nu(fun(C,fun(D,$o)),fun(fun(E2,C),fun(E2,fun(D,$o))),Pa),F),As2,Bs) ) ).

% list_all_zip_map1
tff(fact_5806_laz__len,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),A3: list(C),B2: list(D)] :
      ( list_all_zip(C,D,Pa,A3,B2)
     => ( aa(list(C),nat,size_size(list(C)),A3) = aa(list(D),nat,size_size(list(D)),B2) ) ) ).

% laz_len
tff(fact_5807_laz__swap__ex,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Pa: fun(C,fun(D,fun(E2,$o))),A4: list(C),B3: list(D)] :
      ( list_all_zip(C,D,aTP_Lamp_sz(fun(C,fun(D,fun(E2,$o))),fun(C,fun(D,$o)),Pa),A4,B3)
     => ~ ! [C8: list(E2)] :
            ( list_all_zip(C,E2,aTP_Lamp_ta(fun(C,fun(D,fun(E2,$o))),fun(C,fun(E2,$o)),Pa),A4,C8)
           => ~ list_all_zip(D,E2,aTP_Lamp_tb(fun(C,fun(D,fun(E2,$o))),fun(D,fun(E2,$o)),Pa),B3,C8) ) ) ).

% laz_swap_ex
tff(fact_5808_laz__eq,axiom,
    ! [C: $tType,A3: list(C),B2: list(C)] :
      ( list_all_zip(C,C,fequal(C),A3,B2)
    <=> ( A3 = B2 ) ) ).

% laz_eq
tff(fact_5809_list__all__zip_Osimps_I1_J,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o))] : list_all_zip(C,D,Pa,nil(C),nil(D)) ).

% list_all_zip.simps(1)
tff(fact_5810_list__all__zip_Osimps_I2_J,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),A3: C,As2: list(C),B2: D,Bs: list(D)] :
      ( list_all_zip(C,D,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),As2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B2),Bs))
    <=> ( aa(D,$o,aa(C,fun(D,$o),Pa,A3),B2)
        & list_all_zip(C,D,Pa,As2,Bs) ) ) ).

% list_all_zip.simps(2)
tff(fact_5811_list__all__zip_Osimps_I3_J,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),V: C,Va: list(C)] : ~ list_all_zip(C,D,Pa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va),nil(D)) ).

% list_all_zip.simps(3)
tff(fact_5812_list__all__zip_Osimps_I4_J,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o)),V: D,Va: list(D)] : ~ list_all_zip(C,D,Pa,nil(C),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V),Va)) ).

% list_all_zip.simps(4)
tff(fact_5813_list__all__zip_Oelims_I1_J,axiom,
    ! [D: $tType,C: $tType,X: fun(C,fun(D,$o)),Xa: list(C),Xb: list(D),Y: $o] :
      ( ( list_all_zip(C,D,X,Xa,Xb)
      <=> (Y) )
     => ( ( ( Xa = nil(C) )
         => ( ( Xb = nil(D) )
           => ~ (Y) ) )
       => ( ! [A5: C,As: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
             => ! [B4: D,Bs2: list(D)] :
                  ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2) )
                 => ( (Y)
                  <=> ~ ( aa(D,$o,aa(C,fun(D,$o),X,A5),B4)
                        & list_all_zip(C,D,X,As,Bs2) ) ) ) )
         => ( ( ? [V2: C,Va2: list(C)] : Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)
             => ( ( Xb = nil(D) )
               => (Y) ) )
           => ~ ( ( Xa = nil(C) )
               => ( ? [V2: D,Va2: list(D)] : Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)
                 => (Y) ) ) ) ) ) ) ).

% list_all_zip.elims(1)
tff(fact_5814_list__all__zip_Oelims_I2_J,axiom,
    ! [C: $tType,D: $tType,X: fun(C,fun(D,$o)),Xa: list(C),Xb: list(D)] :
      ( list_all_zip(C,D,X,Xa,Xb)
     => ( ( ( Xa = nil(C) )
         => ( Xb != nil(D) ) )
       => ~ ! [A5: C,As: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
             => ! [B4: D,Bs2: list(D)] :
                  ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2) )
                 => ~ ( aa(D,$o,aa(C,fun(D,$o),X,A5),B4)
                      & list_all_zip(C,D,X,As,Bs2) ) ) ) ) ) ).

% list_all_zip.elims(2)
tff(fact_5815_list__all__zip_Oelims_I3_J,axiom,
    ! [C: $tType,D: $tType,X: fun(C,fun(D,$o)),Xa: list(C),Xb: list(D)] :
      ( ~ list_all_zip(C,D,X,Xa,Xb)
     => ( ! [A5: C,As: list(C)] :
            ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
           => ! [B4: D,Bs2: list(D)] :
                ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2) )
               => ( aa(D,$o,aa(C,fun(D,$o),X,A5),B4)
                  & list_all_zip(C,D,X,As,Bs2) ) ) )
       => ( ( ? [V2: C,Va2: list(C)] : Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)
           => ( Xb != nil(D) ) )
         => ~ ( ( Xa = nil(C) )
             => ! [V2: D,Va2: list(D)] : Xb != aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2) ) ) ) ) ).

% list_all_zip.elims(3)
tff(fact_5816_list__all__zip_Opelims_I3_J,axiom,
    ! [C: $tType,D: $tType,X: fun(C,fun(D,$o)),Xa: list(C),Xb: list(D)] :
      ( ~ list_all_zip(C,D,X,Xa,Xb)
     => ( accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xa),Xb)))
       => ( ! [A5: C,As: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
             => ! [B4: D,Bs2: list(D)] :
                  ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2) )
                 => ( accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2))))
                   => ( aa(D,$o,aa(C,fun(D,$o),X,A5),B4)
                      & list_all_zip(C,D,X,As,Bs2) ) ) ) )
         => ( ! [V2: C,Va2: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
               => ( ( Xb = nil(D) )
                 => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(D)))) ) )
           => ~ ( ( Xa = nil(C) )
               => ! [V2: D,Va2: list(D)] :
                    ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2) )
                   => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)))) ) ) ) ) ) ) ).

% list_all_zip.pelims(3)
tff(fact_5817_list__all__zip_Opelims_I2_J,axiom,
    ! [C: $tType,D: $tType,X: fun(C,fun(D,$o)),Xa: list(C),Xb: list(D)] :
      ( list_all_zip(C,D,X,Xa,Xb)
     => ( accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xa),Xb)))
       => ( ( ( Xa = nil(C) )
           => ( ( Xb = nil(D) )
             => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)))) ) )
         => ~ ! [A5: C,As: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
               => ! [B4: D,Bs2: list(D)] :
                    ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2) )
                   => ( accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2))))
                     => ~ ( aa(D,$o,aa(C,fun(D,$o),X,A5),B4)
                          & list_all_zip(C,D,X,As,Bs2) ) ) ) ) ) ) ) ).

% list_all_zip.pelims(2)
tff(fact_5818_list__all__zip_Opelims_I1_J,axiom,
    ! [C: $tType,D: $tType,X: fun(C,fun(D,$o)),Xa: list(C),Xb: list(D),Y: $o] :
      ( ( list_all_zip(C,D,X,Xa,Xb)
      <=> (Y) )
     => ( accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),Xa),Xb)))
       => ( ( ( Xa = nil(C) )
           => ( ( Xb = nil(D) )
             => ( (Y)
               => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),nil(D)))) ) ) )
         => ( ! [A5: C,As: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
               => ! [B4: D,Bs2: list(D)] :
                    ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2) )
                   => ( ( (Y)
                      <=> ( aa(D,$o,aa(C,fun(D,$o),X,A5),B4)
                          & list_all_zip(C,D,X,As,Bs2) ) )
                     => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B4),Bs2)))) ) ) )
           => ( ! [V2: C,Va2: list(C)] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2) )
                 => ( ( Xb = nil(D) )
                   => ( ~ (Y)
                     => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V2),Va2)),nil(D)))) ) ) )
             => ~ ( ( Xa = nil(C) )
                 => ! [V2: D,Va2: list(D)] :
                      ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2) )
                     => ( ~ (Y)
                       => ~ accp(product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),list_all_zip_rel(C,D),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D))),aa(fun(C,fun(D,$o)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,$o)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,$o)),product_prod(list(C),list(D))),X),aa(list(D),product_prod(list(C),list(D)),aa(list(C),fun(list(D),product_prod(list(C),list(D))),product_Pair(list(C),list(D)),nil(C)),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V2),Va2)))) ) ) ) ) ) ) ) ) ).

% list_all_zip.pelims(1)
tff(fact_5819_lexord__asymmetric,axiom,
    ! [C: $tType,R: set(product_prod(C,C)),A3: list(C),B2: list(C)] :
      ( asym(C,R)
     => ( member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),A3),B2),lexord(C,R))
       => ~ member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),B2),A3),lexord(C,R)) ) ) ).

% lexord_asymmetric
tff(fact_5820_group_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( group(C,F,Z2,Inverse)
     => group_axioms(C,F,Z2,Inverse) ) ).

% group.axioms(2)
tff(fact_5821_ordering__top_Oaxioms_I2_J,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => ordering_top_axioms(C,Less_eq,Top) ) ).

% ordering_top.axioms(2)
tff(fact_5822_asym__lenlex,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( asym(C,R)
     => asym(list(C),lenlex(C,R)) ) ).

% asym_lenlex
tff(fact_5823_group__axioms_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( ! [A5: C] : aa(C,C,aa(C,fun(C,C),F,Z2),A5) = A5
     => ( ! [A5: C] : aa(C,C,aa(C,fun(C,C),F,aa(C,C,Inverse,A5)),A5) = Z2
       => group_axioms(C,F,Z2,Inverse) ) ) ).

% group_axioms.intro
tff(fact_5824_ordering__top__axioms_Ointro,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Top: C] :
      ( ! [A5: C] : aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),Top)
     => ordering_top_axioms(C,Less_eq,Top) ) ).

% ordering_top_axioms.intro
tff(fact_5825_group__axioms__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( group_axioms(C,F,Z2,Inverse)
    <=> ( ! [A6: C] : aa(C,C,aa(C,fun(C,C),F,Z2),A6) = A6
        & ! [A6: C] : aa(C,C,aa(C,fun(C,C),F,aa(C,C,Inverse,A6)),A6) = Z2 ) ) ).

% group_axioms_def
tff(fact_5826_ordering__top__axioms__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Top: C] :
      ( ordering_top_axioms(C,Less_eq,Top)
    <=> ! [A6: C] : aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),Top) ) ).

% ordering_top_axioms_def
tff(fact_5827_lexord__asym,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( asym(C,R)
     => asym(list(C),lexord(C,R)) ) ).

% lexord_asym
tff(fact_5828_asym__lex,axiom,
    ! [C: $tType,R: set(product_prod(C,C))] :
      ( asym(C,R)
     => asym(list(C),lex(C,R)) ) ).

% asym_lex
tff(fact_5829_ordering__top__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C] :
      ( ordering_top(C,Less_eq,Less,Top)
    <=> ( ordering(C,Less_eq,Less)
        & ordering_top_axioms(C,Less_eq,Top) ) ) ).

% ordering_top_def
tff(fact_5830_ordering__top_Ointro,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C] :
      ( ordering(C,Less_eq,Less)
     => ( ordering_top_axioms(C,Less_eq,Top)
       => ordering_top(C,Less_eq,Less,Top) ) ) ).

% ordering_top.intro
tff(fact_5831_group__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( group(C,F,Z2,Inverse)
    <=> ( semigroup(C,F)
        & group_axioms(C,F,Z2,Inverse) ) ) ).

% group_def
tff(fact_5832_sup_Osemigroup__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => semigroup(C,sup_sup(C)) ) ).

% sup.semigroup_axioms
tff(fact_5833_inf_Osemigroup__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => semigroup(C,inf_inf(C)) ) ).

% inf.semigroup_axioms
tff(fact_5834_ordering__top_Oaxioms_I1_J,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),Top: C] :
      ( ordering_top(C,Less_eq,Less,Top)
     => ordering(C,Less_eq,Less) ) ).

% ordering_top.axioms(1)
tff(fact_5835_group_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( group(C,F,Z2,Inverse)
     => semigroup(C,F) ) ).

% group.axioms(1)
tff(fact_5836_add_Osemigroup__axioms,axiom,
    ! [C: $tType] :
      ( semigroup_add(C)
     => semigroup(C,plus_plus(C)) ) ).

% add.semigroup_axioms
tff(fact_5837_min_Osemigroup__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => semigroup(C,ord_min(C)) ) ).

% min.semigroup_axioms
tff(fact_5838_ordering__dualI,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ordering(C,aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Less_eq),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Less))
     => ordering(C,Less_eq,Less) ) ).

% ordering_dualI
tff(fact_5839_ordering__strictI,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ! [A5: C,B4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
        <=> ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
            | ( A5 = B4 ) ) )
     => ( ! [A5: C,B4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
           => ~ aa(C,$o,aa(C,fun(C,$o),Less,B4),A5) )
       => ( ! [A5: C] : ~ aa(C,$o,aa(C,fun(C,$o),Less,A5),A5)
         => ( ! [A5: C,B4: C,C2: C] :
                ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
               => ( aa(C,$o,aa(C,fun(C,$o),Less,B4),C2)
                 => aa(C,$o,aa(C,fun(C,$o),Less,A5),C2) ) )
           => ordering(C,Less_eq,Less) ) ) ) ) ).

% ordering_strictI
tff(fact_5840_semigroup__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semigroup(C,F)
    <=> ! [A6: C,B5: C,C6: C] : aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A6),B5)),C6) = aa(C,C,aa(C,fun(C,C),F,A6),aa(C,C,aa(C,fun(C,C),F,B5),C6)) ) ).

% semigroup_def
tff(fact_5841_ordering_Onot__eq__order__implies__strict,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( ordering(C,Less_eq,Less)
     => ( ( A3 != B2 )
       => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
         => aa(C,$o,aa(C,fun(C,$o),Less,A3),B2) ) ) ) ).

% ordering.not_eq_order_implies_strict
tff(fact_5842_ordering_Ostrict__implies__not__eq,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( ordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
       => ( A3 != B2 ) ) ) ).

% ordering.strict_implies_not_eq
tff(fact_5843_ordering_Ostrict__iff__order,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( ordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
      <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
          & ( A3 != B2 ) ) ) ) ).

% ordering.strict_iff_order
tff(fact_5844_ordering_Oorder__iff__strict,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( ordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
      <=> ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
          | ( A3 = B2 ) ) ) ) ).

% ordering.order_iff_strict
tff(fact_5845_ordering_Oantisym,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( ordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
       => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),A3)
         => ( A3 = B2 ) ) ) ) ).

% ordering.antisym
tff(fact_5846_ordering_Oeq__iff,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( ordering(C,Less_eq,Less)
     => ( ( A3 = B2 )
      <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
          & aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),A3) ) ) ) ).

% ordering.eq_iff
tff(fact_5847_semigroup_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( ! [A5: C,B4: C,C2: C] : aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A5),B4)),C2) = aa(C,C,aa(C,fun(C,C),F,A5),aa(C,C,aa(C,fun(C,C),F,B4),C2))
     => semigroup(C,F) ) ).

% semigroup.intro
tff(fact_5848_semigroup_Oassoc,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C,C3: C] :
      ( semigroup(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3)) ) ) ).

% semigroup.assoc
tff(fact_5849_mult_Osemigroup__axioms,axiom,
    ! [C: $tType] :
      ( semigroup_mult(C)
     => semigroup(C,times_times(C)) ) ).

% mult.semigroup_axioms
tff(fact_5850_append_Osemigroup__axioms,axiom,
    ! [C: $tType] : semigroup(list(C),append(C)) ).

% append.semigroup_axioms
tff(fact_5851_max_Osemigroup__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => semigroup(C,ord_max(C)) ) ).

% max.semigroup_axioms
tff(fact_5852_monoid_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( monoid(C,F,Z2)
     => semigroup(C,F) ) ).

% monoid.axioms(1)
tff(fact_5853_order_Oordering__axioms,axiom,
    ! [C: $tType] :
      ( order(C)
     => ordering(C,ord_less_eq(C),ord_less(C)) ) ).

% order.ordering_axioms
tff(fact_5854_dual__order_Oordering__axioms,axiom,
    ! [C: $tType] :
      ( order(C)
     => ordering(C,aTP_Lamp_tc(C,fun(C,$o)),aTP_Lamp_td(C,fun(C,$o))) ) ).

% dual_order.ordering_axioms
tff(fact_5855_group_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,Inverse: fun(C,C)] :
      ( semigroup(C,F)
     => ( group_axioms(C,F,Z2,Inverse)
       => group(C,F,Z2,Inverse) ) ) ).

% group.intro
tff(fact_5856_monoid__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( monoid(C,F,Z2)
    <=> ( semigroup(C,F)
        & monoid_axioms(C,F,Z2) ) ) ).

% monoid_def
tff(fact_5857_monoid_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( semigroup(C,F)
     => ( monoid_axioms(C,F,Z2)
       => monoid(C,F,Z2) ) ) ).

% monoid.intro
tff(fact_5858_ID_Opred__set,axiom,
    ! [C: $tType,Pa: fun(C,$o),X3: C] :
      ( aa(C,$o,bNF_id_bnf(fun(C,$o),Pa),X3)
    <=> ! [Xa2: C] :
          ( member2(C,Xa2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X3),bot_bot(set(C))))
         => aa(C,$o,Pa,Xa2) ) ) ).

% ID.pred_set
tff(fact_5859_monoid__axioms_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( ! [A5: C] : aa(C,C,aa(C,fun(C,C),F,Z2),A5) = A5
     => ( ! [A5: C] : aa(C,C,aa(C,fun(C,C),F,A5),Z2) = A5
       => monoid_axioms(C,F,Z2) ) ) ).

% monoid_axioms.intro
tff(fact_5860_monoid__axioms__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( monoid_axioms(C,F,Z2)
    <=> ( ! [A6: C] : aa(C,C,aa(C,fun(C,C),F,Z2),A6) = A6
        & ! [A6: C] : aa(C,C,aa(C,fun(C,C),F,A6),Z2) = A6 ) ) ).

% monoid_axioms_def
tff(fact_5861_ID_Opred__mono__strong,axiom,
    ! [C: $tType,Pa: fun(C,$o),X: C,Paa: fun(C,$o)] :
      ( aa(C,$o,bNF_id_bnf(fun(C,$o),Pa),X)
     => ( ! [Z4: C] :
            ( member2(C,Z4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))
           => ( aa(C,$o,Pa,Z4)
             => aa(C,$o,Paa,Z4) ) )
       => aa(C,$o,bNF_id_bnf(fun(C,$o),Paa),X) ) ) ).

% ID.pred_mono_strong
tff(fact_5862_ID_Opred__cong,axiom,
    ! [C: $tType,X: C,Ya: C,Pa: fun(C,$o),Paa: fun(C,$o)] :
      ( ( X = Ya )
     => ( ! [Z4: C] :
            ( member2(C,Z4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Ya),bot_bot(set(C))))
           => ( aa(C,$o,Pa,Z4)
            <=> aa(C,$o,Paa,Z4) ) )
       => ( aa(C,$o,bNF_id_bnf(fun(C,$o),Pa),X)
        <=> aa(C,$o,bNF_id_bnf(fun(C,$o),Paa),Ya) ) ) ) ).

% ID.pred_cong
tff(fact_5863_monoid_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( monoid(C,F,Z2)
     => monoid_axioms(C,F,Z2) ) ).

% monoid.axioms(2)
tff(fact_5864_inj__map__inv__f,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),La: list(C)] :
      ( inj_on(C,D,F,top_top(set(C)))
     => ( aa(list(D),list(C),aa(fun(D,C),fun(list(D),list(C)),map(D,C),hilbert_inv_into(C,D,top_top(set(C)),F)),aa(list(C),list(D),aa(fun(C,D),fun(list(C),list(D)),map(C,D),F),La)) = La ) ) ).

% inj_map_inv_f
tff(fact_5865_ordering_Oaxioms_I2_J,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ordering(C,Less_eq,Less)
     => ordering_axioms(C,Less_eq,Less) ) ).

% ordering.axioms(2)
tff(fact_5866_nth__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [I: nat,Xs: list(C),A3: array(C)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
         => hoare_hoare_triple(C,snga_assn(C,A3,Xs),array_nth(C,A3,I),aa(array(C),fun(C,assn),aa(list(C),fun(array(C),fun(C,assn)),aTP_Lamp_te(nat,fun(list(C),fun(array(C),fun(C,assn))),I),Xs),A3)) ) ) ).

% nth_rule
tff(fact_5867_false__rule,axiom,
    ! [C: $tType,C3: heap_Time_Heap(C),Q: fun(C,assn)] : hoare_hoare_triple(C,bot_bot(assn),C3,Q) ).

% false_rule
tff(fact_5868_norm__pre__pure__iff,axiom,
    ! [C: $tType,Pa: assn,B2: $o,F: heap_Time_Heap(C),Q: fun(C,assn)] :
      ( hoare_hoare_triple(C,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),pure_assn((B2))),F,Q)
    <=> ( (B2)
       => hoare_hoare_triple(C,Pa,F,Q) ) ) ).

% norm_pre_pure_iff
tff(fact_5869_norm__pre__pure__iff__sng,axiom,
    ! [C: $tType,B2: $o,F: heap_Time_Heap(C),Q: fun(C,assn)] :
      ( hoare_hoare_triple(C,pure_assn((B2)),F,Q)
    <=> ( (B2)
       => hoare_hoare_triple(C,one_one(assn),F,Q) ) ) ).

% norm_pre_pure_iff_sng
tff(fact_5870_case__list__rule,axiom,
    ! [C: $tType,D: $tType,La: list(C),Pa: assn,Fn: heap_Time_Heap(D),Q: fun(D,assn),Fc: fun(C,fun(list(C),heap_Time_Heap(D)))] :
      ( ( ( La = nil(C) )
       => hoare_hoare_triple(D,Pa,Fn,Q) )
     => ( ! [X2: C,Xs2: list(C)] :
            ( ( La = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xs2) )
           => hoare_hoare_triple(D,Pa,aa(list(C),heap_Time_Heap(D),aa(C,fun(list(C),heap_Time_Heap(D)),Fc,X2),Xs2),Q) )
       => hoare_hoare_triple(D,Pa,aa(list(C),heap_Time_Heap(D),aa(fun(C,fun(list(C),heap_Time_Heap(D))),fun(list(C),heap_Time_Heap(D)),aa(heap_Time_Heap(D),fun(fun(C,fun(list(C),heap_Time_Heap(D))),fun(list(C),heap_Time_Heap(D))),case_list(heap_Time_Heap(D),C),Fn),Fc),La),Q) ) ) ).

% case_list_rule
tff(fact_5871_frame__rule__left,axiom,
    ! [C: $tType,Pa: assn,C3: heap_Time_Heap(C),Q: fun(C,assn),R: assn] :
      ( hoare_hoare_triple(C,Pa,C3,Q)
     => hoare_hoare_triple(C,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),R),Pa),C3,aa(assn,fun(C,assn),aTP_Lamp_tf(fun(C,assn),fun(assn,fun(C,assn)),Q),R)) ) ).

% frame_rule_left
tff(fact_5872_frame__rule,axiom,
    ! [C: $tType,Pa: assn,C3: heap_Time_Heap(C),Q: fun(C,assn),R: assn] :
      ( hoare_hoare_triple(C,Pa,C3,Q)
     => hoare_hoare_triple(C,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),R),C3,aa(assn,fun(C,assn),aTP_Lamp_se(fun(C,assn),fun(assn,fun(C,assn)),Q),R)) ) ).

% frame_rule
tff(fact_5873_is__hoare__triple,axiom,
    ! [C: $tType,Pa: assn,C3: heap_Time_Heap(C),Q: fun(C,assn)] :
      ( hoare_hoare_triple(C,Pa,C3,Q)
     => hoare_hoare_triple(C,Pa,C3,Q) ) ).

% is_hoare_triple
tff(fact_5874_ordering__axioms__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ordering_axioms(C,Less_eq,Less)
    <=> ( ! [A6: C,B5: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less,A6),B5)
          <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),B5)
              & ( A6 != B5 ) ) )
        & ! [A6: C,B5: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),B5)
           => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B5),A6)
             => ( A6 = B5 ) ) ) ) ) ).

% ordering_axioms_def
tff(fact_5875_ordering__axioms_Ointro,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Less_eq: fun(C,fun(C,$o))] :
      ( ! [A5: C,B4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
        <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
            & ( A5 != B4 ) ) )
     => ( ! [A5: C,B4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
           => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B4),A5)
             => ( A5 = B4 ) ) )
       => ordering_axioms(C,Less_eq,Less) ) ) ).

% ordering_axioms.intro
tff(fact_5876_norm__pre__pure__rule1,axiom,
    ! [C: $tType,B2: $o,Pa: assn,F: heap_Time_Heap(C),Q: fun(C,assn)] :
      ( ( (B2)
       => hoare_hoare_triple(C,Pa,F,Q) )
     => hoare_hoare_triple(C,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),pure_assn((B2))),F,Q) ) ).

% norm_pre_pure_rule1
tff(fact_5877_norm__pre__pure__rule2,axiom,
    ! [C: $tType,B2: $o,F: heap_Time_Heap(C),Q: fun(C,assn)] :
      ( ( (B2)
       => hoare_hoare_triple(C,one_one(assn),F,Q) )
     => hoare_hoare_triple(C,pure_assn((B2)),F,Q) ) ).

% norm_pre_pure_rule2
tff(fact_5878_fi__rule,axiom,
    ! [C: $tType,Pa: assn,C3: heap_Time_Heap(C),Q: fun(C,assn),Ps3: assn,F2: assn] :
      ( hoare_hoare_triple(C,Pa,C3,Q)
     => ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Ps3),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Pa),F2))
       => hoare_hoare_triple(C,Ps3,C3,aa(assn,fun(C,assn),aTP_Lamp_se(fun(C,assn),fun(assn,fun(C,assn)),Q),F2)) ) ) ).

% fi_rule
tff(fact_5879_cons__post__rulet,axiom,
    ! [C: $tType,Pa: assn,C3: heap_Time_Heap(C),Q: fun(C,assn),Q5: fun(C,assn)] :
      ( hoare_hoare_triple(C,Pa,C3,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Q))
     => ( ! [X2: C] : entailst(aa(C,assn,Q,X2),aa(C,assn,Q5,X2))
       => hoare_hoare_triple(C,Pa,C3,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Q5)) ) ) ).

% cons_post_rulet
tff(fact_5880_cons__pre__rulet,axiom,
    ! [C: $tType,Pa: assn,P5: assn,C3: heap_Time_Heap(C),Q: fun(C,assn)] :
      ( entailst(Pa,P5)
     => ( hoare_hoare_triple(C,P5,C3,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Q))
       => hoare_hoare_triple(C,Pa,C3,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Q)) ) ) ).

% cons_pre_rulet
tff(fact_5881_cons__rulet,axiom,
    ! [C: $tType,Pa: assn,P5: assn,Q: fun(C,assn),Q5: fun(C,assn),C3: heap_Time_Heap(C)] :
      ( entailst(Pa,P5)
     => ( ! [X2: C] : entailst(aa(C,assn,Q,X2),aa(C,assn,Q5,X2))
       => ( hoare_hoare_triple(C,P5,C3,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Q))
         => hoare_hoare_triple(C,Pa,C3,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Q5)) ) ) ) ).

% cons_rulet
tff(fact_5882_if__rule__split,axiom,
    ! [C: $tType,B2: $o,Pa: assn,F: heap_Time_Heap(C),Q1: fun(C,assn),G: heap_Time_Heap(C),Q22: fun(C,assn),Q: fun(C,assn)] :
      ( ( (B2)
       => hoare_hoare_triple(C,Pa,F,Q1) )
     => ( ( ~ (B2)
         => hoare_hoare_triple(C,Pa,G,Q22) )
       => ( ! [X2: C] : aa(assn,$o,aa(assn,fun(assn,$o),entails,aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Q1,X2)),pure_assn((B2)))),aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Q22,X2)),pure_assn(~ (B2))))),aa(C,assn,Q,X2))
         => hoare_hoare_triple(C,Pa,
              $ite((B2),F,G),
              Q) ) ) ) ).

% if_rule_split
tff(fact_5883_upd__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [I: nat,Xs: list(C),A3: array(C),X: C] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Xs))
         => hoare_hoare_triple(array(C),snga_assn(C,A3,Xs),array_upd(C,I,X,A3),aa(C,fun(array(C),assn),aa(array(C),fun(C,fun(array(C),assn)),aa(list(C),fun(array(C),fun(C,fun(array(C),assn))),aTP_Lamp_th(nat,fun(list(C),fun(array(C),fun(C,fun(array(C),assn)))),I),Xs),A3),X)) ) ) ).

% upd_rule
tff(fact_5884_make__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [N: nat,F: fun(nat,C)] : hoare_hoare_triple(array(C),one_one(assn),array_make(C,N,F),aa(fun(nat,C),fun(array(C),assn),aTP_Lamp_ti(nat,fun(fun(nat,C),fun(array(C),assn)),N),F)) ) ).

% make_rule
tff(fact_5885_length__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [A3: array(C),Xs: list(C)] : hoare_hoare_triple(nat,snga_assn(C,A3,Xs),array_len(C,A3),aa(list(C),fun(nat,assn),aTP_Lamp_tj(array(C),fun(list(C),fun(nat,assn)),A3),Xs)) ) ).

% length_rule
tff(fact_5886_new__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [N: nat,X: C] : hoare_hoare_triple(array(C),one_one(assn),array_new(C,N,X),aa(C,fun(array(C),assn),aTP_Lamp_tk(nat,fun(C,fun(array(C),assn)),N),X)) ) ).

% new_rule
tff(fact_5887_lookup__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [P3: ref(C),X: C] : hoare_hoare_triple(C,sngr_assn(C,P3,X),ref_lookup(C,P3),aa(C,fun(C,assn),aTP_Lamp_tl(ref(C),fun(C,fun(C,assn)),P3),X)) ) ).

% lookup_rule
tff(fact_5888_of__list__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Xs: list(C)] : hoare_hoare_triple(array(C),one_one(assn),array_of_list(C,Xs),aa(list(C),fun(array(C),assn),aTP_Lamp_kl(list(C),fun(array(C),assn)),Xs)) ) ).

% of_list_rule
tff(fact_5889_freeze__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [A3: array(C),Xs: list(C)] : hoare_hoare_triple(list(C),snga_assn(C,A3,Xs),array_freeze(C,A3),aa(list(C),fun(list(C),assn),aTP_Lamp_tm(array(C),fun(list(C),fun(list(C),assn)),A3),Xs)) ) ).

% freeze_rule
tff(fact_5890_ref__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [X: C] : hoare_hoare_triple(ref(C),one_one(assn),ref_ref(C,X),aa(C,fun(ref(C),assn),aTP_Lamp_km(C,fun(ref(C),assn)),X)) ) ).

% ref_rule
tff(fact_5891_return__sp__rule,axiom,
    ! [C: $tType,Pa: assn,X: C] : hoare_hoare_triple(C,Pa,heap_Time_return(C,X),aa(C,fun(C,assn),aTP_Lamp_tn(assn,fun(C,fun(C,assn)),Pa),X)) ).

% return_sp_rule
tff(fact_5892_return__cons__rule,axiom,
    ! [C: $tType,Pa: assn,Q: fun(C,assn),X: C] :
      ( aa(assn,$o,aa(assn,fun(assn,$o),entails,Pa),aa(C,assn,Q,X))
     => hoare_hoare_triple(C,Pa,heap_Time_return(C,X),Q) ) ).

% return_cons_rule
tff(fact_5893_raise__iff,axiom,
    ! [C: $tType,Pa: assn,S4: list(char),Q: fun(C,assn)] :
      ( hoare_hoare_triple(C,Pa,heap_Time_raise(C,S4),Q)
    <=> ( Pa = bot_bot(assn) ) ) ).

% raise_iff
tff(fact_5894_raise__rule,axiom,
    ! [C: $tType,S4: list(char),Q: fun(C,assn)] : hoare_hoare_triple(C,bot_bot(assn),heap_Time_raise(C,S4),Q) ).

% raise_rule
tff(fact_5895_ordering__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ordering(C,Less_eq,Less)
    <=> ( partial_preordering(C,Less_eq)
        & ordering_axioms(C,Less_eq,Less) ) ) ).

% ordering_def
tff(fact_5896_order_Opartial__preordering__axioms,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => partial_preordering(C,ord_less_eq(C)) ) ).

% order.partial_preordering_axioms
tff(fact_5897_partial__preordering__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o))] :
      ( partial_preordering(C,Less_eq)
    <=> ( ! [A6: C] : aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),A6)
        & ! [A6: C,B5: C,C6: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),B5)
           => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B5),C6)
             => aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),C6) ) ) ) ) ).

% partial_preordering_def
tff(fact_5898_partial__preordering_Otrans,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( partial_preordering(C,Less_eq)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
       => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),C3) ) ) ) ).

% partial_preordering.trans
tff(fact_5899_partial__preordering_Ointro,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o))] :
      ( ! [A5: C] : aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),A5)
     => ( ! [A5: C,B4: C,C2: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
           => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B4),C2)
             => aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),C2) ) )
       => partial_preordering(C,Less_eq) ) ) ).

% partial_preordering.intro
tff(fact_5900_partial__preordering_Orefl,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),A3: C] :
      ( partial_preordering(C,Less_eq)
     => aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),A3) ) ).

% partial_preordering.refl
tff(fact_5901_ordering_Oaxioms_I1_J,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ordering(C,Less_eq,Less)
     => partial_preordering(C,Less_eq) ) ).

% ordering.axioms(1)
tff(fact_5902_dual__order_Opartial__preordering__axioms,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => partial_preordering(C,aTP_Lamp_to(C,fun(C,$o))) ) ).

% dual_order.partial_preordering_axioms
tff(fact_5903_ordering_Ointro,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( partial_preordering(C,Less_eq)
     => ( ordering_axioms(C,Less_eq,Less)
       => ordering(C,Less_eq,Less) ) ) ).

% ordering.intro
tff(fact_5904_wait__rule,axiom,
    ! [N: nat] : hoare_hoare_triple(product_unit,one_one(assn),heap_Time_wait(N),aTP_Lamp_tp(product_unit,assn)) ).

% wait_rule
tff(fact_5905_update__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [P3: ref(C),Y: C,X: C] : hoare_hoare_triple(product_unit,sngr_assn(C,P3,Y),ref_update(C,P3,X),aa(C,fun(product_unit,assn),aTP_Lamp_tq(ref(C),fun(C,fun(product_unit,assn)),P3),X)) ) ).

% update_rule
tff(fact_5906_semilattice__neutr_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( semilattice(C,F)
     => ( comm_monoid(C,F,Z2)
       => semilattice_neutr(C,F,Z2) ) ) ).

% semilattice_neutr.intro
tff(fact_5907_semilattice__neutr_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( semilattice_neutr(C,F,Z2)
     => semilattice(C,F) ) ).

% semilattice_neutr.axioms(1)
tff(fact_5908_max_Osemilattice__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => semilattice(C,ord_max(C)) ) ).

% max.semilattice_axioms
tff(fact_5909_semilattice_Oidem,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C] :
      ( semilattice(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),A3) = A3 ) ) ).

% semilattice.idem
tff(fact_5910_semilattice_Oleft__idem,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C] :
      ( semilattice(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,aa(C,fun(C,C),F,A3),B2)) = aa(C,C,aa(C,fun(C,C),F,A3),B2) ) ) ).

% semilattice.left_idem
tff(fact_5911_semilattice_Oright__idem,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C] :
      ( semilattice(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A3),B2)),B2) = aa(C,C,aa(C,fun(C,C),F,A3),B2) ) ) ).

% semilattice.right_idem
tff(fact_5912_min_Osemilattice__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => semilattice(C,ord_min(C)) ) ).

% min.semilattice_axioms
tff(fact_5913_inf_Osemilattice__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => semilattice(C,inf_inf(C)) ) ).

% inf.semilattice_axioms
tff(fact_5914_sup_Osemilattice__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => semilattice(C,sup_sup(C)) ) ).

% sup.semilattice_axioms
tff(fact_5915_semilattice__order_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semilattice_order(C,F,Less_eq,Less)
     => semilattice(C,F) ) ).

% semilattice_order.axioms(1)
tff(fact_5916_semilattice__map2,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semilattice(C,F)
     => semilattice(list(C),aTP_Lamp_tr(fun(C,fun(C,C)),fun(list(C),fun(list(C),list(C))),F)) ) ).

% semilattice_map2
tff(fact_5917_semilattice__neutr__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( semilattice_neutr(C,F,Z2)
    <=> ( semilattice(C,F)
        & comm_monoid(C,F,Z2) ) ) ).

% semilattice_neutr_def
tff(fact_5918_update__wp__rule,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [R3: ref(C),Y: C,X: C,Q: fun(product_unit,assn)] : hoare_hoare_triple(product_unit,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sngr_assn(C,R3,Y)),wand_assn(sngr_assn(C,R3,X),aa(product_unit,assn,Q,product_Unity))),ref_update(C,R3,X),Q) ) ).

% update_wp_rule
tff(fact_5919_semilattice__order__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semilattice_order(C,F,Less_eq,Less)
    <=> ( semilattice(C,F)
        & semila6385135966242565138axioms(C,F,Less_eq,Less) ) ) ).

% semilattice_order_def
tff(fact_5920_semilattice__order_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semilattice(C,F)
     => ( semila6385135966242565138axioms(C,F,Less_eq,Less)
       => semilattice_order(C,F,Less_eq,Less) ) ) ).

% semilattice_order.intro
tff(fact_5921_inf__unit__def,axiom,
    ! [Uu: product_unit,Uv: product_unit] : aa(product_unit,product_unit,aa(product_unit,fun(product_unit,product_unit),inf_inf(product_unit),Uu),Uv) = product_Unity ).

% inf_unit_def
tff(fact_5922_semilattice__order__axioms__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semila6385135966242565138axioms(C,F,Less_eq,Less)
    <=> ( ! [A6: C,B5: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),B5)
          <=> ( A6 = aa(C,C,aa(C,fun(C,C),F,A6),B5) ) )
        & ! [A6: C,B5: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less,A6),B5)
          <=> ( ( A6 = aa(C,C,aa(C,fun(C,C),F,A6),B5) )
              & ( A6 != B5 ) ) ) ) ) ).

% semilattice_order_axioms_def
tff(fact_5923_semilattice__order__axioms_Ointro,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),F: fun(C,fun(C,C)),Less: fun(C,fun(C,$o))] :
      ( ! [A5: C,B4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
        <=> ( A5 = aa(C,C,aa(C,fun(C,C),F,A5),B4) ) )
     => ( ! [A5: C,B4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
          <=> ( ( A5 = aa(C,C,aa(C,fun(C,C),F,A5),B4) )
              & ( A5 != B4 ) ) )
       => semila6385135966242565138axioms(C,F,Less_eq,Less) ) ) ).

% semilattice_order_axioms.intro
tff(fact_5924_semilattice__order_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( semilattice_order(C,F,Less_eq,Less)
     => semila6385135966242565138axioms(C,F,Less_eq,Less) ) ).

% semilattice_order.axioms(2)
tff(fact_5925_CODE__ABORT__def,axiom,
    ! [C: $tType,F: fun(product_unit,C)] : cODE_ABORT(C,F) = aa(product_unit,C,F,product_Unity) ).

% CODE_ABORT_def
tff(fact_5926_comm__monoid_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( comm_monoid(C,F,Z2)
     => comm_monoid_axioms(C,F,Z2) ) ).

% comm_monoid.axioms(2)
tff(fact_5927_comm__monoid__axioms_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( ! [A5: C] : aa(C,C,aa(C,fun(C,C),F,A5),Z2) = A5
     => comm_monoid_axioms(C,F,Z2) ) ).

% comm_monoid_axioms.intro
tff(fact_5928_comm__monoid__axioms__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( comm_monoid_axioms(C,F,Z2)
    <=> ! [A6: C] : aa(C,C,aa(C,fun(C,C),F,A6),Z2) = A6 ) ).

% comm_monoid_axioms_def
tff(fact_5929_comm__monoid__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( comm_monoid(C,F,Z2)
    <=> ( abel_semigroup(C,F)
        & comm_monoid_axioms(C,F,Z2) ) ) ).

% comm_monoid_def
tff(fact_5930_comm__monoid_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( abel_semigroup(C,F)
     => ( comm_monoid_axioms(C,F,Z2)
       => comm_monoid(C,F,Z2) ) ) ).

% comm_monoid.intro
tff(fact_5931_semilattice_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semilattice(C,F)
     => semilattice_axioms(C,F) ) ).

% semilattice.axioms(2)
tff(fact_5932_inf_Oabel__semigroup__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => abel_semigroup(C,inf_inf(C)) ) ).

% inf.abel_semigroup_axioms
tff(fact_5933_abel__semigroup_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( abel_semigroup(C,F)
     => semigroup(C,F) ) ).

% abel_semigroup.axioms(1)
tff(fact_5934_sup_Oabel__semigroup__axioms,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => abel_semigroup(C,sup_sup(C)) ) ).

% sup.abel_semigroup_axioms
tff(fact_5935_add_Oabel__semigroup__axioms,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => abel_semigroup(C,plus_plus(C)) ) ).

% add.abel_semigroup_axioms
tff(fact_5936_min_Oabel__semigroup__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => abel_semigroup(C,ord_min(C)) ) ).

% min.abel_semigroup_axioms
tff(fact_5937_max_Oabel__semigroup__axioms,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => abel_semigroup(C,ord_max(C)) ) ).

% max.abel_semigroup_axioms
tff(fact_5938_mult_Oabel__semigroup__axioms,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => abel_semigroup(C,times_times(C)) ) ).

% mult.abel_semigroup_axioms
tff(fact_5939_abel__semigroup_Oleft__commute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),B2: C,A3: C,C3: C] :
      ( abel_semigroup(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,B2),aa(C,C,aa(C,fun(C,C),F,A3),C3)) = aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3)) ) ) ).

% abel_semigroup.left_commute
tff(fact_5940_abel__semigroup_Ocommute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C] :
      ( abel_semigroup(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = aa(C,C,aa(C,fun(C,C),F,B2),A3) ) ) ).

% abel_semigroup.commute
tff(fact_5941_semilattice__axioms__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semilattice_axioms(C,F)
    <=> ! [A6: C] : aa(C,C,aa(C,fun(C,C),F,A6),A6) = A6 ) ).

% semilattice_axioms_def
tff(fact_5942_semilattice__axioms_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( ! [A5: C] : aa(C,C,aa(C,fun(C,C),F,A5),A5) = A5
     => semilattice_axioms(C,F) ) ).

% semilattice_axioms.intro
tff(fact_5943_abstract__boolean__algebra_Oaxioms_I2_J,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => abel_semigroup(C,Disj) ) ).

% abstract_boolean_algebra.axioms(2)
tff(fact_5944_abstract__boolean__algebra_Oaxioms_I1_J,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => abel_semigroup(C,Conj) ) ).

% abstract_boolean_algebra.axioms(1)
tff(fact_5945_comm__monoid_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( comm_monoid(C,F,Z2)
     => abel_semigroup(C,F) ) ).

% comm_monoid.axioms(1)
tff(fact_5946_semilattice__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semilattice(C,F)
    <=> ( abel_semigroup(C,F)
        & semilattice_axioms(C,F) ) ) ).

% semilattice_def
tff(fact_5947_semilattice_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( abel_semigroup(C,F)
     => ( semilattice_axioms(C,F)
       => semilattice(C,F) ) ) ).

% semilattice.intro
tff(fact_5948_semilattice_Oaxioms_I1_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semilattice(C,F)
     => abel_semigroup(C,F) ) ).

% semilattice.axioms(1)
tff(fact_5949_abel__semigroup__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( abel_semigroup(C,F)
    <=> ( semigroup(C,F)
        & abel_s757365448890700780axioms(C,F) ) ) ).

% abel_semigroup_def
tff(fact_5950_abel__semigroup_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( semigroup(C,F)
     => ( abel_s757365448890700780axioms(C,F)
       => abel_semigroup(C,F) ) ) ).

% abel_semigroup.intro
tff(fact_5951_abstract__boolean__algebra_Ointro,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( abel_semigroup(C,Conj)
     => ( abel_semigroup(C,Disj)
       => ( boolea6902313364301356556axioms(C,Conj,Disj,Compl,Zero,One)
         => boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One) ) ) ) ).

% abstract_boolean_algebra.intro
tff(fact_5952_abstract__boolean__algebra__axioms_Ointro,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),One: C,Zero: C,Compl: fun(C,C)] :
      ( ! [X2: C,Y2: C,Z4: C] : aa(C,C,aa(C,fun(C,C),Conj,X2),aa(C,C,aa(C,fun(C,C),Disj,Y2),Z4)) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,X2),Y2)),aa(C,C,aa(C,fun(C,C),Conj,X2),Z4))
     => ( ! [X2: C,Y2: C,Z4: C] : aa(C,C,aa(C,fun(C,C),Disj,X2),aa(C,C,aa(C,fun(C,C),Conj,Y2),Z4)) = aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Disj,X2),Y2)),aa(C,C,aa(C,fun(C,C),Disj,X2),Z4))
       => ( ! [X2: C] : aa(C,C,aa(C,fun(C,C),Conj,X2),One) = X2
         => ( ! [X2: C] : aa(C,C,aa(C,fun(C,C),Disj,X2),Zero) = X2
           => ( ! [X2: C] : aa(C,C,aa(C,fun(C,C),Conj,X2),aa(C,C,Compl,X2)) = Zero
             => ( ! [X2: C] : aa(C,C,aa(C,fun(C,C),Disj,X2),aa(C,C,Compl,X2)) = One
               => boolea6902313364301356556axioms(C,Conj,Disj,Compl,Zero,One) ) ) ) ) ) ) ).

% abstract_boolean_algebra_axioms.intro
tff(fact_5953_abstract__boolean__algebra__axioms__def,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea6902313364301356556axioms(C,Conj,Disj,Compl,Zero,One)
    <=> ( ! [X4: C,Y3: C,Z3: C] : aa(C,C,aa(C,fun(C,C),Conj,X4),aa(C,C,aa(C,fun(C,C),Disj,Y3),Z3)) = aa(C,C,aa(C,fun(C,C),Disj,aa(C,C,aa(C,fun(C,C),Conj,X4),Y3)),aa(C,C,aa(C,fun(C,C),Conj,X4),Z3))
        & ! [X4: C,Y3: C,Z3: C] : aa(C,C,aa(C,fun(C,C),Disj,X4),aa(C,C,aa(C,fun(C,C),Conj,Y3),Z3)) = aa(C,C,aa(C,fun(C,C),Conj,aa(C,C,aa(C,fun(C,C),Disj,X4),Y3)),aa(C,C,aa(C,fun(C,C),Disj,X4),Z3))
        & ! [X4: C] : aa(C,C,aa(C,fun(C,C),Conj,X4),One) = X4
        & ! [X4: C] : aa(C,C,aa(C,fun(C,C),Disj,X4),Zero) = X4
        & ! [X4: C] : aa(C,C,aa(C,fun(C,C),Conj,X4),aa(C,C,Compl,X4)) = Zero
        & ! [X4: C] : aa(C,C,aa(C,fun(C,C),Disj,X4),aa(C,C,Compl,X4)) = One ) ) ).

% abstract_boolean_algebra_axioms_def
tff(fact_5954_abel__semigroup__axioms_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( ! [A5: C,B4: C] : aa(C,C,aa(C,fun(C,C),F,A5),B4) = aa(C,C,aa(C,fun(C,C),F,B4),A5)
     => abel_s757365448890700780axioms(C,F) ) ).

% abel_semigroup_axioms.intro
tff(fact_5955_abel__semigroup__axioms__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( abel_s757365448890700780axioms(C,F)
    <=> ! [A6: C,B5: C] : aa(C,C,aa(C,fun(C,C),F,A6),B5) = aa(C,C,aa(C,fun(C,C),F,B5),A6) ) ).

% abel_semigroup_axioms_def
tff(fact_5956_abel__semigroup_Oaxioms_I2_J,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( abel_semigroup(C,F)
     => abel_s757365448890700780axioms(C,F) ) ).

% abel_semigroup.axioms(2)
tff(fact_5957_abstract__boolean__algebra_Oaxioms_I3_J,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
     => boolea6902313364301356556axioms(C,Conj,Disj,Compl,Zero,One) ) ).

% abstract_boolean_algebra.axioms(3)
tff(fact_5958_abstract__boolean__algebra__def,axiom,
    ! [C: $tType,Conj: fun(C,fun(C,C)),Disj: fun(C,fun(C,C)),Compl: fun(C,C),Zero: C,One: C] :
      ( boolea2506097494486148201lgebra(C,Conj,Disj,Compl,Zero,One)
    <=> ( abel_semigroup(C,Conj)
        & abel_semigroup(C,Disj)
        & boolea6902313364301356556axioms(C,Conj,Disj,Compl,Zero,One) ) ) ).

% abstract_boolean_algebra_def
tff(fact_5959_dual__order_Opreordering__axioms,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => preordering(C,aTP_Lamp_to(C,fun(C,$o)),aTP_Lamp_ts(C,fun(C,$o))) ) ).

% dual_order.preordering_axioms
tff(fact_5960_relH__def,axiom,
    ! [As2: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
      ( relH(As2,H,H4)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H),As2))
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H4),As2))
        & ! [T2: typerep,X4: nat] :
            ( member2(nat,X4,As2)
           => ( ( refs(product_unit,H,T2,X4) = refs(product_unit,H4,T2,X4) )
              & ( arrays(product_unit,H,T2,X4) = arrays(product_unit,H4,T2,X4) ) ) ) ) ) ).

% relH_def
tff(fact_5961_preordering__dualI,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( preordering(C,aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Less_eq),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Less))
     => preordering(C,Less_eq,Less) ) ).

% preordering_dualI
tff(fact_5962_preordering__strictI,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( ! [A5: C,B4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
        <=> ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
            | ( A5 = B4 ) ) )
     => ( ! [A5: C,B4: C] :
            ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
           => ~ aa(C,$o,aa(C,fun(C,$o),Less,B4),A5) )
       => ( ! [A5: C] : ~ aa(C,$o,aa(C,fun(C,$o),Less,A5),A5)
         => ( ! [A5: C,B4: C,C2: C] :
                ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
               => ( aa(C,$o,aa(C,fun(C,$o),Less,B4),C2)
                 => aa(C,$o,aa(C,fun(C,$o),Less,A5),C2) ) )
           => preordering(C,Less_eq,Less) ) ) ) ) ).

% preordering_strictI
tff(fact_5963_preordering_Ostrict__implies__order,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( preordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
       => aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2) ) ) ).

% preordering.strict_implies_order
tff(fact_5964_preordering_Ostrict__iff__not,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( preordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
      <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
          & ~ aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),A3) ) ) ) ).

% preordering.strict_iff_not
tff(fact_5965_preordering_Ostrict__trans2,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( preordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
       => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),Less,A3),C3) ) ) ) ).

% preordering.strict_trans2
tff(fact_5966_preordering_Ostrict__trans1,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( preordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A3),B2)
       => ( aa(C,$o,aa(C,fun(C,$o),Less,B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),Less,A3),C3) ) ) ) ).

% preordering.strict_trans1
tff(fact_5967_preordering_Ostrict__trans,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C,C3: C] :
      ( preordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
       => ( aa(C,$o,aa(C,fun(C,$o),Less,B2),C3)
         => aa(C,$o,aa(C,fun(C,$o),Less,A3),C3) ) ) ) ).

% preordering.strict_trans
tff(fact_5968_preordering_Oirrefl,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C] :
      ( preordering(C,Less_eq,Less)
     => ~ aa(C,$o,aa(C,fun(C,$o),Less,A3),A3) ) ).

% preordering.irrefl
tff(fact_5969_preordering_Oasym,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o)),A3: C,B2: C] :
      ( preordering(C,Less_eq,Less)
     => ( aa(C,$o,aa(C,fun(C,$o),Less,A3),B2)
       => ~ aa(C,$o,aa(C,fun(C,$o),Less,B2),A3) ) ) ).

% preordering.asym
tff(fact_5970_preordering_Oaxioms_I1_J,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( preordering(C,Less_eq,Less)
     => partial_preordering(C,Less_eq) ) ).

% preordering.axioms(1)
tff(fact_5971_order_Opreordering__axioms,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => preordering(C,ord_less_eq(C),ord_less(C)) ) ).

% order.preordering_axioms
tff(fact_5972_preordering_Ointro,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( partial_preordering(C,Less_eq)
     => ( preordering_axioms(C,Less_eq,Less)
       => preordering(C,Less_eq,Less) ) ) ).

% preordering.intro
tff(fact_5973_preordering__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( preordering(C,Less_eq,Less)
    <=> ( partial_preordering(C,Less_eq)
        & preordering_axioms(C,Less_eq,Less) ) ) ).

% preordering_def
tff(fact_5974_preordering__axioms_Ointro,axiom,
    ! [C: $tType,Less: fun(C,fun(C,$o)),Less_eq: fun(C,fun(C,$o))] :
      ( ! [A5: C,B4: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Less,A5),B4)
        <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A5),B4)
            & ~ aa(C,$o,aa(C,fun(C,$o),Less_eq,B4),A5) ) )
     => preordering_axioms(C,Less_eq,Less) ) ).

% preordering_axioms.intro
tff(fact_5975_preordering__axioms__def,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( preordering_axioms(C,Less_eq,Less)
    <=> ! [A6: C,B5: C] :
          ( aa(C,$o,aa(C,fun(C,$o),Less,A6),B5)
        <=> ( aa(C,$o,aa(C,fun(C,$o),Less_eq,A6),B5)
            & ~ aa(C,$o,aa(C,fun(C,$o),Less_eq,B5),A6) ) ) ) ).

% preordering_axioms_def
tff(fact_5976_preordering_Oaxioms_I2_J,axiom,
    ! [C: $tType,Less_eq: fun(C,fun(C,$o)),Less: fun(C,fun(C,$o))] :
      ( preordering(C,Less_eq,Less)
     => preordering_axioms(C,Less_eq,Less) ) ).

% preordering.axioms(2)
tff(fact_5977_Restr__natLeq,axiom,
    ! [N: nat] : aa(set(product_prod(nat,nat)),set(product_prod(nat,nat)),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),set(product_prod(nat,nat))),inf_inf(set(product_prod(nat,nat))),bNF_Ca8665028551170535155natLeq),product_Sigma(nat,nat,collect(nat,aTP_Lamp_bf(nat,fun(nat,$o),N)),aTP_Lamp_tt(nat,fun(nat,set(nat)),N))) = collect(product_prod(nat,nat),product_case_prod(nat,nat,$o,aTP_Lamp_tu(nat,fun(nat,fun(nat,$o)),N))) ).

% Restr_natLeq
tff(fact_5978_Restr__natLeq2,axiom,
    ! [N: nat] : aa(set(product_prod(nat,nat)),set(product_prod(nat,nat)),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),set(product_prod(nat,nat))),inf_inf(set(product_prod(nat,nat))),bNF_Ca8665028551170535155natLeq),product_Sigma(nat,nat,order_underS(nat,bNF_Ca8665028551170535155natLeq,N),aTP_Lamp_tv(nat,fun(nat,set(nat)),N))) = collect(product_prod(nat,nat),product_case_prod(nat,nat,$o,aTP_Lamp_tu(nat,fun(nat,fun(nat,$o)),N))) ).

% Restr_natLeq2
tff(fact_5979_in__range_Opelims_I1_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,X)
      <=> (Y) )
     => ( accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel,X)
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( ( (Y)
                <=> ! [X4: nat] :
                      ( member2(nat,X4,As)
                     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),lim(product_unit,H2)) ) )
               => ~ accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)) ) ) ) ) ).

% in_range.pelims(1)
tff(fact_5980_in__range_Opelims_I2_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,X)
     => ( accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel,X)
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
               => ~ ! [X3: nat] :
                      ( member2(nat,X3,As)
                     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X3),lim(product_unit,H2)) ) ) ) ) ) ).

% in_range.pelims(2)
tff(fact_5981_in__range_Opelims_I3_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,X)
     => ( accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel,X)
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
               => ! [X2: nat] :
                    ( member2(nat,X2,As)
                   => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),lim(product_unit,H2)) ) ) ) ) ) ).

% in_range.pelims(3)
tff(fact_5982_one__assn__raw_Opelims_I3_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,X)
     => ( accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel,X)
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
               => ( As = bot_bot(set(nat)) ) ) ) ) ) ).

% one_assn_raw.pelims(3)
tff(fact_5983_one__assn__raw_Opelims_I2_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,X)
     => ( accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel,X)
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As))
               => ( As != bot_bot(set(nat)) ) ) ) ) ) ).

% one_assn_raw.pelims(2)
tff(fact_5984_one__assn__raw_Opelims_I1_J,axiom,
    ! [X: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,one_assn_raw,X)
      <=> (Y) )
     => ( accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel,X)
       => ~ ! [H2: heap_ext(product_unit),As: set(nat)] :
              ( ( X = aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As) )
             => ( ( (Y)
                <=> ( As = bot_bot(set(nat)) ) )
               => ~ accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel,aa(set(nat),product_prod(heap_ext(product_unit),set(nat)),aa(heap_ext(product_unit),fun(set(nat),product_prod(heap_ext(product_unit),set(nat))),product_Pair(heap_ext(product_unit),set(nat)),H2),As)) ) ) ) ) ).

% one_assn_raw.pelims(1)
tff(fact_5985_lenlex__def,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : lenlex(C,R3) = inv_image(product_prod(nat,list(C)),list(C),lex_prod(nat,list(C),less_than,lex(C,R3)),aTP_Lamp_tw(list(C),product_prod(nat,list(C)))) ).

% lenlex_def
tff(fact_5986_bind__rule_H,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Pa: assn,F: heap_Time_Heap(D),R: fun(D,assn),G: fun(D,heap_Time_Heap(E2)),Q: fun(E2,assn)] :
      ( ! [R5: C] : hoare_hoare_triple(D,Pa,F,aa(fun(D,assn),fun(D,assn),aTP_Lamp_tx(assn,fun(fun(D,assn),fun(D,assn)),Pa),R))
     => ( ! [X2: D] : hoare_hoare_triple(E2,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,R,X2)),Pa),aa(D,heap_Time_Heap(E2),G,X2),Q)
       => hoare_hoare_triple(E2,Pa,heap_Time_bind(D,E2,F,G),Q) ) ) ).

% bind_rule'
tff(fact_5987_measures__def,axiom,
    ! [C: $tType,Fs: list(fun(C,nat))] : measures(C,Fs) = inv_image(list(nat),C,lex(nat,less_than),aTP_Lamp_tz(list(fun(C,nat)),fun(C,list(nat)),Fs)) ).

% measures_def
tff(fact_5988_ccpo_Oadmissible__def,axiom,
    ! [C: $tType,Lub: fun(set(C),C),Ord: fun(C,fun(C,$o)),Pa: fun(C,$o)] :
      ( comple1908693960933563346ssible(C,Lub,Ord,Pa)
    <=> ! [A9: set(C)] :
          ( comple1602240252501008431_chain(C,Ord,A9)
         => ( ( A9 != bot_bot(set(C)) )
           => ( ! [X4: C] :
                  ( member2(C,X4,A9)
                 => aa(C,$o,Pa,X4) )
             => aa(C,$o,Pa,aa(set(C),C,Lub,A9)) ) ) ) ) ).

% ccpo.admissible_def
tff(fact_5989_ccpo_OadmissibleD,axiom,
    ! [C: $tType,Lub: fun(set(C),C),Ord: fun(C,fun(C,$o)),Pa: fun(C,$o),A4: set(C)] :
      ( comple1908693960933563346ssible(C,Lub,Ord,Pa)
     => ( comple1602240252501008431_chain(C,Ord,A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C] :
                ( member2(C,X2,A4)
               => aa(C,$o,Pa,X2) )
           => aa(C,$o,Pa,aa(set(C),C,Lub,A4)) ) ) ) ) ).

% ccpo.admissibleD
tff(fact_5990_ccpo_OadmissibleI,axiom,
    ! [C: $tType,Ord: fun(C,fun(C,$o)),Pa: fun(C,$o),Lub: fun(set(C),C)] :
      ( ! [A8: set(C)] :
          ( comple1602240252501008431_chain(C,Ord,A8)
         => ( ( A8 != bot_bot(set(C)) )
           => ( ! [X3: C] :
                  ( member2(C,X3,A8)
                 => aa(C,$o,Pa,X3) )
             => aa(C,$o,Pa,aa(set(C),C,Lub,A8)) ) ) )
     => comple1908693960933563346ssible(C,Lub,Ord,Pa) ) ).

% ccpo.admissibleI
tff(fact_5991_fixp__induct,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [Pa: fun(C,$o),F: fun(C,C)] :
          ( comple1908693960933563346ssible(C,complete_Sup_Sup(C),ord_less_eq(C),Pa)
         => ( aa(fun(C,C),$o,aa(fun(C,fun(C,$o)),fun(fun(C,C),$o),aa(fun(C,fun(C,$o)),fun(fun(C,fun(C,$o)),fun(fun(C,C),$o)),comple7038119648293358887notone(C,C),ord_less_eq(C)),ord_less_eq(C)),F)
           => ( aa(C,$o,Pa,aa(set(C),C,complete_Sup_Sup(C),bot_bot(set(C))))
             => ( ! [X2: C] :
                    ( aa(C,$o,Pa,X2)
                   => aa(C,$o,Pa,aa(C,C,F,X2)) )
               => aa(C,$o,Pa,comple115746919287870866o_fixp(C,F)) ) ) ) ) ) ).

% fixp_induct
tff(fact_5992_prod__set__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,X: C,Y: D] : basic_fsts(C,D,aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),Y)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))) ).

% prod_set_simps(1)
tff(fact_5993_fixp__mono,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [F: fun(C,C),G: fun(C,C)] :
          ( aa(fun(C,C),$o,aa(fun(C,fun(C,$o)),fun(fun(C,C),$o),aa(fun(C,fun(C,$o)),fun(fun(C,fun(C,$o)),fun(fun(C,C),$o)),comple7038119648293358887notone(C,C),ord_less_eq(C)),ord_less_eq(C)),F)
         => ( aa(fun(C,C),$o,aa(fun(C,fun(C,$o)),fun(fun(C,C),$o),aa(fun(C,fun(C,$o)),fun(fun(C,fun(C,$o)),fun(fun(C,C),$o)),comple7038119648293358887notone(C,C),ord_less_eq(C)),ord_less_eq(C)),G)
           => ( ! [Z7: C] : aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(C,C,F,Z7)),aa(C,C,G,Z7))
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),comple115746919287870866o_fixp(C,F)),comple115746919287870866o_fixp(C,G)) ) ) ) ) ).

% fixp_mono
tff(fact_5994_prod__set__defs_I1_J,axiom,
    ! [D: $tType,C: $tType,X3: product_prod(C,D)] : basic_fsts(C,D,X3) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(product_prod(C,D),C,product_fst(C,D),X3)),bot_bot(set(C))) ).

% prod_set_defs(1)
tff(fact_5995_prod__set__simps_I2_J,axiom,
    ! [D: $tType,C: $tType,X: D,Y: C] : basic_snds(D,C,aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),X),Y)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y),bot_bot(set(C))) ).

% prod_set_simps(2)
tff(fact_5996_prod__set__defs_I2_J,axiom,
    ! [C: $tType,D: $tType,X3: product_prod(C,D)] : basic_snds(C,D,X3) = aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),aa(product_prod(C,D),D,product_snd(C,D),X3)),bot_bot(set(D))) ).

% prod_set_defs(2)
tff(fact_5997_enumerate__Suc__eq,axiom,
    ! [C: $tType,N: nat,Xs: list(C)] : enumerate(C,aa(nat,nat,suc,N),Xs) = aa(list(product_prod(nat,C)),list(product_prod(nat,C)),aa(fun(product_prod(nat,C),product_prod(nat,C)),fun(list(product_prod(nat,C)),list(product_prod(nat,C))),map(product_prod(nat,C),product_prod(nat,C)),product_apfst(nat,nat,C,suc)),enumerate(C,N,Xs)) ).

% enumerate_Suc_eq
tff(fact_5998_select,axiom,
    ! [C: $tType,Xs: list(C),S4: product_prod(code_natural,code_natural)] :
      ( ( Xs != nil(C) )
     => member2(C,aa(product_prod(C,product_prod(code_natural,code_natural)),C,product_fst(C,product_prod(code_natural,code_natural)),aa(product_prod(code_natural,code_natural),product_prod(C,product_prod(code_natural,code_natural)),select(C,Xs),S4)),aa(list(C),set(C),set2(C),Xs)) ) ).

% select
tff(fact_5999_select__weight__select,axiom,
    ! [C: $tType,Xs: list(C)] :
      ( ( Xs != nil(C) )
     => ( select_weight(C,aa(list(C),list(product_prod(code_natural,C)),aa(fun(C,product_prod(code_natural,C)),fun(list(C),list(product_prod(code_natural,C))),map(C,product_prod(code_natural,C)),aa(code_natural,fun(C,product_prod(code_natural,C)),product_Pair(code_natural,C),one_one(code_natural))),Xs)) = select(C,Xs) ) ) ).

% select_weight_select
tff(fact_6000_prod__mset_Ocomm__monoid__mset__axioms,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => comm_monoid_mset(C,times_times(C),one_one(C)) ) ).

% prod_mset.comm_monoid_mset_axioms
tff(fact_6001_those_Osimps_I1_J,axiom,
    ! [C: $tType] : aa(list(option(C)),option(list(C)),those(C),nil(option(C))) = aa(list(C),option(list(C)),some(list(C)),nil(C)) ).

% those.simps(1)
tff(fact_6002_bot__in__iterates,axiom,
    ! [C: $tType] :
      ( comple9053668089753744459l_ccpo(C)
     => ! [F: fun(C,C)] : member2(C,aa(set(C),C,complete_Sup_Sup(C),bot_bot(set(C))),comple6359979572994053840erates(C,F)) ) ).

% bot_in_iterates
tff(fact_6003_those_Osimps_I2_J,axiom,
    ! [C: $tType,X: option(C),Xs: list(option(C))] : aa(list(option(C)),option(list(C)),those(C),aa(list(option(C)),list(option(C)),aa(option(C),fun(list(option(C)),list(option(C))),cons(option(C)),X),Xs)) = case_option(option(list(C)),C,none(list(C)),aTP_Lamp_ua(list(option(C)),fun(C,option(list(C))),Xs),X) ).

% those.simps(2)
tff(fact_6004_sym__Int__converse,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] : sym(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),converse(C,C,R3))) ).

% sym_Int_converse
tff(fact_6005_listrel__sym,axiom,
    ! [C: $tType,R3: set(product_prod(C,C))] :
      ( sym(C,R3)
     => sym(list(C),listrel(C,C,R3)) ) ).

% listrel_sym
tff(fact_6006_sym__Int,axiom,
    ! [C: $tType,R3: set(product_prod(C,C)),S4: set(product_prod(C,C))] :
      ( sym(C,R3)
     => ( sym(C,S4)
       => sym(C,aa(set(product_prod(C,C)),set(product_prod(C,C)),aa(set(product_prod(C,C)),fun(set(product_prod(C,C)),set(product_prod(C,C))),inf_inf(set(product_prod(C,C))),R3),S4)) ) ) ).

% sym_Int
tff(fact_6007_ac__operator_Osafe__commute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),X: C,Y: C,A3: C,B2: C] :
      ( syntax_ac_operator(C,F)
     => ( syntax7388354845996824322omatch(C,C,aa(C,C,aa(C,fun(C,C),F,X),Y),A3)
       => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = aa(C,C,aa(C,fun(C,C),F,B2),A3) ) ) ) ).

% ac_operator.safe_commute
tff(fact_6008_Nitpick_OEx1__unfold,axiom,
    ! [C: $tType,Pa: fun(C,$o)] :
      ( ? [X4: C] :
          ( aa(C,$o,Pa,X4)
          & ! [Y3: C] :
              ( aa(C,$o,Pa,Y3)
             => ( Y3 = X4 ) ) )
    <=> ? [X4: C] : collect(C,Pa) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X4),bot_bot(set(C))) ) ).

% Nitpick.Ex1_unfold
tff(fact_6009_ac__operator_Ointro,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( ! [A5: C,B4: C,C2: C] : aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A5),B4)),C2) = aa(C,C,aa(C,fun(C,C),F,A5),aa(C,C,aa(C,fun(C,C),F,B4),C2))
     => ( ! [A5: C,B4: C] : aa(C,C,aa(C,fun(C,C),F,A5),B4) = aa(C,C,aa(C,fun(C,C),F,B4),A5)
       => syntax_ac_operator(C,F) ) ) ).

% ac_operator.intro
tff(fact_6010_ac__operator_Ocommute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C] :
      ( syntax_ac_operator(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),B2) = aa(C,C,aa(C,fun(C,C),F,B2),A3) ) ) ).

% ac_operator.commute
tff(fact_6011_ac__operator_Oleft__assoc,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C,C3: C] :
      ( syntax_ac_operator(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3)) = aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) ) ) ).

% ac_operator.left_assoc
tff(fact_6012_ac__operator_Oright__assoc,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C,C3: C] :
      ( syntax_ac_operator(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3)) ) ) ).

% ac_operator.right_assoc
tff(fact_6013_ac__operator_Oleft__commute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C,C3: C] :
      ( syntax_ac_operator(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,A3),aa(C,C,aa(C,fun(C,C),F,B2),C3)) = aa(C,C,aa(C,fun(C,C),F,B2),aa(C,C,aa(C,fun(C,C),F,A3),C3)) ) ) ).

% ac_operator.left_commute
tff(fact_6014_ac__operator_Oright__commute,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),A3: C,B2: C,C3: C] :
      ( syntax_ac_operator(C,F)
     => ( aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A3),B2)),C3) = aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A3),C3)),B2) ) ) ).

% ac_operator.right_commute
tff(fact_6015_ac__operator__def,axiom,
    ! [C: $tType,F: fun(C,fun(C,C))] :
      ( syntax_ac_operator(C,F)
    <=> ( ! [A6: C,B5: C,C6: C] : aa(C,C,aa(C,fun(C,C),F,aa(C,C,aa(C,fun(C,C),F,A6),B5)),C6) = aa(C,C,aa(C,fun(C,C),F,A6),aa(C,C,aa(C,fun(C,C),F,B5),C6))
        & ! [A6: C,B5: C] : aa(C,C,aa(C,fun(C,C),F,A6),B5) = aa(C,C,aa(C,fun(C,C),F,B5),A6) ) ) ).

% ac_operator_def
tff(fact_6016_mult_Oac__operator__axioms,axiom,
    ! [C: $tType] :
      ( ab_semigroup_mult(C)
     => syntax_ac_operator(C,times_times(C)) ) ).

% mult.ac_operator_axioms
tff(fact_6017_add_Oac__operator__axioms,axiom,
    ! [C: $tType] :
      ( ab_semigroup_add(C)
     => syntax_ac_operator(C,plus_plus(C)) ) ).

% add.ac_operator_axioms
tff(fact_6018_semilattice__neutr__set_Oinsert__remove,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(C),X: C] :
      ( lattic5652469242046573047tr_set(C,F,Z2)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( lattic5214292709420241887eutr_F(C,F,Z2,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),A4)) = aa(C,C,aa(C,fun(C,C),F,X),lattic5214292709420241887eutr_F(C,F,Z2,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ).

% semilattice_neutr_set.insert_remove
tff(fact_6019_semilattice__neutr__set_Oremove,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(C),X: C] :
      ( lattic5652469242046573047tr_set(C,F,Z2)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( member2(C,X,A4)
         => ( lattic5214292709420241887eutr_F(C,F,Z2,A4) = aa(C,C,aa(C,fun(C,C),F,X),lattic5214292709420241887eutr_F(C,F,Z2,minus_minus(set(C),A4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))))) ) ) ) ) ).

% semilattice_neutr_set.remove
tff(fact_6020_semilattice__neutr__set_Oclosed,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C,A4: set(C)] :
      ( lattic5652469242046573047tr_set(C,F,Z2)
     => ( aa(set(C),$o,finite_finite2(C),A4)
       => ( ( A4 != bot_bot(set(C)) )
         => ( ! [X2: C,Y2: C] : member2(C,aa(C,C,aa(C,fun(C,C),F,X2),Y2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X2),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Y2),bot_bot(set(C)))))
           => member2(C,lattic5214292709420241887eutr_F(C,F,Z2,A4),A4) ) ) ) ) ).

% semilattice_neutr_set.closed
tff(fact_6021_semilattice__neutr__set_Oempty,axiom,
    ! [C: $tType,F: fun(C,fun(C,C)),Z2: C] :
      ( lattic5652469242046573047tr_set(C,F,Z2)
     => ( lattic5214292709420241887eutr_F(C,F,Z2,bot_bot(set(C))) = Z2 ) ) ).

% semilattice_neutr_set.empty
tff(fact_6022_of__rat__neg__one,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ( field_char_0_of_rat(C,aa(rat,rat,uminus_uminus(rat),one_one(rat))) = aa(C,C,uminus_uminus(C),one_one(C)) ) ) ).

% of_rat_neg_one
tff(fact_6023_null__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),$o),$o,aa(fun(list(C),$o),fun(fun(list(D),$o),$o),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal($o)),null(C)),null(D)) ).

% null_transfer
tff(fact_6024_of__rat__1,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ( field_char_0_of_rat(C,one_one(rat)) = one_one(C) ) ) ).

% of_rat_1
tff(fact_6025_of__rat__eq__1__iff,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: rat] :
          ( ( field_char_0_of_rat(C,A3) = one_one(C) )
        <=> ( A3 = one_one(rat) ) ) ) ).

% of_rat_eq_1_iff
tff(fact_6026_one__eq__of__rat__iff,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: rat] :
          ( ( one_one(C) = field_char_0_of_rat(C,A3) )
        <=> ( one_one(rat) = A3 ) ) ) ).

% one_eq_of_rat_iff
tff(fact_6027_one__le__of__rat__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [R3: rat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),field_char_0_of_rat(C,R3))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less_eq(rat),one_one(rat)),R3) ) ) ).

% one_le_of_rat_iff
tff(fact_6028_of__rat__le__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [R3: rat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),field_char_0_of_rat(C,R3)),one_one(C))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less_eq(rat),R3),one_one(rat)) ) ) ).

% of_rat_le_1_iff
tff(fact_6029_one__less__of__rat__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [R3: rat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),field_char_0_of_rat(C,R3))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less(rat),one_one(rat)),R3) ) ) ).

% one_less_of_rat_iff
tff(fact_6030_of__rat__less__1__iff,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [R3: rat] :
          ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),field_char_0_of_rat(C,R3)),one_one(C))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less(rat),R3),one_one(rat)) ) ) ).

% of_rat_less_1_iff
tff(fact_6031_list_Omap__transfer,axiom,
    ! [C: $tType,D: $tType,F4: $tType,E2: $tType,Rb: fun(C,fun(E2,$o)),Sd: fun(D,fun(F4,$o))] : aa(fun(fun(E2,F4),fun(list(E2),list(F4))),$o,aa(fun(fun(C,D),fun(list(C),list(D))),fun(fun(fun(E2,F4),fun(list(E2),list(F4))),$o),bNF_rel_fun(fun(C,D),fun(E2,F4),fun(list(C),list(D)),fun(list(E2),list(F4)),bNF_rel_fun(C,E2,D,F4,Rb,Sd),bNF_rel_fun(list(C),list(E2),list(D),list(F4),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),Rb),aa(fun(D,fun(F4,$o)),fun(list(D),fun(list(F4),$o)),list_all2(D,F4),Sd))),map(C,D)),map(E2,F4)) ).

% list.map_transfer
tff(fact_6032_foldr__transfer,axiom,
    ! [C: $tType,D: $tType,F4: $tType,E2: $tType,A4: fun(C,fun(E2,$o)),B3: fun(D,fun(F4,$o))] : aa(fun(fun(E2,fun(F4,F4)),fun(list(E2),fun(F4,F4))),$o,aa(fun(fun(C,fun(D,D)),fun(list(C),fun(D,D))),fun(fun(fun(E2,fun(F4,F4)),fun(list(E2),fun(F4,F4))),$o),bNF_rel_fun(fun(C,fun(D,D)),fun(E2,fun(F4,F4)),fun(list(C),fun(D,D)),fun(list(E2),fun(F4,F4)),bNF_rel_fun(C,E2,fun(D,D),fun(F4,F4),A4,bNF_rel_fun(D,F4,D,F4,B3,B3)),bNF_rel_fun(list(C),list(E2),fun(D,D),fun(F4,F4),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),A4),bNF_rel_fun(D,F4,D,F4,B3,B3))),foldr(C,D)),foldr(E2,F4)) ).

% foldr_transfer
tff(fact_6033_of__rat__mult,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [A3: rat,B2: rat] : field_char_0_of_rat(C,aa(rat,rat,aa(rat,fun(rat,rat),times_times(rat),A3),B2)) = aa(C,C,aa(C,fun(C,C),times_times(C),field_char_0_of_rat(C,A3)),field_char_0_of_rat(C,B2)) ) ).

% of_rat_mult
tff(fact_6034_foldl__transfer,axiom,
    ! [C: $tType,D: $tType,F4: $tType,E2: $tType,B3: fun(C,fun(E2,$o)),A4: fun(D,fun(F4,$o))] : aa(fun(fun(E2,fun(F4,E2)),fun(E2,fun(list(F4),E2))),$o,aa(fun(fun(C,fun(D,C)),fun(C,fun(list(D),C))),fun(fun(fun(E2,fun(F4,E2)),fun(E2,fun(list(F4),E2))),$o),bNF_rel_fun(fun(C,fun(D,C)),fun(E2,fun(F4,E2)),fun(C,fun(list(D),C)),fun(E2,fun(list(F4),E2)),bNF_rel_fun(C,E2,fun(D,C),fun(F4,E2),B3,bNF_rel_fun(D,F4,C,E2,A4,B3)),bNF_rel_fun(C,E2,fun(list(D),C),fun(list(F4),E2),B3,bNF_rel_fun(list(D),list(F4),C,E2,aa(fun(D,fun(F4,$o)),fun(list(D),fun(list(F4),$o)),list_all2(D,F4),A4),B3))),foldl(C,D)),foldl(E2,F4)) ).

% foldl_transfer
tff(fact_6035_List_Ofold__transfer,axiom,
    ! [C: $tType,D: $tType,F4: $tType,E2: $tType,A4: fun(C,fun(E2,$o)),B3: fun(D,fun(F4,$o))] : aa(fun(fun(E2,fun(F4,F4)),fun(list(E2),fun(F4,F4))),$o,aa(fun(fun(C,fun(D,D)),fun(list(C),fun(D,D))),fun(fun(fun(E2,fun(F4,F4)),fun(list(E2),fun(F4,F4))),$o),bNF_rel_fun(fun(C,fun(D,D)),fun(E2,fun(F4,F4)),fun(list(C),fun(D,D)),fun(list(E2),fun(F4,F4)),bNF_rel_fun(C,E2,fun(D,D),fun(F4,F4),A4,bNF_rel_fun(D,F4,D,F4,B3,B3)),bNF_rel_fun(list(C),list(E2),fun(D,D),fun(F4,F4),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),A4),bNF_rel_fun(D,F4,D,F4,B3,B3))),fold(C,D)),fold(E2,F4)) ).

% List.fold_transfer
tff(fact_6036_list_Orec__transfer,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,S: fun(C,fun(D,$o)),R: fun(E2,fun(F4,$o))] : aa(fun(D,fun(fun(F4,fun(list(F4),fun(D,D))),fun(list(F4),D))),$o,aa(fun(C,fun(fun(E2,fun(list(E2),fun(C,C))),fun(list(E2),C))),fun(fun(D,fun(fun(F4,fun(list(F4),fun(D,D))),fun(list(F4),D))),$o),bNF_rel_fun(C,D,fun(fun(E2,fun(list(E2),fun(C,C))),fun(list(E2),C)),fun(fun(F4,fun(list(F4),fun(D,D))),fun(list(F4),D)),S,bNF_rel_fun(fun(E2,fun(list(E2),fun(C,C))),fun(F4,fun(list(F4),fun(D,D))),fun(list(E2),C),fun(list(F4),D),bNF_rel_fun(E2,F4,fun(list(E2),fun(C,C)),fun(list(F4),fun(D,D)),R,bNF_rel_fun(list(E2),list(F4),fun(C,C),fun(D,D),aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),R),bNF_rel_fun(C,D,C,D,S,S))),bNF_rel_fun(list(E2),list(F4),C,D,aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),R),S))),rec_list(C,E2)),rec_list(D,F4)) ).

% list.rec_transfer
tff(fact_6037_prod__list__transfer,axiom,
    ! [C: $tType,D: $tType] :
      ( ( monoid_mult(D)
        & monoid_mult(C) )
     => ! [A4: fun(C,fun(D,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),A4,one_one(C)),one_one(D))
         => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),A4,bNF_rel_fun(C,D,C,D,A4,A4)),times_times(C)),times_times(D))
           => aa(fun(list(D),D),$o,aa(fun(list(C),C),fun(fun(list(D),D),$o),bNF_rel_fun(list(C),list(D),C,D,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),A4),groups5270119922927024881d_list(C)),groups5270119922927024881d_list(D)) ) ) ) ).

% prod_list_transfer
tff(fact_6038_horner__sum__transfer,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType] :
      ( ( comm_semiring_0(D)
        & comm_semiring_0(C) )
     => ! [A4: fun(C,fun(D,$o)),B3: fun(E2,fun(F4,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),A4,zero_zero(C)),zero_zero(D))
         => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),A4,bNF_rel_fun(C,D,C,D,A4,A4)),plus_plus(C)),plus_plus(D))
           => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),A4,bNF_rel_fun(C,D,C,D,A4,A4)),times_times(C)),times_times(D))
             => aa(fun(fun(F4,D),fun(D,fun(list(F4),D))),$o,aa(fun(fun(E2,C),fun(C,fun(list(E2),C))),fun(fun(fun(F4,D),fun(D,fun(list(F4),D))),$o),bNF_rel_fun(fun(E2,C),fun(F4,D),fun(C,fun(list(E2),C)),fun(D,fun(list(F4),D)),bNF_rel_fun(E2,F4,C,D,B3,A4),bNF_rel_fun(C,D,fun(list(E2),C),fun(list(F4),D),A4,bNF_rel_fun(list(E2),list(F4),C,D,aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),B3),A4))),groups4207007520872428315er_sum(E2,C)),groups4207007520872428315er_sum(F4,D)) ) ) ) ) ).

% horner_sum_transfer
tff(fact_6039_transfer__rule__numeral,axiom,
    ! [C: $tType,D: $tType] :
      ( ( monoid_add(D)
        & semiring_numeral(D)
        & monoid_add(C)
        & semiring_numeral(C) )
     => ! [R: fun(C,fun(D,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),R,zero_zero(C)),zero_zero(D))
         => ( aa(D,$o,aa(C,fun(D,$o),R,one_one(C)),one_one(D))
           => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),R,bNF_rel_fun(C,D,C,D,R,R)),plus_plus(C)),plus_plus(D))
             => aa(fun(num,D),$o,aa(fun(num,C),fun(fun(num,D),$o),bNF_rel_fun(num,num,C,D,fequal(num),R),numeral_numeral(C)),numeral_numeral(D)) ) ) ) ) ).

% transfer_rule_numeral
tff(fact_6040_transfer__rule__of__int,axiom,
    ! [C: $tType,D: $tType] :
      ( ( ring_1(D)
        & ring_1(C) )
     => ! [R: fun(C,fun(D,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),R,zero_zero(C)),zero_zero(D))
         => ( aa(D,$o,aa(C,fun(D,$o),R,one_one(C)),one_one(D))
           => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),R,bNF_rel_fun(C,D,C,D,R,R)),plus_plus(C)),plus_plus(D))
             => ( aa(fun(D,D),$o,aa(fun(C,C),fun(fun(D,D),$o),bNF_rel_fun(C,D,C,D,R,R),uminus_uminus(C)),uminus_uminus(D))
               => aa(fun(int,D),$o,aa(fun(int,C),fun(fun(int,D),$o),bNF_rel_fun(int,int,C,D,fequal(int),R),ring_1_of_int(C)),ring_1_of_int(D)) ) ) ) ) ) ).

% transfer_rule_of_int
tff(fact_6041_power__transfer,axiom,
    ! [C: $tType,D: $tType] :
      ( ( power(D)
        & power(C) )
     => ! [R: fun(C,fun(D,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),R,one_one(C)),one_one(D))
         => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),R,bNF_rel_fun(C,D,C,D,R,R)),times_times(C)),times_times(D))
           => aa(fun(D,fun(nat,D)),$o,aa(fun(C,fun(nat,C)),fun(fun(D,fun(nat,D)),$o),bNF_rel_fun(C,D,fun(nat,C),fun(nat,D),R,bNF_rel_fun(nat,nat,C,D,fequal(nat),R)),power_power(C)),power_power(D)) ) ) ) ).

% power_transfer
tff(fact_6042_list_Odisc__transfer_I2_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o))] : aa(fun(list(D),$o),$o,aa(fun(list(C),$o),fun(fun(list(D),$o),$o),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),fequal($o)),aTP_Lamp_fi(list(C),$o)),aTP_Lamp_fs(list(D),$o)) ).

% list.disc_transfer(2)
tff(fact_6043_list_Odisc__transfer_I1_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o))] : aa(fun(list(D),$o),$o,aa(fun(list(C),$o),fun(fun(list(D),$o),$o),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),fequal($o)),aTP_Lamp_ub(list(C),$o)),aTP_Lamp_uc(list(D),$o)) ).

% list.disc_transfer(1)
tff(fact_6044_transfer__rule__of__nat,axiom,
    ! [C: $tType,D: $tType] :
      ( ( semiring_1(D)
        & semiring_1(C) )
     => ! [R: fun(C,fun(D,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),R,zero_zero(C)),zero_zero(D))
         => ( aa(D,$o,aa(C,fun(D,$o),R,one_one(C)),one_one(D))
           => ( aa(fun(D,fun(D,D)),$o,aa(fun(C,fun(C,C)),fun(fun(D,fun(D,D)),$o),bNF_rel_fun(C,D,fun(C,C),fun(D,D),R,bNF_rel_fun(C,D,C,D,R,R)),plus_plus(C)),plus_plus(D))
             => aa(fun(nat,D),$o,aa(fun(nat,C),fun(fun(nat,D),$o),bNF_rel_fun(nat,nat,C,D,fequal(nat),R),semiring_1_of_nat(C)),semiring_1_of_nat(D)) ) ) ) ) ).

% transfer_rule_of_nat
tff(fact_6045_list__ex__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),$o)),$o,aa(fun(fun(C,$o),fun(list(C),$o)),fun(fun(fun(D,$o),fun(list(D),$o)),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),$o),fun(list(D),$o),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal($o))),list_ex(C)),list_ex(D)) ).

% list_ex_transfer
tff(fact_6046_list_Octr__transfer_I2_J,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o))] : aa(fun(D,fun(list(D),list(D))),$o,aa(fun(C,fun(list(C),list(C))),fun(fun(D,fun(list(D),list(D))),$o),bNF_rel_fun(C,D,fun(list(C),list(C)),fun(list(D),list(D)),R,bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R))),cons(C)),cons(D)) ).

% list.ctr_transfer(2)
tff(fact_6047_subseqs__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),list(list(D))),$o,aa(fun(list(C),list(list(C))),fun(fun(list(D),list(list(D))),$o),bNF_rel_fun(list(C),list(D),list(list(C)),list(list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(list(C),fun(list(D),$o)),fun(list(list(C)),fun(list(list(D)),$o)),list_all2(list(C),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),subseqs(C)),subseqs(D)) ).

% subseqs_transfer
tff(fact_6048_length__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),nat),$o,aa(fun(list(C),nat),fun(fun(list(D),nat),$o),bNF_rel_fun(list(C),list(D),nat,nat,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal(nat)),size_size(list(C))),size_size(list(D))) ).

% length_transfer
tff(fact_6049_successively__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,fun(D,$o)),fun(list(D),$o)),$o,aa(fun(fun(C,fun(C,$o)),fun(list(C),$o)),fun(fun(fun(D,fun(D,$o)),fun(list(D),$o)),$o),bNF_rel_fun(fun(C,fun(C,$o)),fun(D,fun(D,$o)),fun(list(C),$o),fun(list(D),$o),bNF_rel_fun(C,D,fun(C,$o),fun(D,$o),A4,bNF_rel_fun(C,D,$o,$o,A4,fequal($o))),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal($o))),successively(C)),successively(D)) ).

% successively_transfer
tff(fact_6050_splice__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),fun(list(D),list(D))),$o,aa(fun(list(C),fun(list(C),list(C))),fun(fun(list(D),fun(list(D),list(D))),$o),bNF_rel_fun(list(C),list(D),fun(list(C),list(C)),fun(list(D),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),splice(C)),splice(D)) ).

% splice_transfer
tff(fact_6051_replicate__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(nat,fun(D,list(D))),$o,aa(fun(nat,fun(C,list(C))),fun(fun(nat,fun(D,list(D))),$o),bNF_rel_fun(nat,nat,fun(C,list(C)),fun(D,list(D)),fequal(nat),bNF_rel_fun(C,D,list(C),list(D),A4,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),replicate(C)),replicate(D)) ).

% replicate_transfer
tff(fact_6052_rotate__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(nat,fun(list(D),list(D))),$o,aa(fun(nat,fun(list(C),list(C))),fun(fun(nat,fun(list(D),list(D))),$o),bNF_rel_fun(nat,nat,fun(list(C),list(C)),fun(list(D),list(D)),fequal(nat),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),rotate(C)),rotate(D)) ).

% rotate_transfer
tff(fact_6053_list_Orel__transfer,axiom,
    ! [C: $tType,D: $tType,F4: $tType,E2: $tType,Sa: fun(C,fun(E2,$o)),Sc: fun(D,fun(F4,$o))] : aa(fun(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o))),$o,aa(fun(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o))),fun(fun(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o))),$o),bNF_rel_fun(fun(C,fun(D,$o)),fun(E2,fun(F4,$o)),fun(list(C),fun(list(D),$o)),fun(list(E2),fun(list(F4),$o)),bNF_rel_fun(C,E2,fun(D,$o),fun(F4,$o),Sa,bNF_rel_fun(D,F4,$o,$o,Sc,fequal($o))),bNF_rel_fun(list(C),list(E2),fun(list(D),$o),fun(list(F4),$o),aa(fun(C,fun(E2,$o)),fun(list(C),fun(list(E2),$o)),list_all2(C,E2),Sa),bNF_rel_fun(list(D),list(F4),$o,$o,aa(fun(D,fun(F4,$o)),fun(list(D),fun(list(F4),$o)),list_all2(D,F4),Sc),fequal($o)))),list_all2(C,D)),list_all2(E2,F4)) ).

% list.rel_transfer
tff(fact_6054_dropWhile__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),list(D))),$o,aa(fun(fun(C,$o),fun(list(C),list(C))),fun(fun(fun(D,$o),fun(list(D),list(D))),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),list(C)),fun(list(D),list(D)),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),dropWhile(C)),dropWhile(D)) ).

% dropWhile_transfer
tff(fact_6055_list__update__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),fun(nat,fun(D,list(D)))),$o,aa(fun(list(C),fun(nat,fun(C,list(C)))),fun(fun(list(D),fun(nat,fun(D,list(D)))),$o),bNF_rel_fun(list(C),list(D),fun(nat,fun(C,list(C))),fun(nat,fun(D,list(D))),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(nat,nat,fun(C,list(C)),fun(D,list(D)),fequal(nat),bNF_rel_fun(C,D,list(C),list(D),A4,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)))),list_update(C)),list_update(D)) ).

% list_update_transfer
tff(fact_6056_take__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(nat,fun(list(D),list(D))),$o,aa(fun(nat,fun(list(C),list(C))),fun(fun(nat,fun(list(D),list(D))),$o),bNF_rel_fun(nat,nat,fun(list(C),list(C)),fun(list(D),list(D)),fequal(nat),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),take(C)),take(D)) ).

% take_transfer
tff(fact_6057_drop__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(nat,fun(list(D),list(D))),$o,aa(fun(nat,fun(list(C),list(C))),fun(fun(nat,fun(list(D),list(D))),$o),bNF_rel_fun(nat,nat,fun(list(C),list(C)),fun(list(D),list(D)),fequal(nat),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),drop(C)),drop(D)) ).

% drop_transfer
tff(fact_6058_append__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),fun(list(D),list(D))),$o,aa(fun(list(C),fun(list(C),list(C))),fun(fun(list(D),fun(list(D),list(D))),$o),bNF_rel_fun(list(C),list(D),fun(list(C),list(C)),fun(list(D),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),append(C)),append(D)) ).

% append_transfer
tff(fact_6059_List_Ofilter__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),list(D))),$o,aa(fun(fun(C,$o),fun(list(C),list(C))),fun(fun(fun(D,$o),fun(list(D),list(D))),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),list(C)),fun(list(D),list(D)),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),filter2(C)),filter2(D)) ).

% List.filter_transfer
tff(fact_6060_takeWhile__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),list(D))),$o,aa(fun(fun(C,$o),fun(list(C),list(C))),fun(fun(fun(D,$o),fun(list(D),list(D))),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),list(C)),fun(list(D),list(D)),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),takeWhile(C)),takeWhile(D)) ).

% takeWhile_transfer
tff(fact_6061_tl__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),list(D)),$o,aa(fun(list(C),list(C)),fun(fun(list(D),list(D)),$o),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),tl(C)),tl(D)) ).

% tl_transfer
tff(fact_6062_rev__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),list(D)),$o,aa(fun(list(C),list(C)),fun(fun(list(D),list(D)),$o),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),rev(C)),rev(D)) ).

% rev_transfer
tff(fact_6063_concat__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(list(D)),list(D)),$o,aa(fun(list(list(C)),list(C)),fun(fun(list(list(D)),list(D)),$o),bNF_rel_fun(list(list(C)),list(list(D)),list(C),list(D),aa(fun(list(C),fun(list(D),$o)),fun(list(list(C)),fun(list(list(D)),$o)),list_all2(list(C),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),concat(C)),concat(D)) ).

% concat_transfer
tff(fact_6064_butlast__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),list(D)),$o,aa(fun(list(C),list(C)),fun(fun(list(D),list(D)),$o),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),butlast(C)),butlast(D)) ).

% butlast_transfer
tff(fact_6065_rotate1__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),list(D)),$o,aa(fun(list(C),list(C)),fun(fun(list(D),list(D)),$o),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),rotate1(C)),rotate1(D)) ).

% rotate1_transfer
tff(fact_6066_list_Ocase__transfer,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,S: fun(C,fun(D,$o)),R: fun(E2,fun(F4,$o))] : aa(fun(D,fun(fun(F4,fun(list(F4),D)),fun(list(F4),D))),$o,aa(fun(C,fun(fun(E2,fun(list(E2),C)),fun(list(E2),C))),fun(fun(D,fun(fun(F4,fun(list(F4),D)),fun(list(F4),D))),$o),bNF_rel_fun(C,D,fun(fun(E2,fun(list(E2),C)),fun(list(E2),C)),fun(fun(F4,fun(list(F4),D)),fun(list(F4),D)),S,bNF_rel_fun(fun(E2,fun(list(E2),C)),fun(F4,fun(list(F4),D)),fun(list(E2),C),fun(list(F4),D),bNF_rel_fun(E2,F4,fun(list(E2),C),fun(list(F4),D),R,bNF_rel_fun(list(E2),list(F4),C,D,aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),R),S)),bNF_rel_fun(list(E2),list(F4),C,D,aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),R),S))),case_list(C,E2)),case_list(D,F4)) ).

% list.case_transfer
tff(fact_6067_transfer__rule__of__bool,axiom,
    ! [C: $tType,D: $tType] :
      ( ( zero_neq_one(D)
        & zero_neq_one(C) )
     => ! [R: fun(C,fun(D,$o))] :
          ( aa(D,$o,aa(C,fun(D,$o),R,zero_zero(C)),zero_zero(D))
         => ( aa(D,$o,aa(C,fun(D,$o),R,one_one(C)),one_one(D))
           => aa(fun($o,D),$o,aa(fun($o,C),fun(fun($o,D),$o),bNF_rel_fun($o,$o,C,D,fequal($o),R),zero_neq_one_of_bool(C)),zero_neq_one_of_bool(D)) ) ) ) ).

% transfer_rule_of_bool
tff(fact_6068_product__lists__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(list(D)),list(list(D))),$o,aa(fun(list(list(C)),list(list(C))),fun(fun(list(list(D)),list(list(D))),$o),bNF_rel_fun(list(list(C)),list(list(D)),list(list(C)),list(list(D)),aa(fun(list(C),fun(list(D),$o)),fun(list(list(C)),fun(list(list(D)),$o)),list_all2(list(C),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),aa(fun(list(C),fun(list(D),$o)),fun(list(list(C)),fun(list(list(D)),$o)),list_all2(list(C),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),product_lists(C)),product_lists(D)) ).

% product_lists_transfer
tff(fact_6069_list_Opred__transfer,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),$o)),$o,aa(fun(fun(C,$o),fun(list(C),$o)),fun(fun(fun(D,$o),fun(list(D),$o)),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),$o),fun(list(D),$o),bNF_rel_fun(C,D,$o,$o,R,fequal($o)),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),fequal($o))),list_all(C)),list_all(D)) ).

% list.pred_transfer
tff(fact_6070_list__all__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),$o)),$o,aa(fun(fun(C,$o),fun(list(C),$o)),fun(fun(fun(D,$o),fun(list(D),$o)),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),$o),fun(list(D),$o),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal($o))),list_all(C)),list_all(D)) ).

% list_all_transfer
tff(fact_6071_List_Oinsert__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(D,fun(list(D),list(D))),$o,aa(fun(C,fun(list(C),list(C))),fun(fun(D,fun(list(D),list(D))),$o),bNF_rel_fun(C,D,fun(list(C),list(C)),fun(list(D),list(D)),A4,bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),insert(C)),insert(D)) ) ).

% List.insert_transfer
tff(fact_6072_removeAll__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(D,fun(list(D),list(D))),$o,aa(fun(C,fun(list(C),list(C))),fun(fun(D,fun(list(D),list(D))),$o),bNF_rel_fun(C,D,fun(list(C),list(C)),fun(list(D),list(D)),A4,bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),removeAll(C)),removeAll(D)) ) ).

% removeAll_transfer
tff(fact_6073_list_Obi__unique__rel,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,R)
     => bi_unique(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R)) ) ).

% list.bi_unique_rel
tff(fact_6074_remdups__adj__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(list(D),list(D)),$o,aa(fun(list(C),list(C)),fun(fun(list(D),list(D)),$o),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),remdups_adj(C)),remdups_adj(D)) ) ).

% remdups_adj_transfer
tff(fact_6075_remdups__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(list(D),list(D)),$o,aa(fun(list(C),list(C)),fun(fun(list(D),list(D)),$o),bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),remdups(C)),remdups(D)) ) ).

% remdups_transfer
tff(fact_6076_distinct__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(list(D),$o),$o,aa(fun(list(C),$o),fun(fun(list(D),$o),$o),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal($o)),distinct(C)),distinct(D)) ) ).

% distinct_transfer
tff(fact_6077_distinct__adj__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(list(D),$o),$o,aa(fun(list(C),$o),fun(fun(list(D),$o),$o),bNF_rel_fun(list(C),list(D),$o,$o,aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),fequal($o)),distinct_adj(C)),distinct_adj(D)) ) ).

% distinct_adj_transfer
tff(fact_6078_remove1__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(D,fun(list(D),list(D))),$o,aa(fun(C,fun(list(C),list(C))),fun(fun(D,fun(list(D),list(D))),$o),bNF_rel_fun(C,D,fun(list(C),list(C)),fun(list(D),list(D)),A4,bNF_rel_fun(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),remove1(C)),remove1(D)) ) ).

% remove1_transfer
tff(fact_6079_monotone__parametric,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(E2,fun(F4,$o))] :
      ( bi_total(C,D,A4)
     => aa(fun(fun(D,fun(D,$o)),fun(fun(F4,fun(F4,$o)),fun(fun(D,F4),$o))),$o,aa(fun(fun(C,fun(C,$o)),fun(fun(E2,fun(E2,$o)),fun(fun(C,E2),$o))),fun(fun(fun(D,fun(D,$o)),fun(fun(F4,fun(F4,$o)),fun(fun(D,F4),$o))),$o),bNF_rel_fun(fun(C,fun(C,$o)),fun(D,fun(D,$o)),fun(fun(E2,fun(E2,$o)),fun(fun(C,E2),$o)),fun(fun(F4,fun(F4,$o)),fun(fun(D,F4),$o)),bNF_rel_fun(C,D,fun(C,$o),fun(D,$o),A4,bNF_rel_fun(C,D,$o,$o,A4,fequal($o))),bNF_rel_fun(fun(E2,fun(E2,$o)),fun(F4,fun(F4,$o)),fun(fun(C,E2),$o),fun(fun(D,F4),$o),bNF_rel_fun(E2,F4,fun(E2,$o),fun(F4,$o),B3,bNF_rel_fun(E2,F4,$o,$o,B3,fequal($o))),bNF_rel_fun(fun(C,E2),fun(D,F4),$o,$o,bNF_rel_fun(C,D,E2,F4,A4,B3),fequal($o)))),comple7038119648293358887notone(C,E2)),comple7038119648293358887notone(D,F4)) ) ).

% monotone_parametric
tff(fact_6080_partition__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),product_prod(list(D),list(D)))),$o,aa(fun(fun(C,$o),fun(list(C),product_prod(list(C),list(C)))),fun(fun(fun(D,$o),fun(list(D),product_prod(list(D),list(D)))),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),product_prod(list(C),list(C))),fun(list(D),product_prod(list(D),list(D))),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),product_prod(list(C),list(C)),product_prod(list(D),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),basic_rel_prod(list(C),list(D),list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)))),partition(C)),partition(D)) ).

% partition_transfer
tff(fact_6081_zip__transfer,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(E2,fun(F4,$o))] : aa(fun(list(D),fun(list(F4),list(product_prod(D,F4)))),$o,aa(fun(list(C),fun(list(E2),list(product_prod(C,E2)))),fun(fun(list(D),fun(list(F4),list(product_prod(D,F4)))),$o),bNF_rel_fun(list(C),list(D),fun(list(E2),list(product_prod(C,E2))),fun(list(F4),list(product_prod(D,F4))),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(list(E2),list(F4),list(product_prod(C,E2)),list(product_prod(D,F4)),aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),B3),aa(fun(product_prod(C,E2),fun(product_prod(D,F4),$o)),fun(list(product_prod(C,E2)),fun(list(product_prod(D,F4)),$o)),list_all2(product_prod(C,E2),product_prod(D,F4)),basic_rel_prod(C,D,E2,F4,A4,B3)))),zip(C,E2)),zip(D,F4)) ).

% zip_transfer
tff(fact_6082_list_Obi__total__rel,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,$o))] :
      ( bi_total(C,D,R)
     => bi_total(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R)) ) ).

% list.bi_total_rel
tff(fact_6083_product__transfer,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(E2,fun(F4,$o))] : aa(fun(list(D),fun(list(F4),list(product_prod(D,F4)))),$o,aa(fun(list(C),fun(list(E2),list(product_prod(C,E2)))),fun(fun(list(D),fun(list(F4),list(product_prod(D,F4)))),$o),bNF_rel_fun(list(C),list(D),fun(list(E2),list(product_prod(C,E2))),fun(list(F4),list(product_prod(D,F4))),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(list(E2),list(F4),list(product_prod(C,E2)),list(product_prod(D,F4)),aa(fun(E2,fun(F4,$o)),fun(list(E2),fun(list(F4),$o)),list_all2(E2,F4),B3),aa(fun(product_prod(C,E2),fun(product_prod(D,F4),$o)),fun(list(product_prod(C,E2)),fun(list(product_prod(D,F4)),$o)),list_all2(product_prod(C,E2),product_prod(D,F4)),basic_rel_prod(C,D,E2,F4,A4,B3)))),product(C,E2)),product(D,F4)) ).

% product_transfer
tff(fact_6084_fun__ord__parametric,axiom,
    ! [E2: $tType,F4: $tType,C: $tType,D: $tType,H8: $tType,G4: $tType,C4: fun(C,fun(D,$o)),A4: fun(E2,fun(G4,$o)),B3: fun(F4,fun(H8,$o))] :
      ( bi_total(C,D,C4)
     => aa(fun(fun(G4,fun(H8,$o)),fun(fun(D,G4),fun(fun(D,H8),$o))),$o,aa(fun(fun(E2,fun(F4,$o)),fun(fun(C,E2),fun(fun(C,F4),$o))),fun(fun(fun(G4,fun(H8,$o)),fun(fun(D,G4),fun(fun(D,H8),$o))),$o),bNF_rel_fun(fun(E2,fun(F4,$o)),fun(G4,fun(H8,$o)),fun(fun(C,E2),fun(fun(C,F4),$o)),fun(fun(D,G4),fun(fun(D,H8),$o)),bNF_rel_fun(E2,G4,fun(F4,$o),fun(H8,$o),A4,bNF_rel_fun(F4,H8,$o,$o,B3,fequal($o))),bNF_rel_fun(fun(C,E2),fun(D,G4),fun(fun(C,F4),$o),fun(fun(D,H8),$o),bNF_rel_fun(C,D,E2,G4,C4,A4),bNF_rel_fun(fun(C,F4),fun(D,H8),$o,$o,bNF_rel_fun(C,D,F4,H8,C4,B3),fequal($o)))),partial_fun_ord(E2,F4,C)),partial_fun_ord(G4,H8,D)) ) ).

% fun_ord_parametric
tff(fact_6085_rtrancl__parametric,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => ( bi_total(C,D,A4)
       => aa(fun(set(product_prod(D,D)),set(product_prod(D,D))),$o,aa(fun(set(product_prod(C,C)),set(product_prod(C,C))),fun(fun(set(product_prod(D,D)),set(product_prod(D,D))),$o),bNF_rel_fun(set(product_prod(C,C)),set(product_prod(D,D)),set(product_prod(C,C)),set(product_prod(D,D)),bNF_rel_set(product_prod(C,C),product_prod(D,D),basic_rel_prod(C,D,C,D,A4,A4)),bNF_rel_set(product_prod(C,C),product_prod(D,D),basic_rel_prod(C,D,C,D,A4,A4))),transitive_rtrancl(C)),transitive_rtrancl(D)) ) ) ).

% rtrancl_parametric
tff(fact_6086_list_Oset__transfer,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o))] : aa(fun(list(D),set(D)),$o,aa(fun(list(C),set(C)),fun(fun(list(D),set(D)),$o),bNF_rel_fun(list(C),list(D),set(C),set(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R),bNF_rel_set(C,D,R)),set2(C)),set2(D)) ).

% list.set_transfer
tff(fact_6087_listset__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(set(D)),set(list(D))),$o,aa(fun(list(set(C)),set(list(C))),fun(fun(list(set(D)),set(list(D))),$o),bNF_rel_fun(list(set(C)),list(set(D)),set(list(C)),set(list(D)),aa(fun(set(C),fun(set(D),$o)),fun(list(set(C)),fun(list(set(D)),$o)),list_all2(set(C),set(D)),bNF_rel_set(C,D,A4)),bNF_rel_set(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),listset(C)),listset(D)) ).

% listset_transfer
tff(fact_6088_set__Cons__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(set(D),fun(set(list(D)),set(list(D)))),$o,aa(fun(set(C),fun(set(list(C)),set(list(C)))),fun(fun(set(D),fun(set(list(D)),set(list(D)))),$o),bNF_rel_fun(set(C),set(D),fun(set(list(C)),set(list(C))),fun(set(list(D)),set(list(D))),bNF_rel_set(C,D,A4),bNF_rel_fun(set(list(C)),set(list(D)),set(list(C)),set(list(D)),bNF_rel_set(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)),bNF_rel_set(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)))),set_Cons(C)),set_Cons(D)) ).

% set_Cons_transfer
tff(fact_6089_lists__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(set(D),set(list(D))),$o,aa(fun(set(C),set(list(C))),fun(fun(set(D),set(list(D))),$o),bNF_rel_fun(set(C),set(D),set(list(C)),set(list(D)),bNF_rel_set(C,D,A4),bNF_rel_set(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),lists(C)),lists(D)) ).

% lists_transfer
tff(fact_6090_inter__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => aa(fun(set(D),fun(set(D),set(D))),$o,aa(fun(set(C),fun(set(C),set(C))),fun(fun(set(D),fun(set(D),set(D))),$o),bNF_rel_fun(set(C),set(D),fun(set(C),set(C)),fun(set(D),set(D)),bNF_rel_set(C,D,A4),bNF_rel_fun(set(C),set(D),set(C),set(D),bNF_rel_set(C,D,A4),bNF_rel_set(C,D,A4))),inf_inf(set(C))),inf_inf(set(D))) ) ).

% inter_transfer
tff(fact_6091_fun__lub__parametric,axiom,
    ! [C: $tType,E2: $tType,G4: $tType,H8: $tType,F4: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(E2,fun(F4,$o)),C4: fun(G4,fun(H8,$o))] :
      ( bi_total(C,D,A4)
     => ( bi_unique(C,D,A4)
       => aa(fun(fun(set(D),F4),fun(set(fun(H8,D)),fun(H8,F4))),$o,aa(fun(fun(set(C),E2),fun(set(fun(G4,C)),fun(G4,E2))),fun(fun(fun(set(D),F4),fun(set(fun(H8,D)),fun(H8,F4))),$o),bNF_rel_fun(fun(set(C),E2),fun(set(D),F4),fun(set(fun(G4,C)),fun(G4,E2)),fun(set(fun(H8,D)),fun(H8,F4)),bNF_rel_fun(set(C),set(D),E2,F4,bNF_rel_set(C,D,A4),B3),bNF_rel_fun(set(fun(G4,C)),set(fun(H8,D)),fun(G4,E2),fun(H8,F4),bNF_rel_set(fun(G4,C),fun(H8,D),bNF_rel_fun(G4,H8,C,D,C4,A4)),bNF_rel_fun(G4,H8,E2,F4,C4,B3))),partial_fun_lub(C,E2,G4)),partial_fun_lub(D,F4,H8)) ) ) ).

% fun_lub_parametric
tff(fact_6092_nths__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),fun(set(nat),list(D))),$o,aa(fun(list(C),fun(set(nat),list(C))),fun(fun(list(D),fun(set(nat),list(D))),$o),bNF_rel_fun(list(C),list(D),fun(set(nat),list(C)),fun(set(nat),list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(set(nat),set(nat),list(C),list(D),bNF_rel_set(nat,nat,fequal(nat)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4))),nths(C)),nths(D)) ).

% nths_transfer
tff(fact_6093_shuffles__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(list(D),fun(list(D),set(list(D)))),$o,aa(fun(list(C),fun(list(C),set(list(C)))),fun(fun(list(D),fun(list(D),set(list(D)))),$o),bNF_rel_fun(list(C),list(D),fun(list(C),set(list(C))),fun(list(D),set(list(D))),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_fun(list(C),list(D),set(list(C)),set(list(D)),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),bNF_rel_set(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4)))),shuffles(C)),shuffles(D)) ).

% shuffles_transfer
tff(fact_6094_empty__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(set(D),$o,aa(set(C),fun(set(D),$o),bNF_rel_set(C,D,A4),bot_bot(set(C))),bot_bot(set(D))) ).

% empty_transfer
tff(fact_6095_vimage__right__total__transfer,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,B3: fun(C,fun(D,$o)),A4: fun(E2,fun(F4,$o))] :
      ( bi_unique(C,D,B3)
     => ( right_total(E2,F4,A4)
       => aa(fun(fun(F4,D),fun(set(D),set(F4))),$o,aa(fun(fun(E2,C),fun(set(C),set(E2))),fun(fun(fun(F4,D),fun(set(D),set(F4))),$o),bNF_rel_fun(fun(E2,C),fun(F4,D),fun(set(C),set(E2)),fun(set(D),set(F4)),bNF_rel_fun(E2,F4,C,D,A4,B3),bNF_rel_fun(set(C),set(D),set(E2),set(F4),bNF_rel_set(C,D,B3),bNF_rel_set(E2,F4,A4))),aTP_Lamp_ud(fun(E2,fun(F4,$o)),fun(fun(E2,C),fun(set(C),set(E2))),A4)),vimage(F4,D)) ) ) ).

% vimage_right_total_transfer
tff(fact_6096_find__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] : aa(fun(fun(D,$o),fun(list(D),option(D))),$o,aa(fun(fun(C,$o),fun(list(C),option(C))),fun(fun(fun(D,$o),fun(list(D),option(D))),$o),bNF_rel_fun(fun(C,$o),fun(D,$o),fun(list(C),option(C)),fun(list(D),option(D)),bNF_rel_fun(C,D,$o,$o,A4,fequal($o)),bNF_rel_fun(list(C),list(D),option(C),option(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),A4),rel_option(C,D,A4))),find(C)),find(D)) ).

% find_transfer
tff(fact_6097_right__total__Inter__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => ( right_total(C,D,A4)
       => aa(fun(set(set(D)),set(D)),$o,aa(fun(set(set(C)),set(C)),fun(fun(set(set(D)),set(D)),$o),bNF_rel_fun(set(set(C)),set(set(D)),set(C),set(D),bNF_rel_set(set(C),set(D),bNF_rel_set(C,D,A4)),bNF_rel_set(C,D,A4)),aTP_Lamp_ue(fun(C,fun(D,$o)),fun(set(set(C)),set(C)),A4)),complete_Inf_Inf(set(D))) ) ) ).

% right_total_Inter_transfer
tff(fact_6098_those__transfer,axiom,
    ! [C: $tType,D: $tType,Pa: fun(C,fun(D,$o))] : aa(fun(list(option(D)),option(list(D))),$o,aa(fun(list(option(C)),option(list(C))),fun(fun(list(option(D)),option(list(D))),$o),bNF_rel_fun(list(option(C)),list(option(D)),option(list(C)),option(list(D)),aa(fun(option(C),fun(option(D),$o)),fun(list(option(C)),fun(list(option(D)),$o)),list_all2(option(C),option(D)),rel_option(C,D,Pa)),rel_option(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),Pa))),those(C)),those(D)) ).

% those_transfer
tff(fact_6099_list_ODomainp__rel,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,$o))] : domainp(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R)) = aa(fun(C,$o),fun(list(C),$o),list_all(C),domainp(C,D,R)) ).

% list.Domainp_rel
tff(fact_6100_list_Oright__total__rel,axiom,
    ! [D: $tType,C: $tType,R: fun(C,fun(D,$o))] :
      ( right_total(C,D,R)
     => right_total(list(C),list(D),aa(fun(C,fun(D,$o)),fun(list(C),fun(list(D),$o)),list_all2(C,D),R)) ) ).

% list.right_total_rel
tff(fact_6101_right__total__Compl__transfer,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => ( right_total(C,D,A4)
       => aa(fun(set(D),set(D)),$o,aa(fun(set(C),set(C)),fun(fun(set(D),set(D)),$o),bNF_rel_fun(set(C),set(D),set(C),set(D),bNF_rel_set(C,D,A4),bNF_rel_set(C,D,A4)),aTP_Lamp_uf(fun(C,fun(D,$o)),fun(set(C),set(C)),A4)),uminus_uminus(set(D))) ) ) ).

% right_total_Compl_transfer
tff(fact_6102_rel__option__inf,axiom,
    ! [D: $tType,C: $tType,A4: fun(C,fun(D,$o)),B3: fun(C,fun(D,$o))] : aa(fun(option(C),fun(option(D),$o)),fun(option(C),fun(option(D),$o)),aa(fun(option(C),fun(option(D),$o)),fun(fun(option(C),fun(option(D),$o)),fun(option(C),fun(option(D),$o))),inf_inf(fun(option(C),fun(option(D),$o))),rel_option(C,D,A4)),rel_option(C,D,B3)) = rel_option(C,D,aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),inf_inf(fun(C,fun(D,$o))),A4),B3)) ).

% rel_option_inf
tff(fact_6103_wfP__SUP,axiom,
    ! [D: $tType,C: $tType,R3: fun(C,fun(D,fun(D,$o)))] :
      ( ! [I3: C] : wfP(D,aa(C,fun(D,fun(D,$o)),R3,I3))
     => ( ! [I3: C,J3: C] :
            ( ( aa(C,fun(D,fun(D,$o)),R3,I3) != aa(C,fun(D,fun(D,$o)),R3,J3) )
           => ( aa(fun(D,$o),fun(D,$o),aa(fun(D,$o),fun(fun(D,$o),fun(D,$o)),inf_inf(fun(D,$o)),domainp(D,D,aa(C,fun(D,fun(D,$o)),R3,I3))),rangep(D,D,aa(C,fun(D,fun(D,$o)),R3,J3))) = bot_bot(fun(D,$o)) ) )
       => wfP(D,aa(set(fun(D,fun(D,$o))),fun(D,fun(D,$o)),complete_Sup_Sup(fun(D,fun(D,$o))),aa(set(C),set(fun(D,fun(D,$o))),image2(C,fun(D,fun(D,$o)),R3),top_top(set(C))))) ) ) ).

% wfP_SUP
tff(fact_6104_option_Osimps_I15_J,axiom,
    ! [C: $tType,X24: C] : set_option(C,aa(C,option(C),some(C),X24)) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X24),bot_bot(set(C))) ).

% option.simps(15)
tff(fact_6105_these__not__empty__eq,axiom,
    ! [C: $tType,B3: set(option(C))] :
      ( ( these(C,B3) != bot_bot(set(C)) )
    <=> ( ( B3 != bot_bot(set(option(C))) )
        & ( B3 != aa(set(option(C)),set(option(C)),aa(option(C),fun(set(option(C)),set(option(C))),insert2(option(C)),none(C)),bot_bot(set(option(C)))) ) ) ) ).

% these_not_empty_eq
tff(fact_6106_set__empty__eq,axiom,
    ! [C: $tType,Xo2: option(C)] :
      ( ( set_option(C,Xo2) = bot_bot(set(C)) )
    <=> ( Xo2 = none(C) ) ) ).

% set_empty_eq
tff(fact_6107_these__empty,axiom,
    ! [C: $tType] : these(C,bot_bot(set(option(C)))) = bot_bot(set(C)) ).

% these_empty
tff(fact_6108_option_Osimps_I14_J,axiom,
    ! [C: $tType] : set_option(C,none(C)) = bot_bot(set(C)) ).

% option.simps(14)
tff(fact_6109_these__empty__eq,axiom,
    ! [C: $tType,B3: set(option(C))] :
      ( ( these(C,B3) = bot_bot(set(C)) )
    <=> ( ( B3 = bot_bot(set(option(C))) )
        | ( B3 = aa(set(option(C)),set(option(C)),aa(option(C),fun(set(option(C)),set(option(C))),insert2(option(C)),none(C)),bot_bot(set(option(C)))) ) ) ) ).

% these_empty_eq
tff(fact_6110_partial__function__definitions_Ofixp__induct__uc,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Leq: fun(C,fun(C,$o)),Lub: fun(set(C),C),U2: fun(E2,fun(D,C)),F2: fun(E2,E2),C4: fun(fun(D,C),E2),F: E2,Pa: fun(fun(D,C),$o)] :
      ( partia7178651479351089652itions(C,Leq,Lub)
     => ( ! [X2: D] : aa(fun(fun(D,C),C),$o,aa(fun(C,fun(C,$o)),fun(fun(fun(D,C),C),$o),aa(fun(fun(D,C),fun(fun(D,C),$o)),fun(fun(C,fun(C,$o)),fun(fun(fun(D,C),C),$o)),comple7038119648293358887notone(fun(D,C),C),aa(fun(C,fun(C,$o)),fun(fun(D,C),fun(fun(D,C),$o)),partial_fun_ord(C,C,D),Leq)),Leq),aa(D,fun(fun(D,C),C),aa(fun(fun(D,C),E2),fun(D,fun(fun(D,C),C)),aa(fun(E2,E2),fun(fun(fun(D,C),E2),fun(D,fun(fun(D,C),C))),aTP_Lamp_ug(fun(E2,fun(D,C)),fun(fun(E2,E2),fun(fun(fun(D,C),E2),fun(D,fun(fun(D,C),C)))),U2),F2),C4),X2))
       => ( ( F = aa(fun(D,C),E2,C4,comple187402453842119260l_fixp(fun(D,C),aa(fun(set(C),C),fun(set(fun(D,C)),fun(D,C)),partial_fun_lub(C,C,D),Lub),aa(fun(C,fun(C,$o)),fun(fun(D,C),fun(fun(D,C),$o)),partial_fun_ord(C,C,D),Leq),aa(fun(fun(D,C),E2),fun(fun(D,C),fun(D,C)),aa(fun(E2,E2),fun(fun(fun(D,C),E2),fun(fun(D,C),fun(D,C))),aTP_Lamp_uh(fun(E2,fun(D,C)),fun(fun(E2,E2),fun(fun(fun(D,C),E2),fun(fun(D,C),fun(D,C)))),U2),F2),C4))) )
         => ( ! [F5: fun(D,C)] : aa(E2,fun(D,C),U2,aa(fun(D,C),E2,C4,F5)) = F5
           => ( comple1908693960933563346ssible(fun(D,C),aa(fun(set(C),C),fun(set(fun(D,C)),fun(D,C)),partial_fun_lub(C,C,D),Lub),aa(fun(C,fun(C,$o)),fun(fun(D,C),fun(fun(D,C),$o)),partial_fun_ord(C,C,D),Leq),Pa)
             => ( aa(fun(D,C),$o,Pa,aTP_Lamp_ui(fun(set(C),C),fun(D,C),Lub))
               => ( ! [F5: E2] :
                      ( aa(fun(D,C),$o,Pa,aa(E2,fun(D,C),U2,F5))
                     => aa(fun(D,C),$o,Pa,aa(E2,fun(D,C),U2,aa(E2,E2,F2,F5))) )
                 => aa(fun(D,C),$o,Pa,aa(E2,fun(D,C),U2,F)) ) ) ) ) ) ) ) ).

% partial_function_definitions.fixp_induct_uc
tff(fact_6111_inf__filter__parametric,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o))] :
      ( bi_unique(C,D,A4)
     => ( bi_total(C,D,A4)
       => aa(fun(filter(D),fun(filter(D),filter(D))),$o,aa(fun(filter(C),fun(filter(C),filter(C))),fun(fun(filter(D),fun(filter(D),filter(D))),$o),bNF_rel_fun(filter(C),filter(D),fun(filter(C),filter(C)),fun(filter(D),filter(D)),rel_filter(C,D,A4),bNF_rel_fun(filter(C),filter(D),filter(C),filter(D),rel_filter(C,D,A4),rel_filter(C,D,A4))),inf_inf(filter(C))),inf_inf(filter(D))) ) ) ).

% inf_filter_parametric
tff(fact_6112_INF__filter__bot__base,axiom,
    ! [C: $tType,D: $tType,I5: set(C),F2: fun(C,filter(D))] :
      ( ! [I3: C] :
          ( member2(C,I3,I5)
         => ! [J3: C] :
              ( member2(C,J3,I5)
             => ? [X3: C] :
                  ( member2(C,X3,I5)
                  & aa(filter(D),$o,aa(filter(D),fun(filter(D),$o),ord_less_eq(filter(D)),aa(C,filter(D),F2,X3)),aa(filter(D),filter(D),aa(filter(D),fun(filter(D),filter(D)),inf_inf(filter(D)),aa(C,filter(D),F2,I3)),aa(C,filter(D),F2,J3))) ) ) )
     => ( ( aa(set(filter(D)),filter(D),complete_Inf_Inf(filter(D)),aa(set(C),set(filter(D)),image2(C,filter(D),F2),I5)) = bot_bot(filter(D)) )
      <=> ? [X4: C] :
            ( member2(C,X4,I5)
            & ( aa(C,filter(D),F2,X4) = bot_bot(filter(D)) ) ) ) ) ).

% INF_filter_bot_base
tff(fact_6113_inf__principal,axiom,
    ! [C: $tType,A4: set(C),B3: set(C)] : aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),principal(C,A4)),principal(C,B3)) = principal(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),A4),B3)) ).

% inf_principal
tff(fact_6114_eventually__INF__base,axiom,
    ! [D: $tType,C: $tType,B3: set(C),F2: fun(C,filter(D)),Pa: fun(D,$o)] :
      ( ( B3 != bot_bot(set(C)) )
     => ( ! [A5: C] :
            ( member2(C,A5,B3)
           => ! [B4: C] :
                ( member2(C,B4,B3)
               => ? [X3: C] :
                    ( member2(C,X3,B3)
                    & aa(filter(D),$o,aa(filter(D),fun(filter(D),$o),ord_less_eq(filter(D)),aa(C,filter(D),F2,X3)),aa(filter(D),filter(D),aa(filter(D),fun(filter(D),filter(D)),inf_inf(filter(D)),aa(C,filter(D),F2,A5)),aa(C,filter(D),F2,B4))) ) ) )
       => ( eventually(D,Pa,aa(set(filter(D)),filter(D),complete_Inf_Inf(filter(D)),aa(set(C),set(filter(D)),image2(C,filter(D),F2),B3)))
        <=> ? [X4: C] :
              ( member2(C,X4,B3)
              & eventually(D,Pa,aa(C,filter(D),F2,X4)) ) ) ) ) ).

% eventually_INF_base
tff(fact_6115_eventually__Inf__base,axiom,
    ! [C: $tType,B3: set(filter(C)),Pa: fun(C,$o)] :
      ( ( B3 != bot_bot(set(filter(C))) )
     => ( ! [F3: filter(C)] :
            ( member2(filter(C),F3,B3)
           => ! [G5: filter(C)] :
                ( member2(filter(C),G5,B3)
               => ? [X3: filter(C)] :
                    ( member2(filter(C),X3,B3)
                    & aa(filter(C),$o,aa(filter(C),fun(filter(C),$o),ord_less_eq(filter(C)),X3),aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),F3),G5)) ) ) )
       => ( eventually(C,Pa,aa(set(filter(C)),filter(C),complete_Inf_Inf(filter(C)),B3))
        <=> ? [X4: filter(C)] :
              ( member2(filter(C),X4,B3)
              & eventually(C,Pa,X4) ) ) ) ) ).

% eventually_Inf_base
tff(fact_6116_eventually__inf,axiom,
    ! [C: $tType,Pa: fun(C,$o),F2: filter(C),F7: filter(C)] :
      ( eventually(C,Pa,aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),F2),F7))
    <=> ? [Q7: fun(C,$o),R8: fun(C,$o)] :
          ( eventually(C,Q7,F2)
          & eventually(C,R8,F7)
          & ! [X4: C] :
              ( ( aa(C,$o,Q7,X4)
                & aa(C,$o,R8,X4) )
             => aa(C,$o,Pa,X4) ) ) ) ).

% eventually_inf
tff(fact_6117_eventually__inf__principal,axiom,
    ! [C: $tType,Pa: fun(C,$o),F2: filter(C),S4: set(C)] :
      ( eventually(C,Pa,aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),F2),principal(C,S4)))
    <=> eventually(C,aa(set(C),fun(C,$o),aTP_Lamp_uj(fun(C,$o),fun(set(C),fun(C,$o)),Pa),S4),F2) ) ).

% eventually_inf_principal
tff(fact_6118_principal__eq__bot__iff,axiom,
    ! [C: $tType,X5: set(C)] :
      ( ( principal(C,X5) = bot_bot(filter(C)) )
    <=> ( X5 = bot_bot(set(C)) ) ) ).

% principal_eq_bot_iff
tff(fact_6119_bot__eq__principal__empty,axiom,
    ! [C: $tType] : bot_bot(filter(C)) = principal(C,bot_bot(set(C))) ).

% bot_eq_principal_empty
tff(fact_6120_filterlim__base__iff,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F4: $tType,I5: set(C),F2: fun(C,set(D)),F: fun(D,E2),G2: fun(F4,set(E2)),J4: set(F4)] :
      ( ( I5 != bot_bot(set(C)) )
     => ( ! [I3: C] :
            ( member2(C,I3,I5)
           => ! [J3: C] :
                ( member2(C,J3,I5)
               => ( aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(C,set(D),F2,I3)),aa(C,set(D),F2,J3))
                  | aa(set(D),$o,aa(set(D),fun(set(D),$o),ord_less_eq(set(D)),aa(C,set(D),F2,J3)),aa(C,set(D),F2,I3)) ) ) )
       => ( filterlim(D,E2,F,aa(set(filter(E2)),filter(E2),complete_Inf_Inf(filter(E2)),aa(set(F4),set(filter(E2)),image2(F4,filter(E2),aTP_Lamp_uk(fun(F4,set(E2)),fun(F4,filter(E2)),G2)),J4)),aa(set(filter(D)),filter(D),complete_Inf_Inf(filter(D)),aa(set(C),set(filter(D)),image2(C,filter(D),aTP_Lamp_ul(fun(C,set(D)),fun(C,filter(D)),F2)),I5)))
        <=> ! [X4: F4] :
              ( member2(F4,X4,J4)
             => ? [Xa2: C] :
                  ( member2(C,Xa2,I5)
                  & ! [Xb4: D] :
                      ( member2(D,Xb4,aa(C,set(D),F2,Xa2))
                     => member2(E2,aa(D,E2,F,Xb4),aa(F4,set(E2),G2,X4)) ) ) ) ) ) ) ).

% filterlim_base_iff
tff(fact_6121_inf__filter__def,axiom,
    ! [C: $tType,F2: filter(C),F7: filter(C)] : aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),F2),F7) = abs_filter(C,aa(filter(C),fun(fun(C,$o),$o),aTP_Lamp_um(filter(C),fun(filter(C),fun(fun(C,$o),$o)),F2),F7)) ).

% inf_filter_def
tff(fact_6122_filterlim__inf,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),F23: filter(D),F32: filter(D),F12: filter(C)] :
      ( filterlim(C,D,F,aa(filter(D),filter(D),aa(filter(D),fun(filter(D),filter(D)),inf_inf(filter(D)),F23),F32),F12)
    <=> ( filterlim(C,D,F,F23,F12)
        & filterlim(C,D,F,F32,F12) ) ) ).

% filterlim_inf
tff(fact_6123_filterlim__If,axiom,
    ! [D: $tType,C: $tType,F: fun(C,D),G2: filter(D),F2: filter(C),Pa: fun(C,$o),G: fun(C,D)] :
      ( filterlim(C,D,F,G2,aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),F2),principal(C,collect(C,Pa))))
     => ( filterlim(C,D,G,G2,aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),F2),principal(C,collect(C,aTP_Lamp_bi(fun(C,$o),fun(C,$o),Pa)))))
       => filterlim(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,$o),fun(fun(C,D),fun(C,D)),aTP_Lamp_un(fun(C,D),fun(fun(C,$o),fun(fun(C,D),fun(C,D))),F),Pa),G),G2,F2) ) ) ).

% filterlim_If
tff(fact_6124_prod__filter__INF,axiom,
    ! [D: $tType,F4: $tType,E2: $tType,C: $tType,I5: set(C),J4: set(D),A4: fun(C,filter(E2)),B3: fun(D,filter(F4))] :
      ( ( I5 != bot_bot(set(C)) )
     => ( ( J4 != bot_bot(set(D)) )
       => ( prod_filter(E2,F4,aa(set(filter(E2)),filter(E2),complete_Inf_Inf(filter(E2)),aa(set(C),set(filter(E2)),image2(C,filter(E2),A4),I5)),aa(set(filter(F4)),filter(F4),complete_Inf_Inf(filter(F4)),aa(set(D),set(filter(F4)),image2(D,filter(F4),B3),J4))) = aa(set(filter(product_prod(E2,F4))),filter(product_prod(E2,F4)),complete_Inf_Inf(filter(product_prod(E2,F4))),aa(set(C),set(filter(product_prod(E2,F4))),image2(C,filter(product_prod(E2,F4)),aa(fun(D,filter(F4)),fun(C,filter(product_prod(E2,F4))),aa(fun(C,filter(E2)),fun(fun(D,filter(F4)),fun(C,filter(product_prod(E2,F4)))),aTP_Lamp_up(set(D),fun(fun(C,filter(E2)),fun(fun(D,filter(F4)),fun(C,filter(product_prod(E2,F4))))),J4),A4),B3)),I5)) ) ) ) ).

% prod_filter_INF
tff(fact_6125_prod__filter__INF1,axiom,
    ! [E2: $tType,D: $tType,C: $tType,I5: set(C),A4: fun(C,filter(D)),B3: filter(E2)] :
      ( ( I5 != bot_bot(set(C)) )
     => ( prod_filter(D,E2,aa(set(filter(D)),filter(D),complete_Inf_Inf(filter(D)),aa(set(C),set(filter(D)),image2(C,filter(D),A4),I5)),B3) = aa(set(filter(product_prod(D,E2))),filter(product_prod(D,E2)),complete_Inf_Inf(filter(product_prod(D,E2))),aa(set(C),set(filter(product_prod(D,E2))),image2(C,filter(product_prod(D,E2)),aa(filter(E2),fun(C,filter(product_prod(D,E2))),aTP_Lamp_uq(fun(C,filter(D)),fun(filter(E2),fun(C,filter(product_prod(D,E2)))),A4),B3)),I5)) ) ) ).

% prod_filter_INF1
tff(fact_6126_prod__filter__INF2,axiom,
    ! [E2: $tType,D: $tType,C: $tType,J4: set(C),A4: filter(D),B3: fun(C,filter(E2))] :
      ( ( J4 != bot_bot(set(C)) )
     => ( prod_filter(D,E2,A4,aa(set(filter(E2)),filter(E2),complete_Inf_Inf(filter(E2)),aa(set(C),set(filter(E2)),image2(C,filter(E2),B3),J4))) = aa(set(filter(product_prod(D,E2))),filter(product_prod(D,E2)),complete_Inf_Inf(filter(product_prod(D,E2))),aa(set(C),set(filter(product_prod(D,E2))),image2(C,filter(product_prod(D,E2)),aa(fun(C,filter(E2)),fun(C,filter(product_prod(D,E2))),aTP_Lamp_ur(filter(D),fun(fun(C,filter(E2)),fun(C,filter(product_prod(D,E2)))),A4),B3)),J4)) ) ) ).

% prod_filter_INF2
tff(fact_6127_prod__filter__principal__singleton2,axiom,
    ! [D: $tType,C: $tType,F2: filter(C),X: D] : prod_filter(C,D,F2,principal(D,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),X),bot_bot(set(D))))) = filtermap(C,product_prod(C,D),aa(D,fun(C,product_prod(C,D)),aTP_Lamp_hs(D,fun(C,product_prod(C,D))),X),F2) ).

% prod_filter_principal_singleton2
tff(fact_6128_prod__filter__principal__singleton,axiom,
    ! [C: $tType,D: $tType,X: C,F2: filter(D)] : prod_filter(C,D,principal(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C)))),F2) = filtermap(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X),F2) ).

% prod_filter_principal_singleton
tff(fact_6129_filtermap__inf,axiom,
    ! [C: $tType,D: $tType,F: fun(D,C),F12: filter(D),F23: filter(D)] : aa(filter(C),$o,aa(filter(C),fun(filter(C),$o),ord_less_eq(filter(C)),filtermap(D,C,F,aa(filter(D),filter(D),aa(filter(D),fun(filter(D),filter(D)),inf_inf(filter(D)),F12),F23))),aa(filter(C),filter(C),aa(filter(C),fun(filter(C),filter(C)),inf_inf(filter(C)),filtermap(D,C,F,F12)),filtermap(D,C,F,F23))) ).

% filtermap_inf
tff(fact_6130_ID_Orel__cong,axiom,
    ! [C: $tType,D: $tType,X: C,Ya: C,Y: D,Xa: D,R: fun(C,fun(D,$o)),Ra: fun(C,fun(D,$o))] :
      ( ( X = Ya )
     => ( ( Y = Xa )
       => ( ! [Z4: C,Yb: D] :
              ( member2(C,Z4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Ya),bot_bot(set(C))))
             => ( member2(D,Yb,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),Xa),bot_bot(set(D))))
               => ( aa(D,$o,aa(C,fun(D,$o),R,Z4),Yb)
                <=> aa(D,$o,aa(C,fun(D,$o),Ra,Z4),Yb) ) ) )
         => ( aa(D,$o,aa(C,fun(D,$o),bNF_id_bnf(fun(C,fun(D,$o)),R),X),Y)
          <=> aa(D,$o,aa(C,fun(D,$o),bNF_id_bnf(fun(C,fun(D,$o)),Ra),Ya),Xa) ) ) ) ) ).

% ID.rel_cong
tff(fact_6131_ID_Orel__mono__strong,axiom,
    ! [C: $tType,D: $tType,R: fun(C,fun(D,$o)),X: C,Y: D,Ra: fun(C,fun(D,$o))] :
      ( aa(D,$o,aa(C,fun(D,$o),bNF_id_bnf(fun(C,fun(D,$o)),R),X),Y)
     => ( ! [Z4: C,Yb: D] :
            ( member2(C,Z4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))
           => ( member2(D,Yb,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),Y),bot_bot(set(D))))
             => ( aa(D,$o,aa(C,fun(D,$o),R,Z4),Yb)
               => aa(D,$o,aa(C,fun(D,$o),Ra,Z4),Yb) ) ) )
       => aa(D,$o,aa(C,fun(D,$o),bNF_id_bnf(fun(C,fun(D,$o)),Ra),X),Y) ) ) ).

% ID.rel_mono_strong
tff(fact_6132_ID_Orel__refl__strong,axiom,
    ! [C: $tType,X: C,Ra: fun(C,fun(C,$o))] :
      ( ! [Z4: C] :
          ( member2(C,Z4,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),X),bot_bot(set(C))))
         => aa(C,$o,aa(C,fun(C,$o),Ra,Z4),Z4) )
     => aa(C,$o,aa(C,fun(C,$o),bNF_id_bnf(fun(C,fun(C,$o)),Ra),X),X) ) ).

% ID.rel_refl_strong
tff(fact_6133_pred__on_Ochain__extend,axiom,
    ! [C: $tType,A4: set(C),Pa: fun(C,fun(C,$o)),C4: set(C),Z2: C] :
      ( pred_chain(C,A4,Pa,C4)
     => ( member2(C,Z2,A4)
       => ( ! [X2: C] :
              ( member2(C,X2,C4)
             => aa(C,$o,aa(C,fun(C,$o),aa(fun(C,fun(C,$o)),fun(C,fun(C,$o)),aa(fun(C,fun(C,$o)),fun(fun(C,fun(C,$o)),fun(C,fun(C,$o))),sup_sup(fun(C,fun(C,$o))),Pa),fequal(C)),X2),Z2) )
         => pred_chain(C,A4,Pa,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Z2),bot_bot(set(C)))),C4)) ) ) ) ).

% pred_on.chain_extend
tff(fact_6134_sup2CI,axiom,
    ! [C: $tType,D: $tType,B3: fun(C,fun(D,$o)),X: C,Y: D,A4: fun(C,fun(D,$o))] :
      ( ( ~ aa(D,$o,aa(C,fun(D,$o),B3,X),Y)
       => aa(D,$o,aa(C,fun(D,$o),A4,X),Y) )
     => aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),sup_sup(fun(C,fun(D,$o))),A4),B3),X),Y) ) ).

% sup2CI
tff(fact_6135_sup2I2,axiom,
    ! [C: $tType,D: $tType,B3: fun(C,fun(D,$o)),X: C,Y: D,A4: fun(C,fun(D,$o))] :
      ( aa(D,$o,aa(C,fun(D,$o),B3,X),Y)
     => aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),sup_sup(fun(C,fun(D,$o))),A4),B3),X),Y) ) ).

% sup2I2
tff(fact_6136_sup2I1,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o)),X: C,Y: D,B3: fun(C,fun(D,$o))] :
      ( aa(D,$o,aa(C,fun(D,$o),A4,X),Y)
     => aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),sup_sup(fun(C,fun(D,$o))),A4),B3),X),Y) ) ).

% sup2I1
tff(fact_6137_sup2E,axiom,
    ! [C: $tType,D: $tType,A4: fun(C,fun(D,$o)),B3: fun(C,fun(D,$o)),X: C,Y: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aa(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),sup_sup(fun(C,fun(D,$o))),A4),B3),X),Y)
     => ( ~ aa(D,$o,aa(C,fun(D,$o),A4,X),Y)
       => aa(D,$o,aa(C,fun(D,$o),B3,X),Y) ) ) ).

% sup2E
tff(fact_6138_pred__on_Ochain__empty,axiom,
    ! [C: $tType,A4: set(C),Pa: fun(C,fun(C,$o))] : pred_chain(C,A4,Pa,bot_bot(set(C))) ).

% pred_on.chain_empty
tff(fact_6139_ATP_Olambda__1,axiom,
    ! [C: $tType,Uu: list(C)] : aa(list(C),product_prod(nat,list(C)),aTP_Lamp_tw(list(C),product_prod(nat,list(C))),Uu) = aa(list(C),product_prod(nat,list(C)),aa(nat,fun(list(C),product_prod(nat,list(C))),product_Pair(nat,list(C)),aa(list(C),nat,size_size(list(C)),Uu)),Uu) ).

% ATP.lambda_1
tff(fact_6140_ATP_Olambda__2,axiom,
    ! [Uu: nat] : aa(nat,nat,aTP_Lamp_ed(nat,nat),Uu) = minus_minus(nat,Uu,aa(nat,nat,suc,zero_zero(nat))) ).

% ATP.lambda_2
tff(fact_6141_ATP_Olambda__3,axiom,
    ! [C: $tType,Uu: C] : aa(C,product_prod(C,C),aTP_Lamp_cz(C,product_prod(C,C)),Uu) = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uu),Uu) ).

% ATP.lambda_3
tff(fact_6142_ATP_Olambda__4,axiom,
    ! [C: $tType] :
      ( semiring_1(C)
     => ! [Uu: C] : aa(C,C,aTP_Lamp_hm(C,C),Uu) = aa(C,C,aa(C,fun(C,C),plus_plus(C),Uu),one_one(C)) ) ).

% ATP.lambda_4
tff(fact_6143_ATP_Olambda__5,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [Uu: C] :
          ( aa(C,$o,aTP_Lamp_rt(C,$o),Uu)
        <=> dvd_dvd(C,Uu,one_one(C)) ) ) ).

% ATP.lambda_5
tff(fact_6144_ATP_Olambda__6,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: C] : aa(C,list(C),aTP_Lamp_ep(C,list(C)),Uu) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),nil(C)) ) ).

% ATP.lambda_6
tff(fact_6145_ATP_Olambda__7,axiom,
    ! [C: $tType,Uu: C] : aa(C,list(C),aTP_Lamp_fa(C,list(C)),Uu) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),nil(C)) ).

% ATP.lambda_7
tff(fact_6146_ATP_Olambda__8,axiom,
    ! [C: $tType,Uu: C] : aa(C,set(C),aTP_Lamp_ap(C,set(C)),Uu) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uu),bot_bot(set(C))) ).

% ATP.lambda_8
tff(fact_6147_ATP_Olambda__9,axiom,
    ! [D: $tType,Uu: list(D)] :
      ( aa(list(D),$o,aTP_Lamp_uc(list(D),$o),Uu)
    <=> ( Uu = nil(D) ) ) ).

% ATP.lambda_9
tff(fact_6148_ATP_Olambda__10,axiom,
    ! [C: $tType,Uu: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_ub(list(C),$o),Uu)
    <=> ( Uu = nil(C) ) ) ).

% ATP.lambda_10
tff(fact_6149_ATP_Olambda__11,axiom,
    ! [D: $tType,Uu: list(D)] : aa(list(D),fun(nat,nat),aTP_Lamp_fr(list(D),fun(nat,nat)),Uu) = aa(nat,fun(nat,nat),ord_max(nat),minus_minus(nat,aa(list(D),nat,size_size(list(D)),Uu),aa(nat,nat,suc,zero_zero(nat)))) ).

% ATP.lambda_11
tff(fact_6150_ATP_Olambda__12,axiom,
    ! [D: $tType,Uu: list(D)] :
      ( aa(list(D),$o,aTP_Lamp_fs(list(D),$o),Uu)
    <=> ( Uu != nil(D) ) ) ).

% ATP.lambda_12
tff(fact_6151_ATP_Olambda__13,axiom,
    ! [C: $tType,Uu: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_fi(list(C),$o),Uu)
    <=> ( Uu != nil(C) ) ) ).

% ATP.lambda_13
tff(fact_6152_ATP_Olambda__14,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Uu: D] : aa(D,fun(product_prod(C,E2),product_prod(C,product_prod(D,E2))),aTP_Lamp_hr(D,fun(product_prod(C,E2),product_prod(C,product_prod(D,E2)))),Uu) = product_case_prod(C,E2,product_prod(C,product_prod(D,E2)),aTP_Lamp_hq(D,fun(C,fun(E2,product_prod(C,product_prod(D,E2)))),Uu)) ).

% ATP.lambda_14
tff(fact_6153_ATP_Olambda__15,axiom,
    ! [D: $tType,Uu: list(D)] : aa(list(D),fun(nat,nat),aTP_Lamp_fq(list(D),fun(nat,nat)),Uu) = aa(nat,fun(nat,nat),ord_max(nat),aa(list(D),nat,size_size(list(D)),Uu)) ).

% ATP.lambda_15
tff(fact_6154_ATP_Olambda__16,axiom,
    ! [C: $tType,Uu: list(C)] : aa(list(C),fun(nat,nat),aTP_Lamp_dj(list(C),fun(nat,nat)),Uu) = aa(nat,fun(nat,nat),ord_max(nat),aa(list(C),nat,size_size(list(C)),Uu)) ).

% ATP.lambda_16
tff(fact_6155_ATP_Olambda__17,axiom,
    ! [C: $tType,D: $tType,Uu: product_prod(product_prod($o,C),product_prod($o,D))] :
      ( aa(product_prod(product_prod($o,C),product_prod($o,D)),$o,aTP_Lamp_jw(product_prod(product_prod($o,C),product_prod($o,D)),$o),Uu)
    <=> ? [X4: C,Y3: D] : Uu = aa(product_prod($o,D),product_prod(product_prod($o,C),product_prod($o,D)),aa(product_prod($o,C),fun(product_prod($o,D),product_prod(product_prod($o,C),product_prod($o,D))),product_Pair(product_prod($o,C),product_prod($o,D)),aa(C,product_prod($o,C),aa($o,fun(C,product_prod($o,C)),product_Pair($o,C),$true),X4)),aa(D,product_prod($o,D),aa($o,fun(D,product_prod($o,D)),product_Pair($o,D),$false),Y3)) ) ).

% ATP.lambda_17
tff(fact_6156_ATP_Olambda__18,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [Uu: nat,Uua: nat] :
          aa(nat,C,aTP_Lamp_fw(nat,fun(nat,C),Uu),Uua) = $ite(dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),bit0(one2)),Uua),aa(nat,C,semiring_1_of_nat(C),binomial(Uu,Uua)),zero_zero(C)) ) ).

% ATP.lambda_18
tff(fact_6157_ATP_Olambda__19,axiom,
    ! [E2: $tType,D: $tType,C: $tType,Uu: product_prod(C,E2),Uua: product_prod(E2,D)] :
      aa(product_prod(E2,D),list(product_prod(C,D)),aTP_Lamp_lo(product_prod(C,E2),fun(product_prod(E2,D),list(product_prod(C,D))),Uu),Uua) = $ite(aa(product_prod(C,E2),E2,product_snd(C,E2),Uu) = aa(product_prod(E2,D),E2,product_fst(E2,D),Uua),aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(product_prod(C,E2),C,product_fst(C,E2),Uu)),aa(product_prod(E2,D),D,product_snd(E2,D),Uua))),nil(product_prod(C,D))),nil(product_prod(C,D))) ).

% ATP.lambda_19
tff(fact_6158_ATP_Olambda__20,axiom,
    ! [C: $tType,Uu: list(C),Uua: nat] :
      aa(nat,option(C),aTP_Lamp_oh(list(C),fun(nat,option(C)),Uu),Uua) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uua),aa(list(C),nat,size_size(list(C)),Uu)),aa(C,option(C),some(C),aa(nat,C,nth(C,Uu),Uua)),none(C)) ).

% ATP.lambda_20
tff(fact_6159_ATP_Olambda__21,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [Uu: nat,Uua: nat] :
          aa(nat,C,aTP_Lamp_fv(nat,fun(nat,C),Uu),Uua) = $ite(~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),bit0(one2)),Uua),aa(nat,C,semiring_1_of_nat(C),binomial(Uu,Uua)),zero_zero(C)) ) ).

% ATP.lambda_21
tff(fact_6160_ATP_Olambda__22,axiom,
    ! [C: $tType] :
      ( ( lattice(C)
        & order_bot(C) )
     => ! [Uu: fun(C,C),Uua: nat] : aa(nat,C,aTP_Lamp_mi(fun(C,C),fun(nat,C),Uu),Uua) = aa(C,C,compow(fun(C,C),Uua,Uu),bot_bot(C)) ) ).

% ATP.lambda_22
tff(fact_6161_ATP_Olambda__23,axiom,
    ! [C: $tType,Uu: list(list(C)),Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_nw(list(list(C)),fun(list(C),$o),Uu),Uua)
    <=> aa(list(list(C)),$o,aa(list(C),fun(list(list(C)),$o),aa(fun(C,fun(list(C),$o)),fun(list(C),fun(list(list(C)),$o)),list_all2(C,list(C)),aTP_Lamp_nv(C,fun(list(C),$o))),Uua),Uu) ) ).

% ATP.lambda_23
tff(fact_6162_ATP_Olambda__24,axiom,
    ! [C: $tType] :
      ( inf(C)
     => ! [Uu: option(C),Uua: C] : aa(C,option(C),aTP_Lamp_ot(option(C),fun(C,option(C)),Uu),Uua) = case_option(option(C),C,none(C),aTP_Lamp_os(C,fun(C,option(C)),Uua),Uu) ) ).

% ATP.lambda_24
tff(fact_6163_ATP_Olambda__25,axiom,
    ! [C: $tType,Uu: list(list(C)),Uua: nat] : aa(nat,list(C),aTP_Lamp_ex(list(list(C)),fun(nat,list(C)),Uu),Uua) = aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),aa(nat,fun(nat,C),aTP_Lamp_ew(list(list(C)),fun(nat,fun(nat,C)),Uu),Uua)),upt(zero_zero(nat),aa(list(list(C)),nat,size_size(list(list(C))),Uu))) ).

% ATP.lambda_25
tff(fact_6164_ATP_Olambda__26,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [Uu: nat,Uua: nat] : aa(nat,C,aTP_Lamp_hj(nat,fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),Uua)),aa(nat,C,semiring_1_of_nat(C),Uua))),aa(nat,C,semiring_1_of_nat(C),binomial(Uu,Uua))) ) ).

% ATP.lambda_26
tff(fact_6165_ATP_Olambda__27,axiom,
    ! [C: $tType,Uu: set(C),Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_dz(set(C),fun(list(C),$o),Uu),Uua)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uua)),Uu)
        & aa(list(C),$o,distinct(C),Uua) ) ) ).

% ATP.lambda_27
tff(fact_6166_ATP_Olambda__28,axiom,
    ! [C: $tType,Uu: set(C),Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_dd(set(C),fun(list(C),$o),Uu),Uua)
    <=> ( ( aa(list(C),set(C),set2(C),Uua) = Uu )
        & aa(list(C),$o,distinct(C),Uua) ) ) ).

% ATP.lambda_28
tff(fact_6167_ATP_Olambda__29,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [Uu: nat,Uua: nat] : aa(nat,C,aTP_Lamp_hl(nat,fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),Uua)),aa(nat,C,semiring_1_of_nat(C),binomial(Uu,Uua))) ) ).

% ATP.lambda_29
tff(fact_6168_ATP_Olambda__30,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C] : aa(C,set(set(C)),aTP_Lamp_pi(set(product_prod(C,C)),fun(C,set(set(C))),Uu),Uua) = aa(set(set(C)),set(set(C)),aa(set(C),fun(set(set(C)),set(set(C))),insert2(set(C)),image(C,C,Uu,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uua),bot_bot(set(C))))),bot_bot(set(set(C)))) ).

% ATP.lambda_30
tff(fact_6169_ATP_Olambda__31,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: C,Uua: nat] : aa(nat,C,aTP_Lamp_gs(C,fun(nat,C),Uu),Uua) = aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),Uu),aa(nat,C,semiring_1_of_nat(C),Uua))),Uua) ) ).

% ATP.lambda_31
tff(fact_6170_ATP_Olambda__32,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: C,Uua: nat] : aa(nat,C,aTP_Lamp_fx(C,fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,Uu),Uua)),minus_minus(C,divide_divide(C,Uu,aa(num,C,numeral_numeral(C),bit0(one2))),aa(nat,C,semiring_1_of_nat(C),Uua))) ) ).

% ATP.lambda_32
tff(fact_6171_ATP_Olambda__33,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: C,Uua: nat] : aa(nat,C,aTP_Lamp_ha(C,fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,Uu),Uua)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),one_one(C))),Uua)) ) ).

% ATP.lambda_33
tff(fact_6172_ATP_Olambda__34,axiom,
    ! [C: $tType,Uu: fun(set(C),$o),Uua: set(C)] :
      ( aa(set(C),$o,aa(fun(set(C),$o),fun(set(C),$o),aTP_Lamp_ks(fun(set(C),$o),fun(set(C),$o)),Uu),Uua)
    <=> ( ( Uua = bot_bot(set(C)) )
        | ? [A9: set(C),A6: C] :
            ( ( Uua = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),A6),A9) )
            & aa(set(C),$o,Uu,A9) ) ) ) ).

% ATP.lambda_34
tff(fact_6173_ATP_Olambda__35,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C] : aa(C,set(set(C)),aTP_Lamp_lr(set(product_prod(C,C)),fun(C,set(set(C))),Uu),Uua) = equiv_quotient(C,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uua),bot_bot(set(C))),Uu) ).

% ATP.lambda_35
tff(fact_6174_ATP_Olambda__36,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: set(C),Uua: list(C)] :
          ( aa(list(C),$o,aTP_Lamp_pw(set(C),fun(list(C),$o),Uu),Uua)
        <=> ( sorted_wrt(C,ord_less(C),Uua)
            & ( aa(list(C),set(C),set2(C),Uua) = Uu ) ) ) ) ).

% ATP.lambda_36
tff(fact_6175_ATP_Olambda__37,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(E2,product_prod(C,D)),Uua: C] : aa(C,set(D),aTP_Lamp_ma(fun(E2,product_prod(C,D)),fun(C,set(D)),Uu),Uua) = aa(set(E2),set(D),image2(E2,D,comp(product_prod(C,D),D,E2,product_snd(C,D),Uu)),top_top(set(E2))) ).

% ATP.lambda_37
tff(fact_6176_ATP_Olambda__38,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(nat,C),Uua: nat] : aa(nat,C,aTP_Lamp_es(fun(nat,C),fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,Uu,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),Uua))),aa(nat,C,Uu,aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),bit0(one2))),Uua)))) ) ).

% ATP.lambda_38
tff(fact_6177_ATP_Olambda__39,axiom,
    ! [C: $tType] :
      ( division_ring(C)
     => ! [Uu: fun(nat,C),Uua: nat] : aa(nat,C,aTP_Lamp_fz(fun(nat,C),fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,Uu,Uua)),aa(nat,C,aa(C,fun(nat,C),power_power(C),zero_zero(C)),Uua)) ) ).

% ATP.lambda_39
tff(fact_6178_ATP_Olambda__40,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Uu: fun(C,$o),Uua: C] :
          ( aa(C,$o,aTP_Lamp_qx(fun(C,$o),fun(C,$o),Uu),Uua)
        <=> ( aa(C,$o,Uu,Uua)
            & ! [Y3: C] :
                ( aa(C,$o,Uu,Y3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Y3) ) ) ) ) ).

% ATP.lambda_40
tff(fact_6179_ATP_Olambda__41,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Uu: fun(C,$o),Uua: C] :
          ( aa(C,$o,aTP_Lamp_qy(fun(C,$o),fun(C,$o),Uu),Uua)
        <=> ( aa(C,$o,Uu,Uua)
            & ! [Y3: C] :
                ( aa(C,$o,Uu,Y3)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Y3),Uua) ) ) ) ) ).

% ATP.lambda_41
tff(fact_6180_ATP_Olambda__42,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: C] : aa(C,product_prod(D,C),aTP_Lamp_bx(fun(C,D),fun(C,product_prod(D,C)),Uu),Uua) = aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),aa(C,D,Uu,Uua)),Uua) ).

% ATP.lambda_42
tff(fact_6181_ATP_Olambda__43,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: C] : aa(C,assn,aTP_Lamp_tg(fun(C,assn),fun(C,assn),Uu),Uua) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Uu,Uua)),top_top(assn)) ).

% ATP.lambda_43
tff(fact_6182_ATP_Olambda__44,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,C),Uua: D] : aa(D,list(C),aTP_Lamp_av(fun(D,C),fun(D,list(C)),Uu),Uua) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,Uu,Uua)),nil(C)) ).

% ATP.lambda_44
tff(fact_6183_ATP_Olambda__45,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,C),Uua: D] : aa(D,set(C),aTP_Lamp_dr(fun(D,C),fun(D,set(C)),Uu),Uua) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),aa(D,C,Uu,Uua)),bot_bot(set(C))) ).

% ATP.lambda_45
tff(fact_6184_ATP_Olambda__46,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: fun(C,D),Uua: C] :
          ( aa(C,$o,aTP_Lamp_di(fun(C,D),fun(C,$o),Uu),Uua)
        <=> ( aa(C,D,Uu,Uua) = one_one(D) ) ) ) ).

% ATP.lambda_46
tff(fact_6185_ATP_Olambda__47,axiom,
    ! [C: $tType,Uu: list(fun(C,nat)),Uua: C] : aa(C,list(nat),aTP_Lamp_tz(list(fun(C,nat)),fun(C,list(nat)),Uu),Uua) = aa(list(fun(C,nat)),list(nat),aa(fun(fun(C,nat),nat),fun(list(fun(C,nat)),list(nat)),map(fun(C,nat),nat),aTP_Lamp_ty(C,fun(fun(C,nat),nat),Uua)),Uu) ).

% ATP.lambda_47
tff(fact_6186_ATP_Olambda__48,axiom,
    ! [C: $tType,Uu: list(C),Uua: list(C)] : aa(list(C),list(list(C)),aTP_Lamp_dn(list(C),fun(list(C),list(list(C))),Uu),Uua) = aa(list(C),list(list(C)),aa(fun(C,list(C)),fun(list(C),list(list(C))),map(C,list(C)),aa(list(C),fun(C,list(C)),aTP_Lamp_dm(list(C),fun(C,list(C))),Uua)),Uu) ).

% ATP.lambda_48
tff(fact_6187_ATP_Olambda__49,axiom,
    ! [Uu: assn,Uua: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aTP_Lamp_rv(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uu),Uua)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,Uua)
        & ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Uu),Uua) ) ) ).

% ATP.lambda_49
tff(fact_6188_ATP_Olambda__50,axiom,
    ! [Uu: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uua: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aTP_Lamp_sp(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uu),Uua)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,in_range,Uua)
        & ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,Uu,Uua) ) ) ).

% ATP.lambda_50
tff(fact_6189_ATP_Olambda__51,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,fun(D,$o)),Uua: list(product_prod(C,D))] :
      ( aa(list(product_prod(C,D)),$o,aTP_Lamp_nr(fun(C,fun(D,$o)),fun(list(product_prod(C,D)),$o),Uu),Uua)
    <=> aa(set(product_prod(C,D)),$o,aa(set(product_prod(C,D)),fun(set(product_prod(C,D)),$o),ord_less_eq(set(product_prod(C,D))),aa(list(product_prod(C,D)),set(product_prod(C,D)),set2(product_prod(C,D)),Uua)),collect(product_prod(C,D),product_case_prod(C,D,$o,Uu))) ) ).

% ATP.lambda_51
tff(fact_6190_ATP_Olambda__52,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,fun(D,$o)),Uua: set(set(C))] : aa(set(set(C)),set(C),aTP_Lamp_ue(fun(C,fun(D,$o)),fun(set(set(C)),set(C)),Uu),Uua) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(set(C)),set(C),complete_Inf_Inf(set(C)),Uua)),collect(C,domainp(C,D,Uu))) ).

% ATP.lambda_52
tff(fact_6191_ATP_Olambda__53,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,fun(D,$o)),Uua: set(C)] : aa(set(C),set(C),aTP_Lamp_uf(fun(C,fun(D,$o)),fun(set(C),set(C)),Uu),Uua) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(set(C),set(C),uminus_uminus(set(C)),Uua)),collect(C,domainp(C,D,Uu))) ).

% ATP.lambda_53
tff(fact_6192_ATP_Olambda__54,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(C)
     => ! [Uu: product_prod(C,D),Uua: product_prod(C,D)] :
          ( aa(product_prod(C,D),$o,aa(product_prod(C,D),fun(product_prod(C,D),$o),aTP_Lamp_la(product_prod(C,D),fun(product_prod(C,D),$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(product_prod(C,D),C,product_fst(C,D),Uu)),aa(product_prod(C,D),C,product_fst(C,D),Uua)) ) ) ).

% ATP.lambda_54
tff(fact_6193_ATP_Olambda__55,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(C)
     => ! [Uu: product_prod(C,D),Uua: product_prod(C,D)] :
          ( aa(product_prod(C,D),$o,aa(product_prod(C,D),fun(product_prod(C,D),$o),aTP_Lamp_lb(product_prod(C,D),fun(product_prod(C,D),$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(product_prod(C,D),C,product_fst(C,D),Uua)),aa(product_prod(C,D),C,product_fst(C,D),Uu)) ) ) ).

% ATP.lambda_55
tff(fact_6194_ATP_Olambda__56,axiom,
    ! [C: $tType,Uu: list(option(C)),Uua: C] : aa(C,option(list(C)),aTP_Lamp_ua(list(option(C)),fun(C,option(list(C))),Uu),Uua) = map_option(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),aa(list(option(C)),option(list(C)),those(C),Uu)) ).

% ATP.lambda_56
tff(fact_6195_ATP_Olambda__57,axiom,
    ! [C: $tType,Uu: list(list(C)),Uua: C] : aa(C,list(list(C)),aTP_Lamp_dq(list(list(C)),fun(C,list(list(C))),Uu),Uua) = aa(list(list(C)),list(list(C)),aa(fun(list(C),list(C)),fun(list(list(C)),list(list(C))),map(list(C),list(C)),aa(C,fun(list(C),list(C)),cons(C),Uua)),aa(list(list(C)),list(list(C)),product_lists(C),Uu)) ).

% ATP.lambda_57
tff(fact_6196_ATP_Olambda__58,axiom,
    ! [C: $tType,Uu: list(C),Uua: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_jp(list(C),fun(list(C),$o)),Uu),Uua)
    <=> ( aa(list(C),nat,size_size(list(C)),Uu) = aa(list(C),nat,size_size(list(C)),Uua) ) ) ).

% ATP.lambda_58
tff(fact_6197_ATP_Olambda__59,axiom,
    ! [C: $tType,Uu: set(C),Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_mk(set(C),fun(list(C),$o),Uu),Uua)
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uua)),Uu) ) ).

% ATP.lambda_59
tff(fact_6198_ATP_Olambda__60,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: nat,Uua: nat] : aa(nat,C,aTP_Lamp_he(nat,fun(nat,C),Uu),Uua) = aa(nat,C,gbinomial(C,aa(nat,C,semiring_1_of_nat(C),Uua)),Uu) ) ).

% ATP.lambda_60
tff(fact_6199_ATP_Olambda__61,axiom,
    ! [C: $tType,D: $tType,Uu: list(D),Uua: C] : aa(C,list(product_prod(C,D)),aTP_Lamp_de(list(D),fun(C,list(product_prod(C,D))),Uu),Uua) = aa(list(D),list(product_prod(C,D)),aa(fun(D,product_prod(C,D)),fun(list(D),list(product_prod(C,D))),map(D,product_prod(C,D)),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uua)),Uu) ).

% ATP.lambda_61
tff(fact_6200_ATP_Olambda__62,axiom,
    ! [C: $tType,Uu: set(nat),Uua: product_prod(C,nat)] :
      ( aa(product_prod(C,nat),$o,aTP_Lamp_lk(set(nat),fun(product_prod(C,nat),$o),Uu),Uua)
    <=> member2(nat,aa(product_prod(C,nat),nat,product_snd(C,nat),Uua),Uu) ) ).

% ATP.lambda_62
tff(fact_6201_ATP_Olambda__63,axiom,
    ! [Uu: set(nat),Uua: nat] :
      ( aa(nat,$o,aTP_Lamp_kq(set(nat),fun(nat,$o),Uu),Uua)
    <=> member2(nat,aa(nat,nat,suc,Uua),Uu) ) ).

% ATP.lambda_63
tff(fact_6202_ATP_Olambda__64,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_mp(nat,fun(list(C),$o),Uu),Uua)
    <=> ( aa(list(C),nat,size_size(list(C)),Uua) = Uu ) ) ).

% ATP.lambda_64
tff(fact_6203_ATP_Olambda__65,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [Uu: C,Uua: C] : aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),aTP_Lamp_id(C,fun(C,product_prod(C,C))),Uu),Uua) = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uu),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Uua)),one_one(C))) ) ).

% ATP.lambda_65
tff(fact_6204_ATP_Olambda__66,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [Uu: C,Uua: C] : aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),aTP_Lamp_ie(C,fun(C,product_prod(C,C))),Uu),Uua) = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uu),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Uua)) ) ).

% ATP.lambda_66
tff(fact_6205_ATP_Olambda__67,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: C,Uua: nat] : aa(nat,C,aTP_Lamp_aa(C,fun(nat,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),plus_plus(C),Uu),divide_divide(C,aa(nat,C,semiring_1_of_nat(C),Uua),aa(num,C,numeral_numeral(C),bit0(one2)))) ) ).

% ATP.lambda_67
tff(fact_6206_ATP_Olambda__68,axiom,
    ! [C: $tType,Uu: C,Uua: set(set(C))] : aa(set(set(C)),set(set(C)),aa(C,fun(set(set(C)),set(set(C))),aTP_Lamp_ho(C,fun(set(set(C)),set(set(C)))),Uu),Uua) = aa(set(set(C)),set(set(C)),aa(set(set(C)),fun(set(set(C)),set(set(C))),sup_sup(set(set(C))),Uua),aa(set(set(C)),set(set(C)),image2(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uu)),Uua)) ).

% ATP.lambda_68
tff(fact_6207_ATP_Olambda__69,axiom,
    ! [C: $tType,D: $tType,Uu: set(product_prod(D,C)),Uua: D] : aa(D,set(C),aTP_Lamp_ph(set(product_prod(D,C)),fun(D,set(C)),Uu),Uua) = image(D,C,Uu,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),Uua),bot_bot(set(D)))) ).

% ATP.lambda_69
tff(fact_6208_ATP_Olambda__70,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,D),Uua: D] : aa(D,set(C),aTP_Lamp_nd(fun(C,D),fun(D,set(C)),Uu),Uua) = aa(set(D),set(C),aa(fun(C,D),fun(set(D),set(C)),vimage(C,D),Uu),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),Uua),bot_bot(set(D)))) ).

% ATP.lambda_70
tff(fact_6209_ATP_Olambda__71,axiom,
    ! [C: $tType,Uu: set(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_ni(set(C),fun(C,$o),Uu),Uua)
    <=> ( Uu = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uua),bot_bot(set(C))) ) ) ).

% ATP.lambda_71
tff(fact_6210_ATP_Olambda__72,axiom,
    ! [C: $tType,Uu: fun(nat,C),Uua: nat] : aa(nat,product_prod(nat,C),aTP_Lamp_do(fun(nat,C),fun(nat,product_prod(nat,C)),Uu),Uua) = aa(C,product_prod(nat,C),aa(nat,fun(C,product_prod(nat,C)),product_Pair(nat,C),Uua),aa(nat,C,Uu,Uua)) ).

% ATP.lambda_72
tff(fact_6211_ATP_Olambda__73,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: C] : aa(C,product_prod(C,D),aTP_Lamp_by(fun(C,D),fun(C,product_prod(C,D)),Uu),Uua) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uua),aa(C,D,Uu,Uua)) ).

% ATP.lambda_73
tff(fact_6212_ATP_Olambda__74,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_fc(nat,fun(list(C),$o),Uu),Uua)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uu),aa(list(C),nat,size_size(list(C)),Uua)) ) ).

% ATP.lambda_74
tff(fact_6213_ATP_Olambda__75,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: C,Uua: nat] : aa(nat,C,aTP_Lamp_et(C,fun(nat,C),Uu),Uua) = minus_minus(C,Uu,aa(nat,C,semiring_1_of_nat(C),Uua)) ) ).

% ATP.lambda_75
tff(fact_6214_ATP_Olambda__76,axiom,
    ! [D: $tType,C: $tType,Uu: list(product_prod(C,D)),Uua: fun(C,option(D))] : aa(fun(C,option(D)),fun(C,option(D)),aa(list(product_prod(C,D)),fun(fun(C,option(D)),fun(C,option(D))),aTP_Lamp_ou(list(product_prod(C,D)),fun(fun(C,option(D)),fun(C,option(D)))),Uu),Uua) = map_add(C,D,Uua,map_of(C,D,Uu)) ).

% ATP.lambda_76
tff(fact_6215_ATP_Olambda__77,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] :
      ( aa(list(C),$o,aa(C,fun(list(C),$o),aTP_Lamp_nv(C,fun(list(C),$o)),Uu),Uua)
    <=> member2(C,Uu,aa(list(C),set(C),set2(C),Uua)) ) ).

% ATP.lambda_77
tff(fact_6216_ATP_Olambda__78,axiom,
    ! [C: $tType,Uu: list(set(C)),Uua: set(C)] :
      ( aa(set(C),$o,aTP_Lamp_ei(list(set(C)),fun(set(C),$o),Uu),Uua)
    <=> member2(set(C),Uua,aa(list(set(C)),set(set(C)),set2(set(C)),Uu)) ) ).

% ATP.lambda_78
tff(fact_6217_ATP_Olambda__79,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_fo(list(C),fun(C,$o),Uu),Uua)
    <=> member2(C,Uua,aa(list(C),set(C),set2(C),Uu)) ) ).

% ATP.lambda_79
tff(fact_6218_ATP_Olambda__80,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C)] :
      ( aa(list(C),$o,aTP_Lamp_mo(nat,fun(list(C),$o),Uu),Uua)
    <=> ( Uu = aa(list(C),nat,size_size(list(C)),Uua) ) ) ).

% ATP.lambda_80
tff(fact_6219_ATP_Olambda__81,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_nz(list(C),fun(C,$o),Uu),Uua)
    <=> ( Uua = aa(list(C),C,hd(C),Uu) ) ) ).

% ATP.lambda_81
tff(fact_6220_ATP_Olambda__82,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_ny(list(C),fun(C,$o),Uu),Uua)
    <=> ( Uua = last(C,Uu) ) ) ).

% ATP.lambda_82
tff(fact_6221_ATP_Olambda__83,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C)] :
      ( aa(set(C),$o,aTP_Lamp_bk(set(C),fun(set(C),$o),Uu),Uua)
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),Uua),Uu) ) ).

% ATP.lambda_83
tff(fact_6222_ATP_Olambda__84,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_kc(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Uu) ) ) ).

% ATP.lambda_84
tff(fact_6223_ATP_Olambda__85,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_sr(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Uu) ) ) ).

% ATP.lambda_85
tff(fact_6224_ATP_Olambda__86,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_pk(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Uu) ) ) ).

% ATP.lambda_86
tff(fact_6225_ATP_Olambda__87,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_to(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Uu) ) ) ).

% ATP.lambda_87
tff(fact_6226_ATP_Olambda__88,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_ao(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Uu) ) ) ).

% ATP.lambda_88
tff(fact_6227_ATP_Olambda__89,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_tc(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),Uu) ) ) ).

% ATP.lambda_89
tff(fact_6228_ATP_Olambda__90,axiom,
    ! [Uu: nat,Uua: nat] :
      ( aa(nat,$o,aTP_Lamp_bf(nat,fun(nat,$o),Uu),Uua)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uua),Uu) ) ).

% ATP.lambda_90
tff(fact_6229_ATP_Olambda__91,axiom,
    ! [C: $tType] :
      ( bounde4967611905675639751up_bot(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_kd(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),Uu) ) ) ).

% ATP.lambda_91
tff(fact_6230_ATP_Olambda__92,axiom,
    ! [C: $tType] :
      ( semilattice_sup(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_ss(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),Uu) ) ) ).

% ATP.lambda_92
tff(fact_6231_ATP_Olambda__93,axiom,
    ! [C: $tType] :
      ( order_bot(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_pl(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),Uu) ) ) ).

% ATP.lambda_93
tff(fact_6232_ATP_Olambda__94,axiom,
    ! [C: $tType] :
      ( preorder(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_ts(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),Uu) ) ) ).

% ATP.lambda_94
tff(fact_6233_ATP_Olambda__95,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_sq(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),Uu) ) ) ).

% ATP.lambda_95
tff(fact_6234_ATP_Olambda__96,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_td(C,fun(C,$o)),Uu),Uua)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),Uu) ) ) ).

% ATP.lambda_96
tff(fact_6235_ATP_Olambda__97,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Uu: C,Uua: C] : aa(C,C,aTP_Lamp_ej(C,fun(C,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),times_times(C),Uua),Uu) ) ).

% ATP.lambda_97
tff(fact_6236_ATP_Olambda__98,axiom,
    ! [C: $tType] :
      ( ab_group_add(C)
     => ! [Uu: C,Uua: C] : aa(C,C,aTP_Lamp_cl(C,fun(C,C),Uu),Uua) = minus_minus(C,Uua,Uu) ) ).

% ATP.lambda_98
tff(fact_6237_ATP_Olambda__99,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C)] : aa(set(C),set(C),aTP_Lamp_cy(set(C),fun(set(C),set(C)),Uu),Uua) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),Uua),Uu) ).

% ATP.lambda_99
tff(fact_6238_ATP_Olambda__100,axiom,
    ! [C: $tType] :
      ( comple592849572758109894attice(C)
     => ! [Uu: C,Uua: C] : aa(C,C,aTP_Lamp_cp(C,fun(C,C),Uu),Uua) = aa(C,C,aa(C,fun(C,C),inf_inf(C),Uua),Uu) ) ).

% ATP.lambda_100
tff(fact_6239_ATP_Olambda__101,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_df(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uu) ).

% ATP.lambda_101
tff(fact_6240_ATP_Olambda__102,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: C,Uua: ref(C)] : aa(ref(C),assn,aa(C,fun(ref(C),assn),aTP_Lamp_km(C,fun(ref(C),assn)),Uu),Uua) = sngr_assn(C,Uua,Uu) ) ).

% ATP.lambda_102
tff(fact_6241_ATP_Olambda__103,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: list(C),Uua: array(C)] : aa(array(C),assn,aa(list(C),fun(array(C),assn),aTP_Lamp_kl(list(C),fun(array(C),assn)),Uu),Uua) = snga_assn(C,Uua,Uu) ) ).

% ATP.lambda_103
tff(fact_6242_ATP_Olambda__104,axiom,
    ! [C: $tType,D: $tType,Uu: D,Uua: C] : aa(C,product_prod(C,D),aa(D,fun(C,product_prod(C,D)),aTP_Lamp_hs(D,fun(C,product_prod(C,D))),Uu),Uua) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uua),Uu) ).

% ATP.lambda_104
tff(fact_6243_ATP_Olambda__105,axiom,
    ! [C: $tType,Uu: C,Uua: nat] : aa(nat,product_prod(nat,C),aTP_Lamp_kr(C,fun(nat,product_prod(nat,C)),Uu),Uua) = aa(C,product_prod(nat,C),aa(nat,fun(C,product_prod(nat,C)),product_Pair(nat,C),Uua),Uu) ).

% ATP.lambda_105
tff(fact_6244_ATP_Olambda__106,axiom,
    ! [D: $tType,C: $tType,Uu: C,Uua: D] : aa(D,product_prod(D,C),aTP_Lamp_kz(C,fun(D,product_prod(D,C)),Uu),Uua) = aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),Uua),Uu) ).

% ATP.lambda_106
tff(fact_6245_ATP_Olambda__107,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] : aa(C,list(C),aa(list(C),fun(C,list(C)),aTP_Lamp_dm(list(C),fun(C,list(C))),Uu),Uua) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uu) ).

% ATP.lambda_107
tff(fact_6246_ATP_Olambda__108,axiom,
    ! [C: $tType] :
      ( wellorder(C)
     => ! [Uu: set(C),Uua: C] :
          ( aa(C,$o,aTP_Lamp_kb(set(C),fun(C,$o),Uu),Uua)
        <=> member2(C,Uua,Uu) ) ) ).

% ATP.lambda_108
tff(fact_6247_ATP_Olambda__109,axiom,
    ! [C: $tType] :
      ( order(C)
     => ! [Uu: set(C),Uua: C] :
          ( aa(C,$o,aTP_Lamp_mn(set(C),fun(C,$o),Uu),Uua)
        <=> member2(C,Uua,Uu) ) ) ).

% ATP.lambda_109
tff(fact_6248_ATP_Olambda__110,axiom,
    ! [C: $tType,Uu: set(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_a(set(C),fun(C,$o),Uu),Uua)
    <=> member2(C,Uua,Uu) ) ).

% ATP.lambda_110
tff(fact_6249_ATP_Olambda__111,axiom,
    ! [C: $tType,Uu: list(C),Uua: nat] : aa(nat,list(C),aTP_Lamp_py(list(C),fun(nat,list(C)),Uu),Uua) = aa(list(C),list(C),aa(nat,fun(list(C),list(C)),drop(C),Uua),Uu) ).

% ATP.lambda_111
tff(fact_6250_ATP_Olambda__112,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C)] : aa(list(C),C,aTP_Lamp_fu(nat,fun(list(C),C),Uu),Uua) = aa(nat,C,nth(C,Uua),Uu) ).

% ATP.lambda_112
tff(fact_6251_ATP_Olambda__113,axiom,
    ! [C: $tType,Uu: C,Uua: C] :
      ( aa(C,$o,aTP_Lamp_ad(C,fun(C,$o),Uu),Uua)
    <=> ( Uua = Uu ) ) ).

% ATP.lambda_113
tff(fact_6252_ATP_Olambda__114,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),aTP_Lamp_eq(C,fun(list(C),list(C))),Uu),Uua) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),nil(C)) ).

% ATP.lambda_114
tff(fact_6253_ATP_Olambda__115,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),list(list(C)),aa(C,fun(list(C),list(list(C))),aTP_Lamp_er(C,fun(list(C),list(list(C)))),Uu),Uua) = aa(list(list(C)),list(list(C)),aa(list(C),fun(list(list(C)),list(list(C))),cons(list(C)),Uua),nil(list(C))) ).

% ATP.lambda_115
tff(fact_6254_ATP_Olambda__116,axiom,
    ! [C: $tType,Uu: C,Uua: C] : aa(C,set(C),aTP_Lamp_nf(C,fun(C,set(C)),Uu),Uua) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uu),bot_bot(set(C))) ).

% ATP.lambda_116
tff(fact_6255_ATP_Olambda__117,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,set(nat),aTP_Lamp_tv(nat,fun(nat,set(nat)),Uu),Uua) = order_underS(nat,bNF_Ca8665028551170535155natLeq,Uu) ).

% ATP.lambda_117
tff(fact_6256_ATP_Olambda__118,axiom,
    ! [C: $tType,Uu: fun(nat,$o),Uua: product_prod(C,nat)] :
      ( aa(product_prod(C,nat),$o,aTP_Lamp_le(fun(nat,$o),fun(product_prod(C,nat),$o),Uu),Uua)
    <=> aa(nat,$o,Uu,aa(nat,nat,suc,aa(product_prod(C,nat),nat,product_snd(C,nat),Uua))) ) ).

% ATP.lambda_118
tff(fact_6257_ATP_Olambda__119,axiom,
    ! [C: $tType,Uu: fun(nat,$o),Uua: product_prod(C,nat)] :
      ( aa(product_prod(C,nat),$o,aTP_Lamp_lf(fun(nat,$o),fun(product_prod(C,nat),$o),Uu),Uua)
    <=> aa(nat,$o,Uu,aa(product_prod(C,nat),nat,product_snd(C,nat),Uua)) ) ).

% ATP.lambda_119
tff(fact_6258_ATP_Olambda__120,axiom,
    ! [E2: $tType,D: $tType,C: $tType,Uu: fun(D,E2),Uua: product_prod(C,D)] : aa(product_prod(C,D),E2,aTP_Lamp_lg(fun(D,E2),fun(product_prod(C,D),E2),Uu),Uua) = aa(D,E2,Uu,aa(product_prod(C,D),D,product_snd(C,D),Uua)) ).

% ATP.lambda_120
tff(fact_6259_ATP_Olambda__121,axiom,
    ! [E2: $tType,D: $tType,C: $tType,Uu: fun(C,E2),Uua: product_prod(C,D)] : aa(product_prod(C,D),E2,aTP_Lamp_li(fun(C,E2),fun(product_prod(C,D),E2),Uu),Uua) = aa(C,E2,Uu,aa(product_prod(C,D),C,product_fst(C,D),Uua)) ).

% ATP.lambda_121
tff(fact_6260_ATP_Olambda__122,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(nat,C),Uua: nat] : aa(nat,C,aTP_Lamp_du(fun(nat,C),fun(nat,C),Uu),Uua) = aa(nat,C,Uu,aa(nat,nat,suc,Uua)) ) ).

% ATP.lambda_122
tff(fact_6261_ATP_Olambda__123,axiom,
    ! [C: $tType,Uu: fun(nat,C),Uua: nat] : aa(nat,C,aTP_Lamp_dw(fun(nat,C),fun(nat,C),Uu),Uua) = aa(nat,C,Uu,aa(nat,nat,suc,Uua)) ).

% ATP.lambda_123
tff(fact_6262_ATP_Olambda__124,axiom,
    ! [C: $tType,Uu: C,Uua: fun(C,nat)] : aa(fun(C,nat),nat,aTP_Lamp_ty(C,fun(fun(C,nat),nat),Uu),Uua) = aa(C,nat,Uua,Uu) ).

% ATP.lambda_124
tff(fact_6263_ATP_Olambda__125,axiom,
    ! [D: $tType,C: $tType,Uu: fun(set(C),C),Uua: D] : aa(D,C,aTP_Lamp_ui(fun(set(C),C),fun(D,C),Uu),Uua) = aa(set(C),C,Uu,bot_bot(set(C))) ).

% ATP.lambda_125
tff(fact_6264_ATP_Olambda__126,axiom,
    ! [C: $tType] :
      ( semilattice_inf(C)
     => ! [Uu: C,Uua: option(C)] : aa(option(C),option(C),aa(C,fun(option(C),option(C)),aTP_Lamp_ox(C,fun(option(C),option(C))),Uu),Uua) = aa(C,option(C),some(C),case_option(C,C,Uu,aa(C,fun(C,C),inf_inf(C),Uu),Uua)) ) ).

% ATP.lambda_126
tff(fact_6265_ATP_Olambda__127,axiom,
    ! [C: $tType,Uu: list(C),Uua: list(C)] : aa(list(C),fun(product_prod(C,list(C)),option($o)),aTP_Lamp_ow(list(C),fun(list(C),fun(product_prod(C,list(C)),option($o))),Uu),Uua) = product_case_prod(C,list(C),option($o),aa(list(C),fun(C,fun(list(C),option($o))),aTP_Lamp_ov(list(C),fun(list(C),fun(C,fun(list(C),option($o)))),Uu),Uua)) ).

% ATP.lambda_127
tff(fact_6266_ATP_Olambda__128,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),fun(product_prod(C,list(C)),option(product_prod(list(C),product_prod(C,list(C))))),aTP_Lamp_op(C,fun(list(C),fun(product_prod(C,list(C)),option(product_prod(list(C),product_prod(C,list(C)))))),Uu),Uua) = product_case_prod(C,list(C),option(product_prod(list(C),product_prod(C,list(C)))),aa(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),aTP_Lamp_oo(C,fun(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))))),Uu),Uua)) ).

% ATP.lambda_128
tff(fact_6267_ATP_Olambda__129,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: list(C)] : aa(list(C),fun(product_prod(list(C),list(C)),list(C)),aTP_Lamp_ip(fun(C,D),fun(list(C),fun(product_prod(list(C),list(C)),list(C))),Uu),Uua) = product_case_prod(list(C),list(C),list(C),aa(list(C),fun(list(C),fun(list(C),list(C))),aTP_Lamp_io(fun(C,D),fun(list(C),fun(list(C),fun(list(C),list(C)))),Uu),Uua)) ) ).

% ATP.lambda_129
tff(fact_6268_ATP_Olambda__130,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(E2,fun(C,E2)),Uua: E2] : aa(E2,fun(product_prod(D,C),E2),aTP_Lamp_ib(fun(E2,fun(C,E2)),fun(E2,fun(product_prod(D,C),E2)),Uu),Uua) = product_case_prod(D,C,E2,aa(E2,fun(D,fun(C,E2)),aTP_Lamp_ia(fun(E2,fun(C,E2)),fun(E2,fun(D,fun(C,E2))),Uu),Uua)) ).

% ATP.lambda_130
tff(fact_6269_ATP_Olambda__131,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,option(C)),Uua: D] :
      ( aa(D,$o,aTP_Lamp_pd(fun(D,option(C)),fun(D,$o),Uu),Uua)
    <=> ( aa(D,option(C),Uu,Uua) != none(C) ) ) ).

% ATP.lambda_131
tff(fact_6270_ATP_Olambda__132,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: list(product_prod(E2,D)),Uua: product_prod(C,E2)] : aa(product_prod(C,E2),list(product_prod(C,D)),aTP_Lamp_lp(list(product_prod(E2,D)),fun(product_prod(C,E2),list(product_prod(C,D))),Uu),Uua) = aa(list(list(product_prod(C,D))),list(product_prod(C,D)),concat(product_prod(C,D)),aa(list(product_prod(E2,D)),list(list(product_prod(C,D))),aa(fun(product_prod(E2,D),list(product_prod(C,D))),fun(list(product_prod(E2,D)),list(list(product_prod(C,D)))),map(product_prod(E2,D),list(product_prod(C,D))),aTP_Lamp_lo(product_prod(C,E2),fun(product_prod(E2,D),list(product_prod(C,D))),Uua)),Uu)) ).

% ATP.lambda_132
tff(fact_6271_ATP_Olambda__133,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: C,Uua: nat] : aa(nat,fun(C,C),aTP_Lamp_fb(C,fun(nat,fun(C,C)),Uu),Uua) = aa(C,fun(C,C),times_times(C),minus_minus(C,Uu,aa(nat,C,semiring_1_of_nat(C),Uua))) ) ).

% ATP.lambda_133
tff(fact_6272_ATP_Olambda__134,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [Uu: C,Uua: nat] : aa(nat,fun(C,C),aTP_Lamp_fd(C,fun(nat,fun(C,C)),Uu),Uua) = aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),Uu),aa(nat,C,semiring_1_of_nat(C),Uua))) ) ).

% ATP.lambda_134
tff(fact_6273_ATP_Olambda__135,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_fp(list(C),fun(C,$o),Uu),Uua)
    <=> ~ member2(C,Uua,aa(list(C),set(C),set2(C),Uu)) ) ).

% ATP.lambda_135
tff(fact_6274_ATP_Olambda__136,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_ii(list(C),fun(C,$o),Uu),Uua)
    <=> ( Uua != last(C,Uu) ) ) ).

% ATP.lambda_136
tff(fact_6275_ATP_Olambda__137,axiom,
    ! [C: $tType] :
      ( inf(C)
     => ! [Uu: C,Uua: C] : aa(C,option(C),aTP_Lamp_os(C,fun(C,option(C)),Uu),Uua) = aa(C,option(C),some(C),aa(C,C,aa(C,fun(C,C),inf_inf(C),Uu),Uua)) ) ).

% ATP.lambda_137
tff(fact_6276_ATP_Olambda__138,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: C,Uua: C] :
          ( aa(C,$o,aTP_Lamp_im(C,fun(C,$o),Uu),Uua)
        <=> ~ aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uu),Uua) ) ) ).

% ATP.lambda_138
tff(fact_6277_ATP_Olambda__139,axiom,
    ! [C: $tType,Uu: set(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_bh(set(C),fun(C,$o),Uu),Uua)
    <=> ~ member2(C,Uua,Uu) ) ).

% ATP.lambda_139
tff(fact_6278_ATP_Olambda__140,axiom,
    ! [C: $tType,Uu: C,Uua: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_fg(C,fun(C,$o)),Uu),Uua)
    <=> ( Uu != Uua ) ) ).

% ATP.lambda_140
tff(fact_6279_ATP_Olambda__141,axiom,
    ! [C: $tType,Uu: C,Uua: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_fn(C,fun(C,$o)),Uu),Uua)
    <=> ( Uua != Uu ) ) ).

% ATP.lambda_141
tff(fact_6280_ATP_Olambda__142,axiom,
    ! [C: $tType,Uu: C,Uua: C] : aa(C,set(C),aTP_Lamp_mw(C,fun(C,set(C)),Uu),Uua) = aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uu),bot_bot(set(C)))) ).

% ATP.lambda_142
tff(fact_6281_ATP_Olambda__143,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(D)
     => ! [Uu: fun(C,$o),Uua: C] : aa(C,D,aTP_Lamp_gd(fun(C,$o),fun(C,D),Uu),Uua) = aa($o,D,zero_neq_one_of_bool(D),aa(C,$o,Uu,Uua)) ) ).

% ATP.lambda_143
tff(fact_6282_ATP_Olambda__144,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,set(product_prod(D,D))),Uua: C] : aa(C,set(product_prod(D,D)),aTP_Lamp_nq(fun(C,set(product_prod(D,D))),fun(C,set(product_prod(D,D))),Uu),Uua) = transitive_trancl(D,aa(C,set(product_prod(D,D)),Uu,Uua)) ).

% ATP.lambda_144
tff(fact_6283_ATP_Olambda__145,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(nat,C),Uua: nat] : aa(nat,fun(C,C),aTP_Lamp_ft(fun(nat,C),fun(nat,fun(C,C)),Uu),Uua) = aa(C,fun(C,C),times_times(C),aa(nat,C,Uu,Uua)) ) ).

% ATP.lambda_145
tff(fact_6284_ATP_Olambda__146,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [Uu: fun(C,D),Uua: C] : aa(C,option(D),aTP_Lamp_oj(fun(C,D),fun(C,option(D)),Uu),Uua) = aa(D,option(D),some(D),aa(C,D,Uu,Uua)) ) ).

% ATP.lambda_146
tff(fact_6285_ATP_Olambda__147,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: C] : aa(C,option(D),aTP_Lamp_oz(fun(C,D),fun(C,option(D)),Uu),Uua) = aa(D,option(D),some(D),aa(C,D,Uu,Uua)) ).

% ATP.lambda_147
tff(fact_6286_ATP_Olambda__148,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(E2,C),Uua: E2] : aa(E2,fun(D,product_prod(C,D)),aTP_Lamp_hu(fun(E2,C),fun(E2,fun(D,product_prod(C,D))),Uu),Uua) = aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(E2,C,Uu,Uua)) ).

% ATP.lambda_148
tff(fact_6287_ATP_Olambda__149,axiom,
    ! [E2: $tType,F4: $tType,Uu: fun(F4,set(E2)),Uua: F4] : aa(F4,filter(E2),aTP_Lamp_uk(fun(F4,set(E2)),fun(F4,filter(E2)),Uu),Uua) = principal(E2,aa(F4,set(E2),Uu,Uua)) ).

% ATP.lambda_149
tff(fact_6288_ATP_Olambda__150,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,set(D)),Uua: C] : aa(C,filter(D),aTP_Lamp_ul(fun(C,set(D)),fun(C,filter(D)),Uu),Uua) = principal(D,aa(C,set(D),Uu,Uua)) ).

% ATP.lambda_150
tff(fact_6289_ATP_Olambda__151,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,set(D)),Uua: C] : aa(C,nat,aTP_Lamp_ic(fun(C,set(D)),fun(C,nat),Uu),Uua) = finite_card(D,aa(C,set(D),Uu,Uua)) ).

% ATP.lambda_151
tff(fact_6290_ATP_Olambda__152,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,list(C)),Uua: D] : aa(D,set(C),aTP_Lamp_dl(fun(D,list(C)),fun(D,set(C)),Uu),Uua) = aa(list(C),set(C),set2(C),aa(D,list(C),Uu,Uua)) ).

% ATP.lambda_152
tff(fact_6291_ATP_Olambda__153,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: C] : aa(C,fun(set(D),set(D)),aTP_Lamp_hz(fun(C,D),fun(C,fun(set(D),set(D))),Uu),Uua) = aa(D,fun(set(D),set(D)),insert2(D),aa(C,D,Uu,Uua)) ).

% ATP.lambda_153
tff(fact_6292_ATP_Olambda__154,axiom,
    ! [D: $tType,Uu: fun(D,$o),Uua: D] :
      ( aa(D,$o,aTP_Lamp_am(fun(D,$o),fun(D,$o),Uu),Uua)
    <=> ~ aa(D,$o,Uu,Uua) ) ).

% ATP.lambda_154
tff(fact_6293_ATP_Olambda__155,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: C] :
      ( aa(C,$o,aTP_Lamp_bi(fun(C,$o),fun(C,$o),Uu),Uua)
    <=> ~ aa(C,$o,Uu,Uua) ) ).

% ATP.lambda_155
tff(fact_6294_ATP_Olambda__156,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(D,$o)),Uua: C] :
      ( aa(C,$o,aTP_Lamp_qc(fun(C,fun(D,$o)),fun(C,$o),Uu),Uua)
    <=> ? [X_12: D] : aa(D,$o,aa(C,fun(D,$o),Uu,Uua),X_12) ) ).

% ATP.lambda_156
tff(fact_6295_ATP_Olambda__157,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,set(nat),aTP_Lamp_tt(nat,fun(nat,set(nat)),Uu),Uua) = collect(nat,aTP_Lamp_bf(nat,fun(nat,$o),Uu)) ).

% ATP.lambda_157
tff(fact_6296_ATP_Olambda__158,axiom,
    ! [C: $tType,Uu: fun(C,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Uua: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aTP_Lamp_so(fun(C,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uu),Uua)
    <=> ? [X4: C] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(C,fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uu,X4),Uua) ) ).

% ATP.lambda_158
tff(fact_6297_ATP_Olambda__159,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(D,$o)),Uua: D] :
      ( aa(D,$o,aTP_Lamp_qd(fun(C,fun(D,$o)),fun(D,$o),Uu),Uua)
    <=> ? [A6: C] : aa(D,$o,aa(C,fun(D,$o),Uu,A6),Uua) ) ).

% ATP.lambda_159
tff(fact_6298_ATP_Olambda__160,axiom,
    ! [C: $tType,Uu: list(C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_jk(list(C),fun(C,$o),Uu),Uua)
    <=> ? [I2: nat] :
          ( ( Uua = aa(nat,C,nth(C,Uu),I2) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Uu)) ) ) ).

% ATP.lambda_160
tff(fact_6299_ATP_Olambda__161,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C)] :
      ( aa(set(C),$o,aTP_Lamp_jx(set(C),fun(set(C),$o),Uu),Uua)
    <=> ? [B9: set(C)] :
          ( ( Uua = aa(set(C),set(C),uminus_uminus(set(C)),B9) )
          & member2(set(C),Uu,pow(C,B9)) ) ) ).

% ATP.lambda_161
tff(fact_6300_ATP_Olambda__162,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [Uu: set(C),Uua: C] :
          ( aa(C,$o,aTP_Lamp_pv(set(C),fun(C,$o),Uu),Uua)
        <=> ! [X4: C] :
              ( member2(C,X4,Uu)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uua),X4) ) ) ) ).

% ATP.lambda_162
tff(fact_6301_ATP_Olambda__163,axiom,
    ! [C: $tType] :
      ( condit1219197933456340205attice(C)
     => ! [Uu: set(C),Uua: C] :
          ( aa(C,$o,aTP_Lamp_pp(set(C),fun(C,$o),Uu),Uua)
        <=> ! [X4: C] :
              ( member2(C,X4,Uu)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),X4),Uua) ) ) ) ).

% ATP.lambda_163
tff(fact_6302_ATP_Olambda__164,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aTP_Lamp_sl(fun(C,assn),fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uu),Uua)
    <=> ? [X4: C] : aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,aa(C,assn,Uu,X4)),Uua) ) ).

% ATP.lambda_164
tff(fact_6303_ATP_Olambda__165,axiom,
    ! [C: $tType,D: $tType,Uu: C,Uua: product_prod(C,D)] :
      ( aa(product_prod(C,D),$o,aTP_Lamp_of(C,fun(product_prod(C,D),$o),Uu),Uua)
    <=> ? [V5: D] : Uua = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uu),V5) ) ).

% ATP.lambda_165
tff(fact_6304_ATP_Olambda__166,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: C] :
      ( aa(C,$o,aTP_Lamp_kw(fun(D,C),fun(C,$o),Uu),Uua)
    <=> ? [X4: D] : Uua = aa(D,C,Uu,X4) ) ).

% ATP.lambda_166
tff(fact_6305_ATP_Olambda__167,axiom,
    ! [D: $tType,C: $tType,Uu: set(product_prod(C,D)),Uua: product_prod(product_prod($o,C),product_prod($o,D))] :
      ( aa(product_prod(product_prod($o,C),product_prod($o,D)),$o,aTP_Lamp_jv(set(product_prod(C,D)),fun(product_prod(product_prod($o,C),product_prod($o,D)),$o),Uu),Uua)
    <=> ? [X4: C,Y3: D] :
          ( ( Uua = aa(product_prod($o,D),product_prod(product_prod($o,C),product_prod($o,D)),aa(product_prod($o,C),fun(product_prod($o,D),product_prod(product_prod($o,C),product_prod($o,D))),product_Pair(product_prod($o,C),product_prod($o,D)),aa(C,product_prod($o,C),aa($o,fun(C,product_prod($o,C)),product_Pair($o,C),$false),X4)),aa(D,product_prod($o,D),aa($o,fun(D,product_prod($o,D)),product_Pair($o,D),$false),Y3)) )
          & member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X4),Y3),Uu) ) ) ).

% ATP.lambda_167
tff(fact_6306_ATP_Olambda__168,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: product_prod(set(C),set(C))] :
      ( aa(product_prod(set(C),set(C)),$o,aTP_Lamp_qk(set(product_prod(C,C)),fun(product_prod(set(C),set(C)),$o),Uu),Uua)
    <=> ? [X9: set(C),Y8: set(C)] :
          ( ( Uua = aa(set(C),product_prod(set(C),set(C)),aa(set(C),fun(set(C),product_prod(set(C),set(C))),product_Pair(set(C),set(C)),X9),Y8) )
          & ( X9 != bot_bot(set(C)) )
          & ! [X4: C] :
              ( member2(C,X4,Y8)
             => ? [Xa2: C] :
                  ( member2(C,Xa2,X9)
                  & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Xa2),X4),Uu) ) ) ) ) ).

% ATP.lambda_168
tff(fact_6307_ATP_Olambda__169,axiom,
    ! [C: $tType,Uu: set(C),Uua: C] : aa(C,set(C),aTP_Lamp_np(set(C),fun(C,set(C)),Uu),Uua) = aa(set(C),set(C),uminus_uminus(set(C)),Uu) ).

% ATP.lambda_169
tff(fact_6308_ATP_Olambda__170,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),option(C),aa(C,fun(list(C),option(C)),aTP_Lamp_oq(C,fun(list(C),option(C))),Uu),Uua) = aa(C,option(C),some(C),Uu) ).

% ATP.lambda_170
tff(fact_6309_ATP_Olambda__171,axiom,
    ! [C: $tType,D: $tType,Uu: set(product_prod(D,D)),Uua: C] : aa(C,set(D),aTP_Lamp_su(set(product_prod(D,D)),fun(C,set(D)),Uu),Uua) = field2(D,Uu) ).

% ATP.lambda_171
tff(fact_6310_ATP_Olambda__172,axiom,
    ! [D: $tType,C: $tType,Uu: set(product_prod(C,C)),Uua: D] : aa(D,set(C),aTP_Lamp_sv(set(product_prod(C,C)),fun(D,set(C)),Uu),Uua) = field2(C,Uu) ).

% ATP.lambda_172
tff(fact_6311_ATP_Olambda__173,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C] : aa(C,set(C),aTP_Lamp_mj(set(product_prod(C,C)),fun(C,set(C)),Uu),Uua) = field2(C,Uu) ).

% ATP.lambda_173
tff(fact_6312_ATP_Olambda__174,axiom,
    ! [C: $tType,D: $tType,Uu: list(D),Uua: C] : aa(C,set(D),aTP_Lamp_md(list(D),fun(C,set(D)),Uu),Uua) = aa(list(D),set(D),set2(D),Uu) ).

% ATP.lambda_174
tff(fact_6313_ATP_Olambda__175,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),fun(set(C),set(C)),aa(C,fun(list(C),fun(set(C),set(C))),aTP_Lamp_ob(C,fun(list(C),fun(set(C),set(C)))),Uu),Uua) = aa(C,fun(set(C),set(C)),insert2(C),Uu) ).

% ATP.lambda_175
tff(fact_6314_ATP_Olambda__176,axiom,
    ! [C: $tType,Uu: set(C),Uua: list(C)] : aa(list(C),set(list(C)),aTP_Lamp_mh(set(C),fun(list(C),set(list(C))),Uu),Uua) = aa(set(C),set(list(C)),lists(C),Uu) ).

% ATP.lambda_176
tff(fact_6315_ATP_Olambda__177,axiom,
    ! [C: $tType,Uu: nat,Uua: C] : aa(C,nat,aa(nat,fun(C,nat),aTP_Lamp_ai(nat,fun(C,nat)),Uu),Uua) = aa(nat,nat,suc,Uu) ).

% ATP.lambda_177
tff(fact_6316_ATP_Olambda__178,axiom,
    ! [C: $tType] :
      ( unique1627219031080169319umeral(C)
     => ! [Uu: num,Uua: C,Uub: C] :
          aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),aTP_Lamp_hn(num,fun(C,fun(C,product_prod(C,C))),Uu),Uua),Uub) = $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(num,C,numeral_numeral(C),Uu)),Uub),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Uua)),one_one(C))),minus_minus(C,Uub,aa(num,C,numeral_numeral(C),Uu))),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(num,C,numeral_numeral(C),bit0(one2))),Uua)),Uub)) ) ).

% ATP.lambda_178
tff(fact_6317_ATP_Olambda__179,axiom,
    ! [C: $tType,Uu: C,Uua: C,Uub: list(C)] :
      aa(list(C),list(C),aa(C,fun(list(C),list(C)),aTP_Lamp_lx(C,fun(C,fun(list(C),list(C))),Uu),Uua),Uub) = $ite(Uu = Uua,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uub),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uub))) ).

% ATP.lambda_179
tff(fact_6318_ATP_Olambda__180,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_add(D)
     => ! [Uu: fun(C,D),Uua: set(C),Uub: C] :
          aa(C,D,aa(set(C),fun(C,D),aTP_Lamp_gi(fun(C,D),fun(set(C),fun(C,D)),Uu),Uua),Uub) = $ite(member2(C,Uub,Uua),aa(C,D,Uu,Uub),zero_zero(D)) ) ).

% ATP.lambda_180
tff(fact_6319_ATP_Olambda__181,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: fun(C,D),Uua: set(C),Uub: C] :
          aa(C,D,aa(set(C),fun(C,D),aTP_Lamp_dh(fun(C,D),fun(set(C),fun(C,D)),Uu),Uua),Uub) = $ite(member2(C,Uub,Uua),aa(C,D,Uu,Uub),one_one(D)) ) ).

% ATP.lambda_181
tff(fact_6320_ATP_Olambda__182,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: C,Uua: fun(C,D),Uub: C] :
          aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_aj(C,fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = $ite(Uu = Uub,aa(C,D,Uua,Uub),one_one(D)) ) ).

% ATP.lambda_182
tff(fact_6321_ATP_Olambda__183,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: C,Uua: fun(C,D),Uub: C] :
          aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_ak(C,fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = $ite(Uub = Uu,aa(C,D,Uua,Uub),one_one(D)) ) ).

% ATP.lambda_183
tff(fact_6322_ATP_Olambda__184,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(C)
     => ! [Uu: D,Uua: C,Uub: D] :
          aa(D,C,aa(C,fun(D,C),aTP_Lamp_re(D,fun(C,fun(D,C)),Uu),Uua),Uub) = $ite(Uu = Uub,Uua,zero_zero(C)) ) ).

% ATP.lambda_184
tff(fact_6323_ATP_Olambda__185,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: D,Uua: C,Uub: D] :
          aa(D,C,aa(C,fun(D,C),aTP_Lamp_rh(D,fun(C,fun(D,C)),Uu),Uua),Uub) = $ite(Uu = Uub,Uua,one_one(C)) ) ).

% ATP.lambda_185
tff(fact_6324_ATP_Olambda__186,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(C)
     => ! [Uu: D,Uua: C,Uub: D] :
          aa(D,C,aa(C,fun(D,C),aTP_Lamp_rd(D,fun(C,fun(D,C)),Uu),Uua),Uub) = $ite(Uub = Uu,Uua,zero_zero(C)) ) ).

% ATP.lambda_186
tff(fact_6325_ATP_Olambda__187,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: D,Uua: C,Uub: D] :
          aa(D,C,aa(C,fun(D,C),aTP_Lamp_ri(D,fun(C,fun(D,C)),Uu),Uua),Uub) = $ite(Uub = Uu,Uua,one_one(C)) ) ).

% ATP.lambda_187
tff(fact_6326_ATP_Olambda__188,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: C,Uub: list(C)] :
      aa(list(C),list(C),aa(C,fun(list(C),list(C)),aTP_Lamp_fm(fun(C,$o),fun(C,fun(list(C),list(C))),Uu),Uua),Uub) = $ite(aa(C,$o,Uu,Uua),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uub),Uub) ).

% ATP.lambda_188
tff(fact_6327_ATP_Olambda__189,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: C,Uub: set(C)] :
      aa(set(C),set(C),aa(C,fun(set(C),set(C)),aTP_Lamp_if(fun(C,$o),fun(C,fun(set(C),set(C))),Uu),Uua),Uub) = $ite(aa(C,$o,Uu,Uua),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uua),Uub),Uub) ).

% ATP.lambda_189
tff(fact_6328_ATP_Olambda__190,axiom,
    ! [D: $tType,C: $tType] :
      ( monoid_add(C)
     => ! [Uu: fun(D,C),Uua: fun(D,$o),Uub: D] :
          aa(D,C,aa(fun(D,$o),fun(D,C),aTP_Lamp_rm(fun(D,C),fun(fun(D,$o),fun(D,C)),Uu),Uua),Uub) = $ite(aa(D,$o,Uua,Uub),aa(D,C,Uu,Uub),zero_zero(C)) ) ).

% ATP.lambda_190
tff(fact_6329_ATP_Olambda__191,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: fun(C,D),Uua: fun(C,$o),Uub: C] :
          aa(C,D,aa(fun(C,$o),fun(C,D),aTP_Lamp_cr(fun(C,D),fun(fun(C,$o),fun(C,D)),Uu),Uua),Uub) = $ite(aa(C,$o,Uua,Uub),aa(C,D,Uu,Uub),one_one(D)) ) ).

% ATP.lambda_191
tff(fact_6330_ATP_Olambda__192,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,fun(C,C)),Uua: fun(D,$o),Uub: D] :
      aa(D,fun(C,C),aa(fun(D,$o),fun(D,fun(C,C)),aTP_Lamp_nm(fun(D,fun(C,C)),fun(fun(D,$o),fun(D,fun(C,C))),Uu),Uua),Uub) = $ite(aa(D,$o,Uua,Uub),aa(D,fun(C,C),Uu,Uub),id(C)) ).

% ATP.lambda_192
tff(fact_6331_ATP_Olambda__193,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,C),Uua: fun(D,$o),Uub: D] :
      aa(D,option(C),aa(fun(D,$o),fun(D,option(C)),aTP_Lamp_om(fun(D,C),fun(fun(D,$o),fun(D,option(C))),Uu),Uua),Uub) = $ite(aa(D,$o,Uua,Uub),aa(C,option(C),some(C),aa(D,C,Uu,Uub)),none(C)) ).

% ATP.lambda_193
tff(fact_6332_ATP_Olambda__194,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: list(C),Uub: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aTP_Lamp_ln(fun(C,fun(C,$o)),fun(list(C),fun(list(C),list(C))),Uu),Uua),Uub) = merges9089515139780605204_merge(C,Uu,aa(list(C),list(C),mergesort_by_rel(C,Uu),Uua),aa(list(C),list(C),mergesort_by_rel(C,Uu),Uub)) ).

% ATP.lambda_194
tff(fact_6333_ATP_Olambda__195,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,fun(C,$o)),Uua: C,Uub: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_qf(fun(D,fun(C,$o)),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> aa(C,$o,aa(D,fun(C,$o),Uu,Uub),Uua) ) ).

% ATP.lambda_195
tff(fact_6334_ATP_Olambda__196,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,fun(C,C)),Uua: C,Uub: D] : aa(D,C,aa(C,fun(D,C),aTP_Lamp_db(fun(D,fun(C,C)),fun(C,fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(D,fun(C,C),Uu,Uub),Uua) ).

% ATP.lambda_196
tff(fact_6335_ATP_Olambda__197,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(D,D)),Uua: D,Uub: C] : aa(C,D,aa(D,fun(C,D),aTP_Lamp_st(fun(C,fun(D,D)),fun(D,fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(C,fun(D,D),Uu,Uub),Uua) ).

% ATP.lambda_197
tff(fact_6336_ATP_Olambda__198,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(D,C)),Uua: D,Uub: C] : aa(C,C,aa(D,fun(C,C),aTP_Lamp_dc(fun(C,fun(D,C)),fun(D,fun(C,C)),Uu),Uua),Uub) = aa(D,C,aa(C,fun(D,C),Uu,Uub),Uua) ).

% ATP.lambda_198
tff(fact_6337_ATP_Olambda__199,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: C,Uub: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_ay(fun(C,fun(C,$o)),fun(C,fun(C,$o)),Uu),Uua),Uub)
    <=> aa(C,$o,aa(C,fun(C,$o),Uu,Uub),Uua) ) ).

% ATP.lambda_199
tff(fact_6338_ATP_Olambda__200,axiom,
    ! [C: $tType] :
      ( field(C)
     => ! [Uu: fun(nat,C),Uua: fun(nat,C),Uub: nat] : aa(nat,C,aa(fun(nat,C),fun(nat,C),aTP_Lamp_gc(fun(nat,C),fun(fun(nat,C),fun(nat,C)),Uu),Uua),Uub) = divide_divide(C,aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,Uu,Uub)),aa(nat,C,aa(C,fun(nat,C),power_power(C),zero_zero(C)),Uub)),aa(nat,C,Uua,Uub)) ) ).

% ATP.lambda_200
tff(fact_6339_ATP_Olambda__201,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: list(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_ik(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(C),nat,size_size(list(C)),Uua)),aa(list(C),nat,size_size(list(C)),Uub))
        | ( ( aa(list(C),nat,size_size(list(C)),Uua) = aa(list(C),nat,size_size(list(C)),Uub) )
          & member2(product_prod(list(C),list(C)),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Uua),Uub),lex(C,Uu)) ) ) ) ).

% ATP.lambda_201
tff(fact_6340_ATP_Olambda__202,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_qh(nat,fun(list(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Uua) = aa(nat,nat,suc,Uu) )
        & ( aa(list(C),nat,size_size(list(C)),Uub) = aa(nat,nat,suc,Uu) ) ) ) ).

% ATP.lambda_202
tff(fact_6341_ATP_Olambda__203,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: list(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_ji(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Uua) = aa(list(C),nat,size_size(list(C)),Uub) )
        & ? [Xys2: list(C),X4: C,Y3: C,Xs5: list(C),Ys5: list(C)] :
            ( ( Uua = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs5)) )
            & ( Uub = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys5)) )
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),Y3),Uu) ) ) ) ).

% ATP.lambda_203
tff(fact_6342_ATP_Olambda__204,axiom,
    ! [C: $tType,Uu: nat,Uua: set(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(set(C),fun(list(C),$o),aTP_Lamp_ey(nat,fun(set(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Uub) = Uu )
        & aa(list(C),$o,distinct(C),Uub)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uub)),Uua) ) ) ).

% ATP.lambda_204
tff(fact_6343_ATP_Olambda__205,axiom,
    ! [C: $tType,Uu: set(C),Uua: nat,Uub: list(C)] :
      ( aa(list(C),$o,aa(nat,fun(list(C),$o),aTP_Lamp_aw(set(C),fun(nat,fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Uub) = Uua )
        & aa(list(C),$o,distinct(C),Uub)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uub)),Uu) ) ) ).

% ATP.lambda_205
tff(fact_6344_ATP_Olambda__206,axiom,
    ! [C: $tType,Uu: set(C),Uua: nat,Uub: list(C)] :
      ( aa(list(C),$o,aa(nat,fun(list(C),$o),aTP_Lamp_mq(set(C),fun(nat,fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uub)),Uu)
        & ( aa(list(C),nat,size_size(list(C)),Uub) = aa(nat,nat,suc,Uua) ) ) ) ).

% ATP.lambda_206
tff(fact_6345_ATP_Olambda__207,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_ec(nat,fun(list(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Uub) = Uu )
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uub)),aa(list(C),set(C),set2(C),Uua)) ) ) ).

% ATP.lambda_207
tff(fact_6346_ATP_Olambda__208,axiom,
    ! [C: $tType,Uu: set(C),Uua: nat,Uub: list(C)] :
      ( aa(list(C),$o,aa(nat,fun(list(C),$o),aTP_Lamp_eh(set(C),fun(nat,fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uub)),Uu)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(C),nat,size_size(list(C)),Uub)),Uua) ) ) ).

% ATP.lambda_208
tff(fact_6347_ATP_Olambda__209,axiom,
    ! [C: $tType,Uu: set(C),Uua: nat,Uub: list(C)] :
      ( aa(list(C),$o,aa(nat,fun(list(C),$o),aTP_Lamp_dx(set(C),fun(nat,fun(list(C),$o)),Uu),Uua),Uub)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(list(C),set(C),set2(C),Uub)),Uu)
        & ( aa(list(C),nat,size_size(list(C)),Uub) = Uua ) ) ) ).

% ATP.lambda_209
tff(fact_6348_ATP_Olambda__210,axiom,
    ! [C: $tType,Uu: set(nat),Uua: nat,Uub: product_prod(C,nat)] :
      ( aa(product_prod(C,nat),$o,aa(nat,fun(product_prod(C,nat),$o),aTP_Lamp_ll(set(nat),fun(nat,fun(product_prod(C,nat),$o)),Uu),Uua),Uub)
    <=> member2(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(product_prod(C,nat),nat,product_snd(C,nat),Uub)),Uua),Uu) ) ).

% ATP.lambda_210
tff(fact_6349_ATP_Olambda__211,axiom,
    ! [C: $tType,Uu: set(list(C)),Uua: list(C),Uub: C] :
      ( aa(C,$o,aa(list(C),fun(C,$o),aTP_Lamp_dk(set(list(C)),fun(list(C),fun(C,$o)),Uu),Uua),Uub)
    <=> member2(list(C),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Uua),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uub),nil(C))),Uu) ) ).

% ATP.lambda_211
tff(fact_6350_ATP_Olambda__212,axiom,
    ! [C: $tType,Uu: list(C),Uua: set(nat),Uub: nat] :
      ( aa(nat,$o,aa(set(nat),fun(nat,$o),aTP_Lamp_kp(list(C),fun(set(nat),fun(nat,$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),aa(list(C),nat,size_size(list(C)),Uu))
        & member2(nat,Uub,Uua) ) ) ).

% ATP.lambda_212
tff(fact_6351_ATP_Olambda__213,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: list(C),Uub: nat] :
      ( aa(nat,$o,aa(list(C),fun(nat,$o),aTP_Lamp_fl(fun(C,$o),fun(list(C),fun(nat,$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),aa(list(C),nat,size_size(list(C)),Uua))
        & aa(C,$o,Uu,aa(nat,C,nth(C,Uua),Uub)) ) ) ).

% ATP.lambda_213
tff(fact_6352_ATP_Olambda__214,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: list(C),Uua: fun(C,$o),Uub: C] :
          ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_or(list(C),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
        <=> ( member2(C,Uub,aa(list(C),set(C),set2(C),Uu))
            & aa(C,$o,Uua,Uub) ) ) ) ).

% ATP.lambda_214
tff(fact_6353_ATP_Olambda__215,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: list(C),Uub: C] :
      ( aa(C,$o,aa(list(C),fun(C,$o),aTP_Lamp_ff(fun(C,$o),fun(list(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,aa(list(C),set(C),set2(C),Uua))
        & aa(C,$o,Uu,Uub) ) ) ).

% ATP.lambda_215
tff(fact_6354_ATP_Olambda__216,axiom,
    ! [C: $tType,Uu: list(C),Uua: set(nat),Uub: nat] :
      ( aa(nat,$o,aa(set(nat),fun(nat,$o),aTP_Lamp_kn(list(C),fun(set(nat),fun(nat,$o)),Uu),Uua),Uub)
    <=> member2(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),aa(list(C),nat,size_size(list(C)),Uu)),Uua) ) ).

% ATP.lambda_216
tff(fact_6355_ATP_Olambda__217,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_tu(nat,fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uua),Uu)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),Uu)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Uua),Uub) ) ) ).

% ATP.lambda_217
tff(fact_6356_ATP_Olambda__218,axiom,
    ! [Uu: set(nat),Uua: set(nat),Uub: nat] :
      ( aa(nat,$o,aa(set(nat),fun(nat,$o),aTP_Lamp_qq(set(nat),fun(set(nat),fun(nat,$o)),Uu),Uua),Uub)
    <=> ( member2(nat,Uub,Uu)
        & member2(nat,finite_card(nat,collect(nat,aa(nat,fun(nat,$o),aTP_Lamp_qp(set(nat),fun(nat,fun(nat,$o)),Uu),Uub))),Uua) ) ) ).

% ATP.lambda_218
tff(fact_6357_ATP_Olambda__219,axiom,
    ! [Uu: assn,Uua: assn,Uub: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_rz(assn,fun(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Uu),Uua),Uub)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Uu),Uub)
        | aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Uua),Uub) ) ) ).

% ATP.lambda_219
tff(fact_6358_ATP_Olambda__220,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_bs(set(C),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uu)
        | member2(C,Uub,Uua) ) ) ).

% ATP.lambda_220
tff(fact_6359_ATP_Olambda__221,axiom,
    ! [C: $tType,Uu: C,Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_bm(C,fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( ( Uub = Uu )
        | member2(C,Uub,Uua) ) ) ).

% ATP.lambda_221
tff(fact_6360_ATP_Olambda__222,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C),Uub: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),aTP_Lamp_qu(set(C),fun(set(C),fun(set(C),$o)),Uu),Uua),Uub)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),Uub),Uua)
        & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),Uua),Uu) ) ) ).

% ATP.lambda_222
tff(fact_6361_ATP_Olambda__223,axiom,
    ! [Uu: assn,Uua: assn,Uub: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_sa(assn,fun(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Uu),Uua),Uub)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Uu),Uub)
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(assn,fun(product_prod(heap_ext(product_unit),set(nat)),$o),rep_assn,Uua),Uub) ) ) ).

% ATP.lambda_223
tff(fact_6362_ATP_Olambda__224,axiom,
    ! [Uu: set(nat),Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_qp(set(nat),fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> ( member2(nat,Uub,Uu)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),Uua) ) ) ).

% ATP.lambda_224
tff(fact_6363_ATP_Olambda__225,axiom,
    ! [C: $tType,Uu: set(set(C)),Uua: C,Uub: set(C)] :
      ( aa(set(C),$o,aa(C,fun(set(C),$o),aTP_Lamp_ro(set(set(C)),fun(C,fun(set(C),$o)),Uu),Uua),Uub)
    <=> ( member2(set(C),Uub,Uu)
        & member2(C,Uua,Uub) ) ) ).

% ATP.lambda_225
tff(fact_6364_ATP_Olambda__226,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_bv(set(C),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uu)
        & member2(C,Uub,Uua) ) ) ).

% ATP.lambda_226
tff(fact_6365_ATP_Olambda__227,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C),Uub: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),aTP_Lamp_da(set(C),fun(set(C),fun(set(C),$o)),Uu),Uua),Uub)
    <=> ( minus_minus(set(C),Uub,Uu) = minus_minus(set(C),Uua,Uu) ) ) ).

% ATP.lambda_227
tff(fact_6366_ATP_Olambda__228,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_uj(fun(C,$o),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uua)
       => aa(C,$o,Uu,Uub) ) ) ).

% ATP.lambda_228
tff(fact_6367_ATP_Olambda__229,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Uu: set(C),Uua: fun(C,$o),Uub: C] :
          ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_kf(set(C),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
        <=> ( member2(C,Uub,Uu)
            & aa(C,$o,Uua,Uub) ) ) ) ).

% ATP.lambda_229
tff(fact_6368_ATP_Olambda__230,axiom,
    ! [C: $tType,Uu: set(C),Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bl(set(C),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uu)
        & aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_230
tff(fact_6369_ATP_Olambda__231,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_ig(fun(C,$o),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uua)
        & aa(C,$o,Uu,Uub) ) ) ).

% ATP.lambda_231
tff(fact_6370_ATP_Olambda__232,axiom,
    ! [C: $tType,Uu: C,Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bp(C,fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( ( Uu = Uub )
        & aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_232
tff(fact_6371_ATP_Olambda__233,axiom,
    ! [C: $tType,Uu: C,Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bq(C,fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( ( Uub = Uu )
        & aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_233
tff(fact_6372_ATP_Olambda__234,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: fun(C,set(D)),Uub: C] :
      ( aa(C,$o,aa(fun(C,set(D)),fun(C,$o),aTP_Lamp_ml(set(C),fun(fun(C,set(D)),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uu)
        & ( aa(C,set(D),Uua,Uub) != bot_bot(set(D)) ) ) ) ).

% ATP.lambda_234
tff(fact_6373_ATP_Olambda__235,axiom,
    ! [C: $tType,D: $tType] :
      ( ab_group_add(D)
     => ! [Uu: set(C),Uua: fun(C,D),Uub: C] :
          ( aa(C,$o,aa(fun(C,D),fun(C,$o),aTP_Lamp_in(set(C),fun(fun(C,D),fun(C,$o)),Uu),Uua),Uub)
        <=> ( member2(C,Uub,Uu)
            & ( aa(C,D,Uua,Uub) != zero_zero(D) ) ) ) ) ).

% ATP.lambda_235
tff(fact_6374_ATP_Olambda__236,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: set(C),Uua: fun(C,D),Uub: C] :
          ( aa(C,$o,aa(fun(C,D),fun(C,$o),aTP_Lamp_ch(set(C),fun(fun(C,D),fun(C,$o)),Uu),Uua),Uub)
        <=> ( member2(C,Uub,Uu)
            & ( aa(C,D,Uua,Uub) != one_one(D) ) ) ) ) ).

% ATP.lambda_236
tff(fact_6375_ATP_Olambda__237,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(D,C),Uua: set(D),Uub: D] :
          ( aa(D,$o,aa(set(D),fun(D,$o),aTP_Lamp_kj(fun(D,C),fun(set(D),fun(D,$o)),Uu),Uua),Uub)
        <=> ( member2(D,Uub,Uua)
            & ( aa(D,C,Uu,Uub) != one_one(C) ) ) ) ) ).

% ATP.lambda_237
tff(fact_6376_ATP_Olambda__238,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: array(C),Uua: list(C),Uub: nat] : aa(nat,assn,aa(list(C),fun(nat,assn),aTP_Lamp_tj(array(C),fun(list(C),fun(nat,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),snga_assn(C,Uu,Uua)),pure_assn(Uub = aa(list(C),nat,size_size(list(C)),Uua))) ) ).

% ATP.lambda_238
tff(fact_6377_ATP_Olambda__239,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: ref(C),Uua: C,Uub: C] : aa(C,assn,aa(C,fun(C,assn),aTP_Lamp_tl(ref(C),fun(C,fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),sngr_assn(C,Uu,Uua)),pure_assn(Uub = Uua)) ) ).

% ATP.lambda_239
tff(fact_6378_ATP_Olambda__240,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: array(C),Uua: list(C),Uub: list(C)] : aa(list(C),assn,aa(list(C),fun(list(C),assn),aTP_Lamp_tm(array(C),fun(list(C),fun(list(C),assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),snga_assn(C,Uu,Uua)),pure_assn(Uub = Uua)) ) ).

% ATP.lambda_240
tff(fact_6379_ATP_Olambda__241,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_cb(set(C),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ( member2(C,Uub,Uu)
        & ~ member2(C,Uub,Uua) ) ) ).

% ATP.lambda_241
tff(fact_6380_ATP_Olambda__242,axiom,
    ! [C: $tType,F4: $tType,E2: $tType,Uu: fun(E2,fun(F4,$o)),Uua: fun(E2,C),Uub: set(C)] : aa(set(C),set(E2),aa(fun(E2,C),fun(set(C),set(E2)),aTP_Lamp_ud(fun(E2,fun(F4,$o)),fun(fun(E2,C),fun(set(C),set(E2))),Uu),Uua),Uub) = aa(set(E2),set(E2),aa(set(E2),fun(set(E2),set(E2)),inf_inf(set(E2)),aa(set(C),set(E2),aa(fun(E2,C),fun(set(C),set(E2)),vimage(E2,C),Uua),Uub)),collect(E2,domainp(E2,F4,Uu))) ).

% ATP.lambda_242
tff(fact_6381_ATP_Olambda__243,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Uu: C,Uua: C,Uub: C] : aa(C,C,aa(C,fun(C,C),aTP_Lamp_en(C,fun(C,fun(C,C)),Uu),Uua),Uub) = minus_minus(C,divide_divide(C,Uub,Uu),Uua) ) ).

% ATP.lambda_243
tff(fact_6382_ATP_Olambda__244,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Uu: C,Uua: C,Uub: C] : aa(C,C,aa(C,fun(C,C),aTP_Lamp_el(C,fun(C,fun(C,C)),Uu),Uua),Uub) = minus_minus(C,aa(C,C,aa(C,fun(C,C),times_times(C),Uu),Uub),Uua) ) ).

% ATP.lambda_244
tff(fact_6383_ATP_Olambda__245,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Uu: C,Uua: C,Uub: C] : aa(C,C,aa(C,fun(C,C),aTP_Lamp_em(C,fun(C,fun(C,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),divide_divide(C,Uub,Uu)),Uua) ) ).

% ATP.lambda_245
tff(fact_6384_ATP_Olambda__246,axiom,
    ! [C: $tType] :
      ( linordered_field(C)
     => ! [Uu: C,Uua: C,Uub: C] : aa(C,C,aa(C,fun(C,C),aTP_Lamp_ek(C,fun(C,fun(C,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),Uu),Uub)),Uua) ) ).

% ATP.lambda_246
tff(fact_6385_ATP_Olambda__247,axiom,
    ! [C: $tType,D: $tType,Uu: set(product_prod(D,C)),Uua: D,Uub: C] :
      ( aa(C,$o,aa(D,fun(C,$o),aTP_Lamp_pc(set(product_prod(D,C)),fun(D,fun(C,$o)),Uu),Uua),Uub)
    <=> member2(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),Uua),Uub),Uu) ) ).

% ATP.lambda_247
tff(fact_6386_ATP_Olambda__248,axiom,
    ! [D: $tType,C: $tType,Uu: set(product_prod(C,D)),Uua: C,Uub: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_bw(set(product_prod(C,D)),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> member2(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uua),Uub),Uu) ) ).

% ATP.lambda_248
tff(fact_6387_ATP_Olambda__249,axiom,
    ! [C: $tType,Uu: set(list(C)),Uua: C,Uub: list(C)] :
      ( aa(list(C),$o,aa(C,fun(list(C),$o),aTP_Lamp_cg(set(list(C)),fun(C,fun(list(C),$o)),Uu),Uua),Uub)
    <=> member2(list(C),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uub),Uu) ) ).

% ATP.lambda_249
tff(fact_6388_ATP_Olambda__250,axiom,
    ! [C: $tType,Uu: list(list(C)),Uua: nat,Uub: nat] : aa(nat,C,aa(nat,fun(nat,C),aTP_Lamp_ew(list(list(C)),fun(nat,fun(nat,C)),Uu),Uua),Uub) = aa(nat,C,nth(C,aa(nat,list(C),nth(list(C),Uu),Uub)),Uua) ).

% ATP.lambda_250
tff(fact_6389_ATP_Olambda__251,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [Uu: fun(D,C),Uua: D,Uub: D] :
          ( aa(D,$o,aa(D,fun(D,$o),aTP_Lamp_ct(fun(D,C),fun(D,fun(D,$o)),Uu),Uua),Uub)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(D,C,Uu,Uua)),aa(D,C,Uu,Uub)) ) ) ).

% ATP.lambda_251
tff(fact_6390_ATP_Olambda__252,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(D,C),Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_cf(fun(D,C),fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(D,C,Uu,Uub)),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_252
tff(fact_6391_ATP_Olambda__253,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: fun(C,D),Uua: fun(C,D),Uub: C] : aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_kk(fun(C,D),fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,Uu,Uub)),aa(C,D,Uua,Uub)) ) ).

% ATP.lambda_253
tff(fact_6392_ATP_Olambda__254,axiom,
    ! [D: $tType,C: $tType] :
      ( linordered_idom(D)
     => ! [Uu: fun(C,D),Uua: fun(C,D),Uub: C] : aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_gt(fun(C,D),fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,Uua,Uub)),aa(C,D,Uu,Uub)) ) ).

% ATP.lambda_254
tff(fact_6393_ATP_Olambda__255,axiom,
    ! [C: $tType,D: $tType] :
      ( ab_group_add(C)
     => ! [Uu: fun(D,C),Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_rl(fun(D,C),fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = minus_minus(C,aa(D,C,Uu,Uub),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_255
tff(fact_6394_ATP_Olambda__256,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: fun(C,assn),Uub: C] : aa(C,assn,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sk(fun(C,assn),fun(fun(C,assn),fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(C,assn,Uu,Uub)),aa(C,assn,Uua,Uub)) ).

% ATP.lambda_256
tff(fact_6395_ATP_Olambda__257,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [Uu: fun(C,D),Uua: fun(C,D),Uub: C] : aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_po(fun(C,D),fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),sup_sup(D),aa(C,D,Uu,Uub)),aa(C,D,Uua,Uub)) ) ).

% ATP.lambda_257
tff(fact_6396_ATP_Olambda__258,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,set(C)),Uua: fun(D,set(C)),Uub: D] : aa(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_lu(fun(D,set(C)),fun(fun(D,set(C)),fun(D,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(D,set(C),Uu,Uub)),aa(D,set(C),Uua,Uub)) ).

% ATP.lambda_258
tff(fact_6397_ATP_Olambda__259,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [Uu: fun(D,C),Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_lt(fun(D,C),fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(D,C,Uu,Uub)),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_259
tff(fact_6398_ATP_Olambda__260,axiom,
    ! [C: $tType,D: $tType] :
      ( lattice(C)
     => ! [Uu: fun(D,C),Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_pt(fun(D,C),fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(D,C,Uu,Uub)),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_260
tff(fact_6399_ATP_Olambda__261,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,set(D)),Uua: fun(C,set(D)),Uub: C] : aa(C,set(D),aa(fun(C,set(D)),fun(C,set(D)),aTP_Lamp_mt(fun(C,set(D)),fun(fun(C,set(D)),fun(C,set(D))),Uu),Uua),Uub) = aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),aa(C,set(D),Uu,Uub)),aa(C,set(D),Uua,Uub)) ).

% ATP.lambda_261
tff(fact_6400_ATP_Olambda__262,axiom,
    ! [D: $tType,C: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [Uu: fun(C,D),Uua: fun(C,D),Uub: C] : aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_pu(fun(C,D),fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(C,D,Uu,Uub)),aa(C,D,Uua,Uub)) ) ).

% ATP.lambda_262
tff(fact_6401_ATP_Olambda__263,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_add(C)
     => ! [Uu: fun(D,C),Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_rk(fun(D,C),fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(D,C,Uu,Uub)),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_263
tff(fact_6402_ATP_Olambda__264,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,multiset(D)),Uua: fun(C,multiset(D)),Uub: C] : aa(C,multiset(D),aa(fun(C,multiset(D)),fun(C,multiset(D)),aTP_Lamp_qe(fun(C,multiset(D)),fun(fun(C,multiset(D)),fun(C,multiset(D))),Uu),Uua),Uub) = union_mset(D,aa(C,multiset(D),Uu,Uub),aa(C,multiset(D),Uua,Uub)) ).

% ATP.lambda_264
tff(fact_6403_ATP_Olambda__265,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,multiset(D)),Uua: fun(C,multiset(D)),Uub: C] : aa(C,multiset(D),aa(fun(C,multiset(D)),fun(C,multiset(D)),aTP_Lamp_qb(fun(C,multiset(D)),fun(fun(C,multiset(D)),fun(C,multiset(D))),Uu),Uua),Uub) = inter_mset(D,aa(C,multiset(D),Uu,Uub),aa(C,multiset(D),Uua,Uub)) ).

% ATP.lambda_265
tff(fact_6404_ATP_Olambda__266,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(E2,C),Uua: fun(E2,D),Uub: E2] : aa(E2,product_prod(C,D),aa(fun(E2,D),fun(E2,product_prod(C,D)),aTP_Lamp_mx(fun(E2,C),fun(fun(E2,D),fun(E2,product_prod(C,D))),Uu),Uua),Uub) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(E2,C,Uu,Uub)),aa(E2,D,Uua,Uub)) ).

% ATP.lambda_266
tff(fact_6405_ATP_Olambda__267,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bg(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,$o,Uu,Uub)
       => aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_267
tff(fact_6406_ATP_Olambda__268,axiom,
    ! [Uu: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uua: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uub: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_sn(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Uu),Uua),Uub)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Uu,Uub)
        | aa(product_prod(heap_ext(product_unit),set(nat)),$o,Uua,Uub) ) ) ).

% ATP.lambda_268
tff(fact_6407_ATP_Olambda__269,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bt(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,$o,Uu,Uub)
        | aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_269
tff(fact_6408_ATP_Olambda__270,axiom,
    ! [Uu: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uua: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Uub: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aa(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o),aTP_Lamp_sm(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(fun(product_prod(heap_ext(product_unit),set(nat)),$o),fun(product_prod(heap_ext(product_unit),set(nat)),$o)),Uu),Uua),Uub)
    <=> ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,Uu,Uub)
        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,Uua,Uub) ) ) ).

% ATP.lambda_270
tff(fact_6409_ATP_Olambda__271,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bu(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,$o,Uu,Uub)
        & aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_271
tff(fact_6410_ATP_Olambda__272,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_fe(fun(C,$o),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,$o,Uua,Uub)
        & aa(C,$o,Uu,Uub) ) ) ).

% ATP.lambda_272
tff(fact_6411_ATP_Olambda__273,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: C,Uub: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_ns(fun(C,D),fun(C,fun(C,$o)),Uu),Uua),Uub)
        <=> ( aa(C,D,Uu,Uua) = aa(C,D,Uu,Uub) ) ) ) ).

% ATP.lambda_273
tff(fact_6412_ATP_Olambda__274,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: C,Uub: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_fj(fun(C,D),fun(C,fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,D,Uu,Uua) = aa(C,D,Uu,Uub) ) ) ).

% ATP.lambda_274
tff(fact_6413_ATP_Olambda__275,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: fun(C,D),Uub: C] :
      ( aa(C,$o,aa(fun(C,D),fun(C,$o),aTP_Lamp_rq(fun(C,D),fun(fun(C,D),fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,D,Uu,Uub) = aa(C,D,Uua,Uub) ) ) ).

% ATP.lambda_275
tff(fact_6414_ATP_Olambda__276,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: C,Uua: fun(C,D),Uub: C] :
          ( aa(C,$o,aa(fun(C,D),fun(C,$o),aTP_Lamp_it(C,fun(fun(C,D),fun(C,$o)),Uu),Uua),Uub)
        <=> ( aa(C,D,Uua,Uu) = aa(C,D,Uua,Uub) ) ) ) ).

% ATP.lambda_276
tff(fact_6415_ATP_Olambda__277,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(D)
     => ! [Uu: fun(C,D),Uua: fun(C,$o),Uub: C] : aa(C,D,aa(fun(C,$o),fun(C,D),aTP_Lamp_ga(fun(C,D),fun(fun(C,$o),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,Uu,Uub)),aa($o,D,zero_neq_one_of_bool(D),aa(C,$o,Uua,Uub))) ) ).

% ATP.lambda_277
tff(fact_6416_ATP_Olambda__278,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_qz(fun(C,fun(C,$o)),fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,$o,Uua,Uub)
        & ! [Y3: C] :
            ( aa(C,$o,Uua,Y3)
           => aa(C,$o,aa(C,fun(C,$o),Uu,Uub),Y3) ) ) ) ).

% ATP.lambda_278
tff(fact_6417_ATP_Olambda__279,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: fun(C,assn),Uub: C] : aa(C,assn,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sj(fun(C,assn),fun(fun(C,assn),fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(C,assn,Uu,Uub)),ex_assn(C,Uua)) ).

% ATP.lambda_279
tff(fact_6418_ATP_Olambda__280,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,option(D)),Uua: C,Uub: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_oi(fun(C,option(D)),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> ( aa(C,option(D),Uu,Uua) = aa(D,option(D),some(D),Uub) ) ) ).

% ATP.lambda_280
tff(fact_6419_ATP_Olambda__281,axiom,
    ! [C: $tType,D: $tType] :
      ( euclid4440199948858584721cancel(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C] : aa(C,D,aa(D,fun(C,D),aTP_Lamp_go(fun(C,D),fun(D,fun(C,D)),Uu),Uua),Uub) = divide_divide(D,aa(C,D,Uu,Uub),Uua) ) ).

% ATP.lambda_281
tff(fact_6420_ATP_Olambda__282,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_0(C)
     => ! [Uu: fun(D,C),Uua: C,Uub: D] : aa(D,C,aa(C,fun(D,C),aTP_Lamp_gf(fun(D,C),fun(C,fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(D,C,Uu,Uub)),Uua) ) ).

% ATP.lambda_282
tff(fact_6421_ATP_Olambda__283,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: assn,Uub: C] : aa(C,assn,aa(assn,fun(C,assn),aTP_Lamp_se(fun(C,assn),fun(assn,fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,Uu,Uub)),Uua) ).

% ATP.lambda_283
tff(fact_6422_ATP_Olambda__284,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,set(C)),Uua: set(C),Uub: D] : aa(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_ls(fun(D,set(C)),fun(set(C),fun(D,set(C))),Uu),Uua),Uub) = minus_minus(set(C),aa(D,set(C),Uu,Uub),Uua) ).

% ATP.lambda_284
tff(fact_6423_ATP_Olambda__285,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,set(C)),Uua: set(C),Uub: D] : aa(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_as(fun(D,set(C)),fun(set(C),fun(D,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(D,set(C),Uu,Uub)),Uua) ).

% ATP.lambda_285
tff(fact_6424_ATP_Olambda__286,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: assn,Uub: C] : aa(C,assn,aa(assn,fun(C,assn),aTP_Lamp_sg(fun(C,assn),fun(assn,fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),aa(C,assn,Uu,Uub)),Uua) ).

% ATP.lambda_286
tff(fact_6425_ATP_Olambda__287,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,set(C)),Uua: set(C),Uub: D] : aa(D,set(C),aa(set(C),fun(D,set(C)),aTP_Lamp_cv(fun(D,set(C)),fun(set(C),fun(D,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(D,set(C),Uu,Uub)),Uua) ).

% ATP.lambda_287
tff(fact_6426_ATP_Olambda__288,axiom,
    ! [D: $tType,C: $tType] :
      ( comple592849572758109894attice(C)
     => ! [Uu: fun(D,C),Uua: C,Uub: D] : aa(D,C,aa(C,fun(D,C),aTP_Lamp_cq(fun(D,C),fun(C,fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(D,C,Uu,Uub)),Uua) ) ).

% ATP.lambda_288
tff(fact_6427_ATP_Olambda__289,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: assn,Uub: C] : aa(C,assn,aa(assn,fun(C,assn),aTP_Lamp_sh(fun(C,assn),fun(assn,fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),aa(C,assn,Uu,Uub)),Uua) ).

% ATP.lambda_289
tff(fact_6428_ATP_Olambda__290,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C] : aa(C,D,aa(D,fun(C,D),aTP_Lamp_lw(fun(C,D),fun(D,fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),inf_inf(D),aa(C,D,Uu,Uub)),Uua) ) ).

% ATP.lambda_290
tff(fact_6429_ATP_Olambda__291,axiom,
    ! [C: $tType,D: $tType] :
      ( linord4140545234300271783up_add(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C] : aa(C,D,aa(D,fun(C,D),aTP_Lamp_dt(fun(C,D),fun(D,fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(C,D,Uu,Uub)),Uua) ) ).

% ATP.lambda_291
tff(fact_6430_ATP_Olambda__292,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(C,filter(D)),Uua: filter(E2),Uub: C] : aa(C,filter(product_prod(D,E2)),aa(filter(E2),fun(C,filter(product_prod(D,E2))),aTP_Lamp_uq(fun(C,filter(D)),fun(filter(E2),fun(C,filter(product_prod(D,E2)))),Uu),Uua),Uub) = prod_filter(D,E2,aa(C,filter(D),Uu,Uub),Uua) ).

% ATP.lambda_292
tff(fact_6431_ATP_Olambda__293,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,D),Uua: set(D),Uub: C] :
      ( aa(C,$o,aa(set(D),fun(C,$o),aTP_Lamp_nb(fun(C,D),fun(set(D),fun(C,$o)),Uu),Uua),Uub)
    <=> member2(D,aa(C,D,Uu,Uub),Uua) ) ).

% ATP.lambda_293
tff(fact_6432_ATP_Olambda__294,axiom,
    ! [D: $tType,C: $tType,Uu: set(C),Uua: fun(D,C),Uub: D] :
      ( aa(D,$o,aa(fun(D,C),fun(D,$o),aTP_Lamp_kx(set(C),fun(fun(D,C),fun(D,$o)),Uu),Uua),Uub)
    <=> member2(C,aa(D,C,Uua,Uub),Uu) ) ).

% ATP.lambda_294
tff(fact_6433_ATP_Olambda__295,axiom,
    ! [E2: $tType,C: $tType,D: $tType,Uu: fun(E2,set(D)),Uua: fun(D,set(C)),Uub: E2] : aa(E2,set(C),aa(fun(D,set(C)),fun(E2,set(C)),aTP_Lamp_ql(fun(E2,set(D)),fun(fun(D,set(C)),fun(E2,set(C))),Uu),Uua),Uub) = bind2(D,C,aa(E2,set(D),Uu,Uub),Uua) ).

% ATP.lambda_295
tff(fact_6434_ATP_Olambda__296,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C] :
          ( aa(C,$o,aa(D,fun(C,$o),aTP_Lamp_iv(fun(C,D),fun(D,fun(C,$o)),Uu),Uua),Uub)
        <=> ( aa(C,D,Uu,Uub) = Uua ) ) ) ).

% ATP.lambda_296
tff(fact_6435_ATP_Olambda__297,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,D),Uua: D,Uub: C] :
      ( aa(C,$o,aa(D,fun(C,$o),aTP_Lamp_nj(fun(C,D),fun(D,fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(C,D,Uu,Uub) = Uua ) ) ).

% ATP.lambda_297
tff(fact_6436_ATP_Olambda__298,axiom,
    ! [C: $tType,Uu: C,Uua: fun(C,$o),Uub: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aTP_Lamp_bn(C,fun(fun(C,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ( ( Uub != Uu )
       => aa(C,$o,Uua,Uub) ) ) ).

% ATP.lambda_298
tff(fact_6437_ATP_Olambda__299,axiom,
    ! [C: $tType,Uu: C,Uua: C,Uub: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_je(C,fun(C,fun(C,$o)),Uu),Uua),Uub)
    <=> ( ( Uua != Uu )
        & ( Uub != Uu ) ) ) ).

% ATP.lambda_299
tff(fact_6438_ATP_Olambda__300,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: C,Uub: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_rp(fun(C,$o),fun(C,fun(C,$o)),Uu),Uua),Uub)
    <=> ( ~ aa(C,$o,Uu,Uub)
        | ( Uua = Uub ) ) ) ).

% ATP.lambda_300
tff(fact_6439_ATP_Olambda__301,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(D)
     => ! [Uu: fun(C,$o),Uua: fun(C,D),Uub: C] : aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_gb(fun(C,$o),fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),times_times(D),aa($o,D,zero_neq_one_of_bool(D),aa(C,$o,Uu,Uub))),aa(C,D,Uua,Uub)) ) ).

% ATP.lambda_301
tff(fact_6440_ATP_Olambda__302,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Uu: fun(list(C),fun(list(C),$o)),Uua: list(C),Uub: list(C)] :
          ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o)),aTP_Lamp_jy(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o))),Uu),Uua),Uub)
        <=> ( ? [Y3: C,Ys3: list(C)] :
                ( ( Uua = nil(C) )
                & ( Uub = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) ) )
            | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
                ( ( Uua = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
                & ( Uub = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
                & aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y3) )
            | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
                ( ( Uua = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
                & ( Uub = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
                & ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),X4),Y3)
                & ~ aa(C,$o,aa(C,fun(C,$o),ord_less(C),Y3),X4)
                & aa(list(C),$o,aa(list(C),fun(list(C),$o),Uu,Xs3),Ys3) ) ) ) ) ).

% ATP.lambda_302
tff(fact_6441_ATP_Olambda__303,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: set(C),Uub: set(C)] :
      ( aa(set(C),$o,aa(set(C),fun(set(C),$o),aTP_Lamp_qw(set(product_prod(C,C)),fun(set(C),fun(set(C),$o)),Uu),Uua),Uub)
    <=> ( aa(set(C),$o,finite_finite2(C),Uua)
        & aa(set(C),$o,finite_finite2(C),Uub)
        & ( Uub != bot_bot(set(C)) )
        & ! [X4: C] :
            ( member2(C,X4,Uua)
           => ? [Xa2: C] :
                ( member2(C,Xa2,Uub)
                & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),Xa2),Uu) ) ) ) ) ).

% ATP.lambda_303
tff(fact_6442_ATP_Olambda__304,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,C)),Uua: list(C),Uub: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aTP_Lamp_tr(fun(C,fun(C,C)),fun(list(C),fun(list(C),list(C))),Uu),Uua),Uub) = aa(list(product_prod(C,C)),list(C),aa(fun(product_prod(C,C),C),fun(list(product_prod(C,C)),list(C)),map(product_prod(C,C),C),product_case_prod(C,C,C,Uu)),aa(list(C),list(product_prod(C,C)),aa(list(C),fun(list(C),list(product_prod(C,C))),zip(C,C),Uua),Uub)) ).

% ATP.lambda_304
tff(fact_6443_ATP_Olambda__305,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C,Uub: C] : aa(C,set(C),aa(C,fun(C,set(C)),aTP_Lamp_qv(set(product_prod(C,C)),fun(C,fun(C,set(C))),Uu),Uua),Uub) = image(C,C,converse(C,C,Uu),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uua),bot_bot(set(C)))) ).

% ATP.lambda_305
tff(fact_6444_ATP_Olambda__306,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: list(C),Uub: C] : aa(C,fun(list(C),list(C)),aa(list(C),fun(C,fun(list(C),list(C))),aTP_Lamp_is(fun(C,D),fun(list(C),fun(C,fun(list(C),list(C)))),Uu),Uua),Uub) = aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),Uua),aa(C,fun(C,fun(list(C),list(C))),aa(list(C),fun(C,fun(C,fun(list(C),list(C)))),aTP_Lamp_ir(fun(C,D),fun(list(C),fun(C,fun(C,fun(list(C),list(C))))),Uu),Uua),Uub)) ) ).

% ATP.lambda_306
tff(fact_6445_ATP_Olambda__307,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,C),Uua: list(C),Uub: D] : aa(D,list(C),aa(list(C),fun(D,list(C)),aTP_Lamp_ee(fun(D,C),fun(list(C),fun(D,list(C))),Uu),Uua),Uub) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Uua),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),aa(D,C,Uu,Uub)),nil(C))) ).

% ATP.lambda_307
tff(fact_6446_ATP_Olambda__308,axiom,
    ! [C: $tType] :
      ( euclid5411537665997757685th_nat(C)
     => ! [Uu: C,Uua: C,Uub: nat] : aa(nat,C,aa(C,fun(nat,C),aTP_Lamp_hk(C,fun(C,fun(nat,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),Uu),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),Uub)),Uua)) ) ).

% ATP.lambda_308
tff(fact_6447_ATP_Olambda__309,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [Uu: C,Uua: C,Uub: nat] : aa(nat,C,aa(C,fun(nat,C),aTP_Lamp_hh(C,fun(C,fun(nat,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),Uu),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),Uub)),Uua)) ) ).

% ATP.lambda_309
tff(fact_6448_ATP_Olambda__310,axiom,
    ! [C: $tType,Uu: C,Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_pj(C,fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> member2(C,Uub,minus_minus(set(C),Uua,aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uu),bot_bot(set(C))))) ) ).

% ATP.lambda_310
tff(fact_6449_ATP_Olambda__311,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: nat,Uua: fun(nat,C),Uub: array(C)] : aa(array(C),assn,aa(fun(nat,C),fun(array(C),assn),aTP_Lamp_ti(nat,fun(fun(nat,C),fun(array(C),assn)),Uu),Uua),Uub) = snga_assn(C,Uub,aa(list(nat),list(C),aa(fun(nat,C),fun(list(nat),list(C)),map(nat,C),Uua),upt(zero_zero(nat),Uu))) ) ).

% ATP.lambda_311
tff(fact_6450_ATP_Olambda__312,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [Uu: C,Uua: nat,Uub: nat] : aa(nat,C,aa(nat,fun(nat,C),aTP_Lamp_gz(C,fun(nat,fun(nat,C)),Uu),Uua),Uub) = aa(nat,C,aa(C,fun(nat,C),power_power(C),Uu),minus_minus(nat,Uua,aa(nat,nat,suc,Uub))) ) ).

% ATP.lambda_312
tff(fact_6451_ATP_Olambda__313,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,option(D)),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_pe(fun(C,option(D)),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> member2(C,Uub,minus_minus(set(C),Uua,dom(C,D,Uu))) ) ).

% ATP.lambda_313
tff(fact_6452_ATP_Olambda__314,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,option(D)),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_pf(fun(C,option(D)),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> member2(C,Uub,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),Uua),dom(C,D,Uu))) ) ).

% ATP.lambda_314
tff(fact_6453_ATP_Olambda__315,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [Uu: C,Uua: nat,Uub: nat] : aa(nat,C,aa(nat,fun(nat,C),aTP_Lamp_gj(C,fun(nat,fun(nat,C)),Uu),Uua),Uub) = aa(nat,C,aa(C,fun(nat,C),power_power(C),Uu),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uub)) ) ).

% ATP.lambda_315
tff(fact_6454_ATP_Olambda__316,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: nat,Uua: C,Uub: array(C)] : aa(array(C),assn,aa(C,fun(array(C),assn),aTP_Lamp_tk(nat,fun(C,fun(array(C),assn)),Uu),Uua),Uub) = snga_assn(C,Uub,aa(C,list(C),aa(nat,fun(C,list(C)),replicate(C),Uu),Uua)) ) ).

% ATP.lambda_316
tff(fact_6455_ATP_Olambda__317,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: C,Uua: D,Uub: E2] : aa(E2,product_prod(C,product_prod(D,E2)),aa(D,fun(E2,product_prod(C,product_prod(D,E2))),aa(C,fun(D,fun(E2,product_prod(C,product_prod(D,E2)))),aTP_Lamp_ih(C,fun(D,fun(E2,product_prod(C,product_prod(D,E2))))),Uu),Uua),Uub) = aa(product_prod(D,E2),product_prod(C,product_prod(D,E2)),aa(C,fun(product_prod(D,E2),product_prod(C,product_prod(D,E2))),product_Pair(C,product_prod(D,E2)),Uu),aa(E2,product_prod(D,E2),aa(D,fun(E2,product_prod(D,E2)),product_Pair(D,E2),Uua),Uub)) ).

% ATP.lambda_317
tff(fact_6456_ATP_Olambda__318,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: D,Uua: C,Uub: E2] : aa(E2,product_prod(C,product_prod(D,E2)),aa(C,fun(E2,product_prod(C,product_prod(D,E2))),aTP_Lamp_hq(D,fun(C,fun(E2,product_prod(C,product_prod(D,E2)))),Uu),Uua),Uub) = aa(product_prod(D,E2),product_prod(C,product_prod(D,E2)),aa(C,fun(product_prod(D,E2),product_prod(C,product_prod(D,E2))),product_Pair(C,product_prod(D,E2)),Uua),aa(E2,product_prod(D,E2),aa(D,fun(E2,product_prod(D,E2)),product_Pair(D,E2),Uu),Uub)) ).

% ATP.lambda_318
tff(fact_6457_ATP_Olambda__319,axiom,
    ! [C: $tType,Uu: C,Uua: list(C),Uub: nat] : aa(nat,list(C),aa(list(C),fun(nat,list(C)),aTP_Lamp_px(C,fun(list(C),fun(nat,list(C))),Uu),Uua),Uub) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),Uub),Uua)) ).

% ATP.lambda_319
tff(fact_6458_ATP_Olambda__320,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,option(C)),Uua: list(D),Uub: C] : aa(C,list(C),aa(list(D),fun(C,list(C)),aTP_Lamp_pb(fun(D,option(C)),fun(list(D),fun(C,list(C))),Uu),Uua),Uub) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uub),map_filter(D,C,Uu,Uua)) ).

% ATP.lambda_320
tff(fact_6459_ATP_Olambda__321,axiom,
    ! [D: $tType,C: $tType] :
      ( ( order(C)
        & order(D) )
     => ! [Uu: fun(C,D),Uua: set(C),Uub: D] :
          ( aa(D,$o,aa(set(C),fun(D,$o),aTP_Lamp_mm(fun(C,D),fun(set(C),fun(D,$o)),Uu),Uua),Uub)
        <=> member2(D,Uub,aa(set(C),set(D),image2(C,D,Uu),Uua)) ) ) ).

% ATP.lambda_321
tff(fact_6460_ATP_Olambda__322,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( comm_monoid_mult(E2)
     => ! [Uu: fun(C,set(D)),Uua: fun(D,E2),Uub: C] : aa(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_eg(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),Uu),Uua),Uub) = aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7121269368397514597t_prod(D,E2),Uua),aa(C,set(D),Uu,Uub)) ) ).

% ATP.lambda_322
tff(fact_6461_ATP_Olambda__323,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( comm_monoid_add(E2)
     => ! [Uu: fun(C,set(D)),Uua: fun(D,E2),Uub: C] : aa(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_gr(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),Uu),Uua),Uub) = aa(set(D),E2,aa(fun(D,E2),fun(set(D),E2),groups7311177749621191930dd_sum(D,E2),Uua),aa(C,set(D),Uu,Uub)) ) ).

% ATP.lambda_323
tff(fact_6462_ATP_Olambda__324,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [Uu: fun(D,C),Uua: C,Uub: D] :
          ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_il(fun(D,C),fun(C,fun(D,$o)),Uu),Uua),Uub)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),aa(D,C,Uu,Uub)) ) ) ).

% ATP.lambda_324
tff(fact_6463_ATP_Olambda__325,axiom,
    ! [D: $tType,Uu: assn,Uua: fun(D,assn),Uub: D] : aa(D,assn,aa(fun(D,assn),fun(D,assn),aTP_Lamp_tx(assn,fun(fun(D,assn),fun(D,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Uu),aa(D,assn,Uua,Uub)) ).

% ATP.lambda_325
tff(fact_6464_ATP_Olambda__326,axiom,
    ! [C: $tType,Uu: assn,Uua: fun(C,assn),Uub: C] : aa(C,assn,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sd(assn,fun(fun(C,assn),fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Uu),aa(C,assn,Uua,Uub)) ).

% ATP.lambda_326
tff(fact_6465_ATP_Olambda__327,axiom,
    ! [C: $tType,D: $tType] :
      ( semiring_0(C)
     => ! [Uu: C,Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_ge(C,fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),times_times(C),Uu),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_327
tff(fact_6466_ATP_Olambda__328,axiom,
    ! [C: $tType,Uu: fun(C,assn),Uua: assn,Uub: C] : aa(C,assn,aa(assn,fun(C,assn),aTP_Lamp_tf(fun(C,assn),fun(assn,fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Uua),aa(C,assn,Uu,Uub)) ).

% ATP.lambda_328
tff(fact_6467_ATP_Olambda__329,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: fun(D,set(C)),Uub: D] : aa(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_lq(set(C),fun(fun(D,set(C)),fun(D,set(C))),Uu),Uua),Uub) = minus_minus(set(C),Uu,aa(D,set(C),Uua,Uub)) ).

% ATP.lambda_329
tff(fact_6468_ATP_Olambda__330,axiom,
    ! [C: $tType,Uu: assn,Uua: fun(C,assn),Uub: C] : aa(C,assn,aa(fun(C,assn),fun(C,assn),aTP_Lamp_sf(assn,fun(fun(C,assn),fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),Uu),aa(C,assn,Uua,Uub)) ).

% ATP.lambda_330
tff(fact_6469_ATP_Olambda__331,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: fun(D,set(C)),Uub: D] : aa(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_ar(set(C),fun(fun(D,set(C)),fun(D,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),Uu),aa(D,set(C),Uua,Uub)) ).

% ATP.lambda_331
tff(fact_6470_ATP_Olambda__332,axiom,
    ! [C: $tType,Uu: assn,Uua: fun(C,assn),Uub: C] : aa(C,assn,aa(fun(C,assn),fun(C,assn),aTP_Lamp_si(assn,fun(fun(C,assn),fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),inf_inf(assn),Uu),aa(C,assn,Uua,Uub)) ).

% ATP.lambda_332
tff(fact_6471_ATP_Olambda__333,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: fun(D,set(C)),Uub: D] : aa(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_cu(set(C),fun(fun(D,set(C)),fun(D,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),Uu),aa(D,set(C),Uua,Uub)) ).

% ATP.lambda_333
tff(fact_6472_ATP_Olambda__334,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [Uu: D,Uua: fun(C,D),Uub: C] : aa(C,D,aa(fun(C,D),fun(C,D),aTP_Lamp_lv(D,fun(fun(C,D),fun(C,D)),Uu),Uua),Uub) = aa(D,D,aa(D,fun(D,D),inf_inf(D),Uu),aa(C,D,Uua,Uub)) ) ).

% ATP.lambda_334
tff(fact_6473_ATP_Olambda__335,axiom,
    ! [C: $tType,D: $tType] :
      ( comple592849572758109894attice(C)
     => ! [Uu: C,Uua: fun(D,C),Uub: D] : aa(D,C,aa(fun(D,C),fun(D,C),aTP_Lamp_co(C,fun(fun(D,C),fun(D,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),inf_inf(C),Uu),aa(D,C,Uua,Uub)) ) ).

% ATP.lambda_335
tff(fact_6474_ATP_Olambda__336,axiom,
    ! [D: $tType,C: $tType] :
      ( euclid4440199948858584721cancel(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C] :
          ( aa(C,$o,aa(D,fun(C,$o),aTP_Lamp_gp(fun(C,D),fun(D,fun(C,$o)),Uu),Uua),Uub)
        <=> dvd_dvd(D,Uua,aa(C,D,Uu,Uub)) ) ) ).

% ATP.lambda_336
tff(fact_6475_ATP_Olambda__337,axiom,
    ! [D: $tType,E2: $tType,C: $tType,Uu: filter(D),Uua: fun(C,filter(E2)),Uub: C] : aa(C,filter(product_prod(D,E2)),aa(fun(C,filter(E2)),fun(C,filter(product_prod(D,E2))),aTP_Lamp_ur(filter(D),fun(fun(C,filter(E2)),fun(C,filter(product_prod(D,E2)))),Uu),Uua),Uub) = prod_filter(D,E2,Uu,aa(C,filter(E2),Uua,Uub)) ).

% ATP.lambda_337
tff(fact_6476_ATP_Olambda__338,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(E2,D),Uua: C,Uub: E2] : aa(E2,product_prod(C,D),aa(C,fun(E2,product_prod(C,D)),aTP_Lamp_hv(fun(E2,D),fun(C,fun(E2,product_prod(C,D))),Uu),Uua),Uub) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uua),aa(E2,D,Uu,Uub)) ).

% ATP.lambda_338
tff(fact_6477_ATP_Olambda__339,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: set(product_prod(D,C)),Uua: fun(E2,set(D)),Uub: E2] : aa(E2,set(C),aa(fun(E2,set(D)),fun(E2,set(C)),aTP_Lamp_qg(set(product_prod(D,C)),fun(fun(E2,set(D)),fun(E2,set(C))),Uu),Uua),Uub) = image(D,C,Uu,aa(E2,set(D),Uua,Uub)) ).

% ATP.lambda_339
tff(fact_6478_ATP_Olambda__340,axiom,
    ! [C: $tType,D: $tType,Uu: C,Uua: fun(D,set(C)),Uub: D] : aa(D,set(C),aa(fun(D,set(C)),fun(D,set(C)),aTP_Lamp_aq(C,fun(fun(D,set(C)),fun(D,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uu),aa(D,set(C),Uua,Uub)) ).

% ATP.lambda_340
tff(fact_6479_ATP_Olambda__341,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( condit1219197933456340205attice(E2)
     => ! [Uu: fun(C,set(D)),Uua: fun(D,E2),Uub: C] : aa(C,set(E2),aa(fun(D,E2),fun(C,set(E2)),aTP_Lamp_pm(fun(C,set(D)),fun(fun(D,E2),fun(C,set(E2))),Uu),Uua),Uub) = aa(set(D),set(E2),image2(D,E2,Uua),aa(C,set(D),Uu,Uub)) ) ).

% ATP.lambda_341
tff(fact_6480_ATP_Olambda__342,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: fun(list(C),C),Uua: list(C),Uub: C] :
          ( aa(C,$o,aa(list(C),fun(C,$o),aTP_Lamp_fh(fun(list(C),C),fun(list(C),fun(C,$o)),Uu),Uua),Uub)
        <=> ( Uub = aa(list(C),C,Uu,Uua) ) ) ) ).

% ATP.lambda_342
tff(fact_6481_ATP_Olambda__343,axiom,
    ! [C: $tType,Uu: assn,Uua: C,Uub: C] : aa(C,assn,aa(C,fun(C,assn),aTP_Lamp_tn(assn,fun(C,fun(C,assn)),Uu),Uua),Uub) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),Uu),pure_assn(Uub = Uua)) ).

% ATP.lambda_343
tff(fact_6482_ATP_Olambda__344,axiom,
    ! [C: $tType,Uu: list(C),Uua: set(nat),Uub: C] :
      ( aa(C,$o,aa(set(nat),fun(C,$o),aTP_Lamp_ko(list(C),fun(set(nat),fun(C,$o)),Uu),Uua),Uub)
    <=> member2(C,Uub,aa(list(C),set(C),set2(C),aa(set(nat),list(C),aa(list(C),fun(set(nat),list(C)),nths(C),Uu),Uua))) ) ).

% ATP.lambda_344
tff(fact_6483_ATP_Olambda__345,axiom,
    ! [C: $tType,D: $tType,Uu: set(product_prod(D,D)),Uua: fun(D,C),Uub: C] : aa(C,set(C),aa(fun(D,C),fun(C,set(C)),aTP_Lamp_qi(set(product_prod(D,D)),fun(fun(D,C),fun(C,set(C))),Uu),Uua),Uub) = aa(set(D),set(C),image2(D,C,Uua),field2(D,Uu)) ).

% ATP.lambda_345
tff(fact_6484_ATP_Olambda__346,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(C),Uub: C] : aa(C,set(C),aa(set(C),fun(C,set(C)),aTP_Lamp_no(set(C),fun(set(C),fun(C,set(C))),Uu),Uua),Uub) = minus_minus(set(C),Uu,Uua) ).

% ATP.lambda_346
tff(fact_6485_ATP_Olambda__347,axiom,
    ! [C: $tType,D: $tType,Uu: set(D),Uua: set(D),Uub: C] : aa(C,set(D),aa(set(D),fun(C,set(D)),aTP_Lamp_mu(set(D),fun(set(D),fun(C,set(D))),Uu),Uua),Uub) = aa(set(D),set(D),aa(set(D),fun(set(D),set(D)),inf_inf(set(D)),Uu),Uua) ).

% ATP.lambda_347
tff(fact_6486_ATP_Olambda__348,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C,Uub: C] : aa(C,set(C),aa(C,fun(C,set(C)),aTP_Lamp_qj(set(product_prod(C,C)),fun(C,fun(C,set(C))),Uu),Uua),Uub) = order_underS(C,Uu,Uua) ).

% ATP.lambda_348
tff(fact_6487_ATP_Olambda__349,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C,Uub: C] : aa(C,set(C),aa(C,fun(C,set(C)),aTP_Lamp_nx(set(product_prod(C,C)),fun(C,fun(C,set(C))),Uu),Uua),Uub) = order_above(C,Uu,Uua) ).

% ATP.lambda_349
tff(fact_6488_ATP_Olambda__350,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: ref(C),Uua: C,Uub: product_unit] : aa(product_unit,assn,aa(C,fun(product_unit,assn),aTP_Lamp_tq(ref(C),fun(C,fun(product_unit,assn)),Uu),Uua),Uub) = sngr_assn(C,Uu,Uua) ) ).

% ATP.lambda_350
tff(fact_6489_ATP_Olambda__351,axiom,
    ! [C: $tType,Uu: list(C),Uua: C,Uub: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),aTP_Lamp_ba(list(C),fun(C,fun(list(C),list(C))),Uu),Uua),Uub) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Uub),Uu) ).

% ATP.lambda_351
tff(fact_6490_ATP_Olambda__352,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: set(D),Uub: C] : aa(C,set(C),aa(set(D),fun(C,set(C)),aTP_Lamp_mf(fun(D,C),fun(set(D),fun(C,set(C))),Uu),Uua),Uub) = aa(set(D),set(C),image2(D,C,Uu),Uua) ).

% ATP.lambda_352
tff(fact_6491_ATP_Olambda__353,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: list(C),Uub: nat] :
      ( aa(nat,$o,aa(list(C),fun(nat,$o),aTP_Lamp_gl(fun(C,$o),fun(list(C),fun(nat,$o)),Uu),Uua),Uub)
    <=> aa(C,$o,Uu,aa(nat,C,nth(C,Uua),Uub)) ) ).

% ATP.lambda_353
tff(fact_6492_ATP_Olambda__354,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [Uu: fun(multiset(C),D),Uua: fun(E2,multiset(C)),Uub: E2] : aa(E2,D,aa(fun(E2,multiset(C)),fun(E2,D),aTP_Lamp_qa(fun(multiset(C),D),fun(fun(E2,multiset(C)),fun(E2,D)),Uu),Uua),Uub) = aa(multiset(C),D,Uu,aa(E2,multiset(C),Uua,Uub)) ) ).

% ATP.lambda_354
tff(fact_6493_ATP_Olambda__355,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Uu: fun(E2,C),Uua: fun(D,E2),Uub: D] : aa(D,C,aa(fun(D,E2),fun(D,C),aTP_Lamp_kv(fun(E2,C),fun(fun(D,E2),fun(D,C)),Uu),Uua),Uub) = aa(E2,C,Uu,aa(D,E2,Uua,Uub)) ).

% ATP.lambda_355
tff(fact_6494_ATP_Olambda__356,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(D,C),Uua: fun(E2,D),Uub: E2] : aa(E2,C,aa(fun(E2,D),fun(E2,C),aTP_Lamp_bc(fun(D,C),fun(fun(E2,D),fun(E2,C)),Uu),Uua),Uub) = aa(D,C,Uu,aa(E2,D,Uua,Uub)) ).

% ATP.lambda_356
tff(fact_6495_ATP_Olambda__357,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( ( condit1219197933456340205attice(C)
        & condit1219197933456340205attice(D) )
     => ! [Uu: fun(C,D),Uua: fun(E2,C),Uub: E2] : aa(E2,D,aa(fun(E2,C),fun(E2,D),aTP_Lamp_pq(fun(C,D),fun(fun(E2,C),fun(E2,D)),Uu),Uua),Uub) = aa(C,D,Uu,aa(E2,C,Uua,Uub)) ) ).

% ATP.lambda_357
tff(fact_6496_ATP_Olambda__358,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(C,fun(D,$o)),Uua: fun(E2,C),Uub: E2] : aa(E2,fun(D,$o),aa(fun(E2,C),fun(E2,fun(D,$o)),aTP_Lamp_nu(fun(C,fun(D,$o)),fun(fun(E2,C),fun(E2,fun(D,$o))),Uu),Uua),Uub) = aa(C,fun(D,$o),Uu,aa(E2,C,Uua,Uub)) ).

% ATP.lambda_358
tff(fact_6497_ATP_Olambda__359,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: fun(D,$o),Uub: C] :
      ( aa(C,$o,aa(fun(D,$o),fun(C,$o),aTP_Lamp_mz(fun(C,D),fun(fun(D,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> aa(D,$o,Uua,aa(C,D,Uu,Uub)) ) ).

% ATP.lambda_359
tff(fact_6498_ATP_Olambda__360,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( comm_monoid_mult(E2)
     => ! [Uu: fun(C,D),Uua: fun(D,E2),Uub: C] : aa(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_rc(fun(C,D),fun(fun(D,E2),fun(C,E2)),Uu),Uua),Uub) = aa(D,E2,Uua,aa(C,D,Uu,Uub)) ) ).

% ATP.lambda_360
tff(fact_6499_ATP_Olambda__361,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( semiring_1(E2)
     => ! [Uu: fun(C,D),Uua: fun(D,E2),Uub: C] : aa(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_gu(fun(C,D),fun(fun(D,E2),fun(C,E2)),Uu),Uua),Uub) = aa(D,E2,Uua,aa(C,D,Uu,Uub)) ) ).

% ATP.lambda_361
tff(fact_6500_ATP_Olambda__362,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(E2,fun(C,E2)),Uua: E2,Uub: D] : aa(D,fun(C,E2),aa(E2,fun(D,fun(C,E2)),aTP_Lamp_ia(fun(E2,fun(C,E2)),fun(E2,fun(D,fun(C,E2))),Uu),Uua),Uub) = aa(E2,fun(C,E2),Uu,Uua) ).

% ATP.lambda_362
tff(fact_6501_ATP_Olambda__363,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,$o),Uua: C,Uub: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_sy(fun(C,$o),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> aa(C,$o,Uu,Uua) ) ).

% ATP.lambda_363
tff(fact_6502_ATP_Olambda__364,axiom,
    ! [D: $tType,E2: $tType,C: $tType,Uu: fun(C,E2),Uua: C,Uub: D] : aa(D,E2,aa(C,fun(D,E2),aTP_Lamp_lj(fun(C,E2),fun(C,fun(D,E2)),Uu),Uua),Uub) = aa(C,E2,Uu,Uua) ).

% ATP.lambda_364
tff(fact_6503_ATP_Olambda__365,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C,Uub: C] : aa(C,fun(product_prod(C,C),$o),aa(C,fun(C,fun(product_prod(C,C),$o)),aTP_Lamp_qt(set(product_prod(C,C)),fun(C,fun(C,fun(product_prod(C,C),$o))),Uu),Uua),Uub) = product_case_prod(C,C,$o,aa(C,fun(C,fun(C,$o)),aa(C,fun(C,fun(C,fun(C,$o))),aTP_Lamp_qs(set(product_prod(C,C)),fun(C,fun(C,fun(C,fun(C,$o)))),Uu),Uua),Uub)) ).

% ATP.lambda_365
tff(fact_6504_ATP_Olambda__366,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(C,fun(D,fun(E2,$o))),Uua: C,Uub: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_sz(fun(C,fun(D,fun(E2,$o))),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> ? [X_12: E2] : aa(E2,$o,aa(D,fun(E2,$o),aa(C,fun(D,fun(E2,$o)),Uu,Uua),Uub),X_12) ) ).

% ATP.lambda_366
tff(fact_6505_ATP_Olambda__367,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( condit1219197933456340205attice(E2)
     => ! [Uu: fun(C,set(D)),Uua: fun(D,E2),Uub: C] : aa(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_pn(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),Uu),Uua),Uub) = aa(set(E2),E2,complete_Sup_Sup(E2),aa(set(D),set(E2),image2(D,E2,Uua),aa(C,set(D),Uu,Uub))) ) ).

% ATP.lambda_367
tff(fact_6506_ATP_Olambda__368,axiom,
    ! [E2: $tType,D: $tType,C: $tType] :
      ( condit1219197933456340205attice(E2)
     => ! [Uu: fun(C,set(D)),Uua: fun(D,E2),Uub: C] : aa(C,E2,aa(fun(D,E2),fun(C,E2),aTP_Lamp_ps(fun(C,set(D)),fun(fun(D,E2),fun(C,E2)),Uu),Uua),Uub) = aa(set(E2),E2,complete_Inf_Inf(E2),aa(set(D),set(E2),image2(D,E2,Uua),aa(C,set(D),Uu,Uub))) ) ).

% ATP.lambda_368
tff(fact_6507_ATP_Olambda__369,axiom,
    ! [D: $tType,C: $tType] :
      ( euclid4440199948858584721cancel(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C] :
          ( aa(C,$o,aa(D,fun(C,$o),aTP_Lamp_gq(fun(C,D),fun(D,fun(C,$o)),Uu),Uua),Uub)
        <=> ~ dvd_dvd(D,Uua,aa(C,D,Uu,Uub)) ) ) ).

% ATP.lambda_369
tff(fact_6508_ATP_Olambda__370,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: D,Uub: list(D)] : aa(list(D),fun(list(C),list(C)),aa(D,fun(list(D),fun(list(C),list(C))),aTP_Lamp_oa(fun(D,C),fun(D,fun(list(D),fun(list(C),list(C)))),Uu),Uua),Uub) = aa(C,fun(list(C),list(C)),cons(C),aa(D,C,Uu,Uua)) ).

% ATP.lambda_370
tff(fact_6509_ATP_Olambda__371,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(C,fun(D,fun(E2,$o))),Uua: C,Uub: E2] :
      ( aa(E2,$o,aa(C,fun(E2,$o),aTP_Lamp_ta(fun(C,fun(D,fun(E2,$o))),fun(C,fun(E2,$o)),Uu),Uua),Uub)
    <=> ? [B5: D] : aa(E2,$o,aa(D,fun(E2,$o),aa(C,fun(D,fun(E2,$o)),Uu,Uua),B5),Uub) ) ).

% ATP.lambda_371
tff(fact_6510_ATP_Olambda__372,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(C,fun(D,fun(E2,$o))),Uua: D,Uub: E2] :
      ( aa(E2,$o,aa(D,fun(E2,$o),aTP_Lamp_tb(fun(C,fun(D,fun(E2,$o))),fun(D,fun(E2,$o)),Uu),Uua),Uub)
    <=> ? [A6: C] : aa(E2,$o,aa(D,fun(E2,$o),aa(C,fun(D,fun(E2,$o)),Uu,A6),Uua),Uub) ) ).

% ATP.lambda_372
tff(fact_6511_ATP_Olambda__373,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(C,fun(D,E2)),Uua: set(E2),Uub: C] :
      ( aa(C,$o,aa(set(E2),fun(C,$o),aTP_Lamp_ld(fun(C,fun(D,E2)),fun(set(E2),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [B5: D] : member2(E2,aa(D,E2,aa(C,fun(D,E2),Uu,Uub),B5),Uua) ) ).

% ATP.lambda_373
tff(fact_6512_ATP_Olambda__374,axiom,
    ! [C: $tType,D: $tType,Uu: list(C),Uua: list(D),Uub: product_prod(C,D)] :
      ( aa(product_prod(C,D),$o,aa(list(D),fun(product_prod(C,D),$o),aTP_Lamp_iz(list(C),fun(list(D),fun(product_prod(C,D),$o)),Uu),Uua),Uub)
    <=> ? [I2: nat] :
          ( ( Uub = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(nat,C,nth(C,Uu),I2)),aa(nat,D,nth(D,Uua),I2)) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(nat,nat,aa(nat,fun(nat,nat),ord_min(nat),aa(list(C),nat,size_size(list(C)),Uu)),aa(list(D),nat,size_size(list(D)),Uua))) ) ) ).

% ATP.lambda_374
tff(fact_6513_ATP_Olambda__375,axiom,
    ! [C: $tType,Uu: list(C),Uua: set(nat),Uub: C] :
      ( aa(C,$o,aa(set(nat),fun(C,$o),aTP_Lamp_ki(list(C),fun(set(nat),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [I2: nat] :
          ( ( Uub = aa(nat,C,nth(C,Uu),I2) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Uu))
          & member2(nat,I2,Uua) ) ) ).

% ATP.lambda_375
tff(fact_6514_ATP_Olambda__376,axiom,
    ! [C: $tType,Uu: nat,Uua: list(C),Uub: C] :
      ( aa(C,$o,aa(list(C),fun(C,$o),aTP_Lamp_jr(nat,fun(list(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [I2: nat] :
          ( ( Uub = aa(nat,C,nth(C,Uua),I2) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Uu),I2)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),Uua)) ) ) ).

% ATP.lambda_376
tff(fact_6515_ATP_Olambda__377,axiom,
    ! [D: $tType,C: $tType,Uu: set(D),Uua: fun(D,set(C)),Uub: C] :
      ( aa(C,$o,aa(fun(D,set(C)),fun(C,$o),aTP_Lamp_qn(set(D),fun(fun(D,set(C)),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X4: set(C)] :
          ( member2(set(C),X4,aa(set(D),set(set(C)),image2(D,set(C),Uua),Uu))
          & member2(C,Uub,X4) ) ) ).

% ATP.lambda_377
tff(fact_6516_ATP_Olambda__378,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [Uu: set(C),Uua: C,Uub: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_jo(set(C),fun(C,fun(C,$o)),Uu),Uua),Uub)
        <=> ? [A6: C] :
              ( ( Uub = aa(C,C,aa(C,fun(C,C),sup_sup(C),Uua),A6) )
              & member2(C,A6,Uu) ) ) ) ).

% ATP.lambda_378
tff(fact_6517_ATP_Olambda__379,axiom,
    ! [C: $tType] :
      ( finite8700451911770168679attice(C)
     => ! [Uu: C,Uua: set(C),Uub: C] :
          ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_jt(C,fun(set(C),fun(C,$o)),Uu),Uua),Uub)
        <=> ? [B5: C] :
              ( ( Uub = aa(C,C,aa(C,fun(C,C),inf_inf(C),Uu),B5) )
              & member2(C,B5,Uua) ) ) ) ).

% ATP.lambda_379
tff(fact_6518_ATP_Olambda__380,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [Uu: set(C),Uua: C,Uub: C] :
          ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_jl(set(C),fun(C,fun(C,$o)),Uu),Uua),Uub)
        <=> ? [A6: C] :
              ( ( Uub = aa(C,C,aa(C,fun(C,C),inf_inf(C),Uua),A6) )
              & member2(C,A6,Uu) ) ) ) ).

% ATP.lambda_380
tff(fact_6519_ATP_Olambda__381,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,set(C)),Uua: list(D),Uub: set(C)] :
      ( aa(set(C),$o,aa(list(D),fun(set(C),$o),aTP_Lamp_jq(fun(D,set(C)),fun(list(D),fun(set(C),$o)),Uu),Uua),Uub)
    <=> ? [I2: nat] :
          ( ( Uub = aa(D,set(C),Uu,aa(nat,D,nth(D,Uua),I2)) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(D),nat,size_size(list(D)),Uua)) ) ) ).

% ATP.lambda_381
tff(fact_6520_ATP_Olambda__382,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,set(C)),Uua: list(D),Uub: set(C)] :
      ( aa(set(C),$o,aa(list(D),fun(set(C),$o),aTP_Lamp_jj(fun(D,set(C)),fun(list(D),fun(set(C),$o)),Uu),Uua),Uub)
    <=> ? [A6: D] :
          ( ( Uub = aa(D,set(C),Uu,A6) )
          & member2(D,A6,aa(list(D),set(D),set2(D),Uua)) ) ) ).

% ATP.lambda_382
tff(fact_6521_ATP_Olambda__383,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: set(D),Uub: C] :
      ( aa(C,$o,aa(set(D),fun(C,$o),aTP_Lamp_jb(fun(D,C),fun(set(D),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [L3: D] :
          ( ( Uub = aa(D,C,Uu,L3) )
          & member2(D,L3,Uua) ) ) ).

% ATP.lambda_383
tff(fact_6522_ATP_Olambda__384,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: fun(D,$o),Uub: C] :
      ( aa(C,$o,aa(fun(D,$o),fun(C,$o),aTP_Lamp_jd(fun(D,C),fun(fun(D,$o),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X4: D] :
          ( ( Uub = aa(D,C,Uu,X4) )
          & aa(D,$o,Uua,X4) ) ) ).

% ATP.lambda_384
tff(fact_6523_ATP_Olambda__385,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,option(C)),Uua: list(D),Uub: C] :
      ( aa(C,$o,aa(list(D),fun(C,$o),aTP_Lamp_on(fun(D,option(C)),fun(list(D),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X4: D] :
          ( member2(D,X4,aa(list(D),set(D),set2(D),Uua))
          & ( aa(D,option(C),Uu,X4) = aa(C,option(C),some(C),Uub) ) ) ) ).

% ATP.lambda_385
tff(fact_6524_ATP_Olambda__386,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(C,fun(D,E2)),Uua: set(E2),Uub: product_prod(C,D)] :
      ( aa(product_prod(C,D),$o,aa(set(E2),fun(product_prod(C,D),$o),aTP_Lamp_lc(fun(C,fun(D,E2)),fun(set(E2),fun(product_prod(C,D),$o)),Uu),Uua),Uub)
    <=> ? [P4: product_prod(C,D)] :
          ( ( Uub = P4 )
          & member2(E2,aa(D,E2,aa(C,fun(D,E2),Uu,aa(product_prod(C,D),C,product_fst(C,D),P4)),aa(product_prod(C,D),D,product_snd(C,D),P4)),Uua) ) ) ).

% ATP.lambda_386
tff(fact_6525_ATP_Olambda__387,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: set(C),Uub: C] :
      ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_qo(fun(C,D),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X4: C] :
          ( member2(C,X4,Uua)
          & ( aa(C,D,Uu,X4) = aa(C,D,Uu,Uub) ) ) ) ).

% ATP.lambda_387
tff(fact_6526_ATP_Olambda__388,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,option(C)),Uua: set(D),Uub: C] :
      ( aa(C,$o,aa(set(D),fun(C,$o),aTP_Lamp_qr(fun(D,option(C)),fun(set(D),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X4: D] :
          ( member2(D,X4,Uua)
          & ( aa(D,option(C),Uu,X4) = aa(C,option(C),some(C),Uub) ) ) ) ).

% ATP.lambda_388
tff(fact_6527_ATP_Olambda__389,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: set(D),Uub: C] :
      ( aa(C,$o,aa(set(D),fun(C,$o),aTP_Lamp_qm(fun(D,C),fun(set(D),fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X4: D] :
          ( member2(D,X4,Uua)
          & ( Uub = aa(D,C,Uu,X4) ) ) ) ).

% ATP.lambda_389
tff(fact_6528_ATP_Olambda__390,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: fun(D,fun(D,$o)),Uub: product_prod(C,C)] :
      ( aa(product_prod(C,C),$o,aa(fun(D,fun(D,$o)),fun(product_prod(C,C),$o),aTP_Lamp_ju(fun(D,C),fun(fun(D,fun(D,$o)),fun(product_prod(C,C),$o)),Uu),Uua),Uub)
    <=> ? [A6: D,B5: D] :
          ( ( Uub = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(D,C,Uu,A6)),aa(D,C,Uu,B5)) )
          & aa(D,$o,aa(D,fun(D,$o),Uua,A6),B5) ) ) ).

% ATP.lambda_390
tff(fact_6529_ATP_Olambda__391,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: list(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_jg(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ? [A6: C,V4: list(C)] :
          ( ( Uub = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Uua),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A6),V4)) )
          | ? [U4: list(C),Aa3: C,B5: C,Va3: list(C),W4: list(C)] :
              ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Aa3),B5),Uu)
              & ( Uua = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Aa3),Va3)) )
              & ( Uub = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),U4),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B5),W4)) ) ) ) ) ).

% ATP.lambda_391
tff(fact_6530_ATP_Olambda__392,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [Uu: set(C),Uua: set(C),Uub: C] :
          ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_jn(set(C),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
        <=> ? [A6: C,B5: C] :
              ( ( Uub = aa(C,C,aa(C,fun(C,C),sup_sup(C),A6),B5) )
              & member2(C,A6,Uu)
              & member2(C,B5,Uua) ) ) ) ).

% ATP.lambda_392
tff(fact_6531_ATP_Olambda__393,axiom,
    ! [C: $tType] :
      ( distrib_lattice(C)
     => ! [Uu: set(C),Uua: set(C),Uub: C] :
          ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_jm(set(C),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
        <=> ? [A6: C,B5: C] :
              ( ( Uub = aa(C,C,aa(C,fun(C,C),inf_inf(C),A6),B5) )
              & member2(C,A6,Uu)
              & member2(C,B5,Uua) ) ) ) ).

% ATP.lambda_393
tff(fact_6532_ATP_Olambda__394,axiom,
    ! [C: $tType,Uu: set(C),Uua: set(list(C)),Uub: list(C)] :
      ( aa(list(C),$o,aa(set(list(C)),fun(list(C),$o),aTP_Lamp_jc(set(C),fun(set(list(C)),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ? [X4: C,Xs3: list(C)] :
          ( ( Uub = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
          & member2(C,X4,Uu)
          & member2(list(C),Xs3,Uua) ) ) ).

% ATP.lambda_394
tff(fact_6533_ATP_Olambda__395,axiom,
    ! [C: $tType,Uu: filter(C),Uua: filter(C),Uub: fun(C,$o)] :
      ( aa(fun(C,$o),$o,aa(filter(C),fun(fun(C,$o),$o),aTP_Lamp_um(filter(C),fun(filter(C),fun(fun(C,$o),$o)),Uu),Uua),Uub)
    <=> ? [Q7: fun(C,$o),R8: fun(C,$o)] :
          ( eventually(C,Q7,Uu)
          & eventually(C,R8,Uua)
          & ! [X4: C] :
              ( ( aa(C,$o,Q7,X4)
                & aa(C,$o,R8,X4) )
             => aa(C,$o,Uub,X4) ) ) ) ).

% ATP.lambda_395
tff(fact_6534_ATP_Olambda__396,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: list(C),Uub: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aTP_Lamp_jf(set(product_prod(C,C)),fun(list(C),fun(list(C),$o)),Uu),Uua),Uub)
    <=> ? [Us: list(C),Z3: C,Z8: C,Vs2: list(C)] :
          ( ( Uua = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z3),Vs2)) )
          & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Z3),Z8),Uu)
          & ( Uub = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Us),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Z8),Vs2)) ) ) ) ).

% ATP.lambda_396
tff(fact_6535_ATP_Olambda__397,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,Uu: fun(D,fun(E2,fun(F4,C))),Uua: F4,Uub: D,Uuc: E2] : aa(E2,C,aa(D,fun(E2,C),aa(F4,fun(D,fun(E2,C)),aTP_Lamp_hp(fun(D,fun(E2,fun(F4,C))),fun(F4,fun(D,fun(E2,C))),Uu),Uua),Uub),Uuc) = aa(F4,C,aa(E2,fun(F4,C),aa(D,fun(E2,fun(F4,C)),Uu,Uub),Uuc),Uua) ).

% ATP.lambda_397
tff(fact_6536_ATP_Olambda__398,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: set(C),Uub: C,Uuc: D] :
      aa(D,C,aa(C,fun(D,C),aa(set(C),fun(C,fun(D,C)),aTP_Lamp_rr(fun(C,D),fun(set(C),fun(C,fun(D,C))),Uu),Uua),Uub),Uuc) = $ite(member2(D,Uuc,aa(set(C),set(D),image2(C,D,Uu),Uua)),the_inv_into(C,D,Uua,Uu,Uuc),Uub) ).

% ATP.lambda_398
tff(fact_6537_ATP_Olambda__399,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: C,Uub: D,Uuc: set(D)] :
      aa(set(D),set(D),aa(D,fun(set(D),set(D)),aa(C,fun(D,fun(set(D),set(D))),aTP_Lamp_pg(set(C),fun(C,fun(D,fun(set(D),set(D)))),Uu),Uua),Uub),Uuc) = $ite(member2(C,Uua,Uu),aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),Uub),Uuc),Uuc) ).

% ATP.lambda_399
tff(fact_6538_ATP_Olambda__400,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: nat,Uua: fun(nat,C),Uub: fun(nat,C),Uuc: nat] :
          aa(nat,C,aa(fun(nat,C),fun(nat,C),aa(fun(nat,C),fun(fun(nat,C),fun(nat,C)),aTP_Lamp_eu(nat,fun(fun(nat,C),fun(fun(nat,C),fun(nat,C))),Uu),Uua),Uub),Uuc) = $ite(
            aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),
            aa(nat,C,Uua,Uuc),
            $ite(Uuc = Uu,one_one(C),aa(nat,C,Uub,minus_minus(nat,Uuc,aa(nat,nat,suc,zero_zero(nat))))) ) ) ).

% ATP.lambda_400
tff(fact_6539_ATP_Olambda__401,axiom,
    ! [C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: nat,Uua: fun(nat,C),Uub: fun(nat,C),Uuc: nat] :
          aa(nat,C,aa(fun(nat,C),fun(nat,C),aa(fun(nat,C),fun(fun(nat,C),fun(nat,C)),aTP_Lamp_ev(nat,fun(fun(nat,C),fun(fun(nat,C),fun(nat,C))),Uu),Uua),Uub),Uuc) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),aa(nat,C,Uua,Uuc),aa(nat,C,Uub,Uuc)) ) ).

% ATP.lambda_401
tff(fact_6540_ATP_Olambda__402,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: set(C),Uub: fun(C,D),Uuc: C] :
      aa(C,D,aa(fun(C,D),fun(C,D),aa(set(C),fun(fun(C,D),fun(C,D)),aTP_Lamp_ds(fun(C,D),fun(set(C),fun(fun(C,D),fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(member2(C,Uuc,Uua),aa(C,D,Uu,Uuc),aa(C,D,Uub,Uuc)) ).

% ATP.lambda_402
tff(fact_6541_ATP_Olambda__403,axiom,
    ! [C: $tType,D: $tType,Uu: D,Uua: fun(D,C),Uub: fun(D,C),Uuc: D] :
      aa(D,C,aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),aTP_Lamp_sb(D,fun(fun(D,C),fun(fun(D,C),fun(D,C))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(D,C,Uua,Uuc),aa(D,C,Uub,Uuc)) ).

% ATP.lambda_403
tff(fact_6542_ATP_Olambda__404,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: C,Uua: fun(C,D),Uub: fun(C,D),Uuc: C] :
          aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_ef(C,fun(fun(C,D),fun(fun(C,D),fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(C,D,Uua,Uuc),aa(C,D,Uub,Uuc)) ) ).

% ATP.lambda_404
tff(fact_6543_ATP_Olambda__405,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [Uu: C,Uua: fun(C,D),Uub: fun(C,D),Uuc: C] :
          aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_gn(C,fun(fun(C,D),fun(fun(C,D),fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(C,D,Uua,Uuc),aa(C,D,Uub,Uuc)) ) ).

% ATP.lambda_405
tff(fact_6544_ATP_Olambda__406,axiom,
    ! [D: $tType,C: $tType,Uu: C,Uua: fun(D,C),Uub: set(D),Uuc: D] :
      aa(D,C,aa(set(D),fun(D,C),aa(fun(D,C),fun(set(D),fun(D,C)),aTP_Lamp_ry(C,fun(fun(D,C),fun(set(D),fun(D,C))),Uu),Uua),Uub),Uuc) = $ite(member2(D,Uuc,Uub),aa(D,C,Uua,Uuc),Uu) ).

% ATP.lambda_406
tff(fact_6545_ATP_Olambda__407,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: C,Uua: fun(C,D),Uub: D,Uuc: C] :
          aa(C,D,aa(D,fun(C,D),aa(fun(C,D),fun(D,fun(C,D)),aTP_Lamp_eo(C,fun(fun(C,D),fun(D,fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(C,D,Uua,Uuc),Uub) ) ).

% ATP.lambda_407
tff(fact_6546_ATP_Olambda__408,axiom,
    ! [D: $tType,C: $tType,Uu: C,Uua: D,Uub: fun(C,option(D)),Uuc: C] :
      aa(C,option(D),aa(fun(C,option(D)),fun(C,option(D)),aa(D,fun(fun(C,option(D)),fun(C,option(D))),aTP_Lamp_oy(C,fun(D,fun(fun(C,option(D)),fun(C,option(D)))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(D,option(D),some(D),Uua),aa(C,option(D),Uub,Uuc)) ).

% ATP.lambda_408
tff(fact_6547_ATP_Olambda__409,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,option(C)),Uua: D,Uub: C,Uuc: D] :
      aa(D,option(C),aa(C,fun(D,option(C)),aa(D,fun(C,fun(D,option(C))),aTP_Lamp_og(fun(D,option(C)),fun(D,fun(C,fun(D,option(C)))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uua,aa(C,option(C),some(C),Uub),aa(D,option(C),Uu,Uuc)) ).

% ATP.lambda_409
tff(fact_6548_ATP_Olambda__410,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: D,Uub: D,Uuc: C] :
      aa(C,D,aa(D,fun(C,D),aa(D,fun(D,fun(C,D)),aTP_Lamp_na(set(C),fun(D,fun(D,fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(member2(C,Uuc,Uu),Uua,Uub) ).

% ATP.lambda_410
tff(fact_6549_ATP_Olambda__411,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: C,Uub: list(C),Uuc: list(C)] :
      aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),aa(C,fun(list(C),fun(list(C),product_prod(list(C),list(C)))),aTP_Lamp_ne(fun(C,$o),fun(C,fun(list(C),fun(list(C),product_prod(list(C),list(C))))),Uu),Uua),Uub),Uuc) = $ite(aa(C,$o,Uu,Uua),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uub)),Uuc),aa(list(C),product_prod(list(C),list(C)),aa(list(C),fun(list(C),product_prod(list(C),list(C))),product_Pair(list(C),list(C)),Uub),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uua),Uuc))) ).

% ATP.lambda_411
tff(fact_6550_ATP_Olambda__412,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,$o),Uua: fun(D,C),Uub: fun(D,C),Uuc: D] :
      aa(D,C,aa(fun(D,C),fun(D,C),aa(fun(D,C),fun(fun(D,C),fun(D,C)),aTP_Lamp_al(fun(D,$o),fun(fun(D,C),fun(fun(D,C),fun(D,C))),Uu),Uua),Uub),Uuc) = $ite(aa(D,$o,Uu,Uuc),aa(D,C,Uua,Uuc),aa(D,C,Uub,Uuc)) ).

% ATP.lambda_412
tff(fact_6551_ATP_Olambda__413,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,$o),Uua: fun(C,option(D)),Uub: fun(C,option(D)),Uuc: C] :
      aa(C,option(D),aa(fun(C,option(D)),fun(C,option(D)),aa(fun(C,option(D)),fun(fun(C,option(D)),fun(C,option(D))),aTP_Lamp_pa(fun(C,$o),fun(fun(C,option(D)),fun(fun(C,option(D)),fun(C,option(D)))),Uu),Uua),Uub),Uuc) = $ite(aa(C,$o,Uu,Uuc),aa(C,option(D),Uua,Uuc),aa(C,option(D),Uub,Uuc)) ).

% ATP.lambda_413
tff(fact_6552_ATP_Olambda__414,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: fun(C,$o),Uua: fun(C,D),Uub: fun(C,D),Uuc: C] :
          aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_dv(fun(C,$o),fun(fun(C,D),fun(fun(C,D),fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(aa(C,$o,Uu,Uuc),aa(C,D,Uua,Uuc),aa(C,D,Uub,Uuc)) ) ).

% ATP.lambda_414
tff(fact_6553_ATP_Olambda__415,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [Uu: fun(C,$o),Uua: fun(C,D),Uub: fun(C,D),Uuc: C] :
          aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,D),fun(fun(C,D),fun(C,D)),aTP_Lamp_gm(fun(C,$o),fun(fun(C,D),fun(fun(C,D),fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(aa(C,$o,Uu,Uuc),aa(C,D,Uua,Uuc),aa(C,D,Uub,Uuc)) ) ).

% ATP.lambda_415
tff(fact_6554_ATP_Olambda__416,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,D),Uua: fun(C,$o),Uub: fun(C,D),Uuc: C] :
      aa(C,D,aa(fun(C,D),fun(C,D),aa(fun(C,$o),fun(fun(C,D),fun(C,D)),aTP_Lamp_un(fun(C,D),fun(fun(C,$o),fun(fun(C,D),fun(C,D))),Uu),Uua),Uub),Uuc) = $ite(aa(C,$o,Uua,Uuc),aa(C,D,Uu,Uuc),aa(C,D,Uub,Uuc)) ).

% ATP.lambda_416
tff(fact_6555_ATP_Olambda__417,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_semiring_0(C)
     => ! [Uu: fun(D,C),Uua: C,Uub: list(D),Uuc: nat] : aa(nat,C,aa(list(D),fun(nat,C),aa(C,fun(list(D),fun(nat,C)),aTP_Lamp_jz(fun(D,C),fun(C,fun(list(D),fun(nat,C))),Uu),Uua),Uub),Uuc) = aa(C,C,compow(fun(C,C),Uuc,aa(C,fun(C,C),times_times(C),Uua)),aa(D,C,Uu,aa(nat,D,nth(D,Uub),Uuc))) ) ).

% ATP.lambda_417
tff(fact_6556_ATP_Olambda__418,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: C,Uub: list(C),Uuc: $o] :
      ( aa($o,$o,aa(list(C),fun($o,$o),aa(C,fun(list(C),fun($o,$o)),aTP_Lamp_rb(fun(C,fun(C,$o)),fun(C,fun(list(C),fun($o,$o))),Uu),Uua),Uub),(Uuc))
    <=> aa(list(C),$o,aa(fun(C,fun(list(C),$o)),fun(list(C),$o),aa($o,fun(fun(C,fun(list(C),$o)),fun(list(C),$o)),case_list($o,C),$true),aa($o,fun(C,fun(list(C),$o)),aa(C,fun($o,fun(C,fun(list(C),$o))),aTP_Lamp_ra(fun(C,fun(C,$o)),fun(C,fun($o,fun(C,fun(list(C),$o)))),Uu),Uua),(Uuc))),Uub) ) ).

% ATP.lambda_418
tff(fact_6557_ATP_Olambda__419,axiom,
    ! [D: $tType,E2: $tType,C: $tType,Uu: fun(E2,fun(list(E2),fun(D,D))),Uua: fun(C,E2),Uub: C,Uuc: list(C)] : aa(list(C),fun(D,D),aa(C,fun(list(C),fun(D,D)),aa(fun(C,E2),fun(C,fun(list(C),fun(D,D))),aTP_Lamp_oc(fun(E2,fun(list(E2),fun(D,D))),fun(fun(C,E2),fun(C,fun(list(C),fun(D,D)))),Uu),Uua),Uub),Uuc) = aa(list(E2),fun(D,D),aa(E2,fun(list(E2),fun(D,D)),Uu,aa(C,E2,Uua,Uub)),aa(list(C),list(E2),aa(fun(C,E2),fun(list(C),list(E2)),map(C,E2),Uua),Uuc)) ).

% ATP.lambda_419
tff(fact_6558_ATP_Olambda__420,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(C,$o)),Uua: fun(D,C),Uub: D,Uuc: D] :
      ( aa(D,$o,aa(D,fun(D,$o),aa(fun(D,C),fun(D,fun(D,$o)),aTP_Lamp_bb(fun(C,fun(C,$o)),fun(fun(D,C),fun(D,fun(D,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(C,$o,aa(C,fun(C,$o),Uu,aa(D,C,Uua,Uub)),aa(D,C,Uua,Uuc)) ) ).

% ATP.lambda_420
tff(fact_6559_ATP_Olambda__421,axiom,
    ! [D: $tType,C: $tType,E2: $tType,F4: $tType,Uu: fun(D,fun(E2,C)),Uua: fun(F4,D),Uub: fun(F4,E2),Uuc: F4] : aa(F4,C,aa(fun(F4,E2),fun(F4,C),aa(fun(F4,D),fun(fun(F4,E2),fun(F4,C)),aTP_Lamp_ht(fun(D,fun(E2,C)),fun(fun(F4,D),fun(fun(F4,E2),fun(F4,C))),Uu),Uua),Uub),Uuc) = aa(E2,C,aa(D,fun(E2,C),Uu,aa(F4,D,Uua,Uuc)),aa(F4,E2,Uub,Uuc)) ).

% ATP.lambda_421
tff(fact_6560_ATP_Olambda__422,axiom,
    ! [C: $tType,E2: $tType,D: $tType,F4: $tType] :
      ( ( order(E2)
        & order(C) )
     => ! [Uu: fun(C,fun(D,E2)),Uua: fun(F4,D),Uub: C,Uuc: F4] : aa(F4,E2,aa(C,fun(F4,E2),aa(fun(F4,D),fun(C,fun(F4,E2)),aTP_Lamp_mv(fun(C,fun(D,E2)),fun(fun(F4,D),fun(C,fun(F4,E2))),Uu),Uua),Uub),Uuc) = aa(D,E2,aa(C,fun(D,E2),Uu,Uub),aa(F4,D,Uua,Uuc)) ) ).

% ATP.lambda_422
tff(fact_6561_ATP_Olambda__423,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(C,fun(D,$o)),Uua: fun(E2,D),Uub: C,Uuc: E2] :
      ( aa(E2,$o,aa(C,fun(E2,$o),aa(fun(E2,D),fun(C,fun(E2,$o)),aTP_Lamp_nt(fun(C,fun(D,$o)),fun(fun(E2,D),fun(C,fun(E2,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(D,$o,aa(C,fun(D,$o),Uu,Uub),aa(E2,D,Uua,Uuc)) ) ).

% ATP.lambda_423
tff(fact_6562_ATP_Olambda__424,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(C,fun(D,C)),Uua: fun(E2,D),Uub: C,Uuc: E2] : aa(E2,C,aa(C,fun(E2,C),aa(fun(E2,D),fun(C,fun(E2,C)),aTP_Lamp_bj(fun(C,fun(D,C)),fun(fun(E2,D),fun(C,fun(E2,C))),Uu),Uua),Uub),Uuc) = aa(D,C,aa(C,fun(D,C),Uu,Uub),aa(E2,D,Uua,Uuc)) ).

% ATP.lambda_424
tff(fact_6563_ATP_Olambda__425,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( semiring_0(C)
     => ! [Uu: fun(D,C),Uua: fun(E2,C),Uub: set(E2),Uuc: D] : aa(D,C,aa(set(E2),fun(D,C),aa(fun(E2,C),fun(set(E2),fun(D,C)),aTP_Lamp_gh(fun(D,C),fun(fun(E2,C),fun(set(E2),fun(D,C))),Uu),Uua),Uub),Uuc) = aa(set(E2),C,aa(fun(E2,C),fun(set(E2),C),groups7311177749621191930dd_sum(E2,C),aa(D,fun(E2,C),aa(fun(E2,C),fun(D,fun(E2,C)),aTP_Lamp_gg(fun(D,C),fun(fun(E2,C),fun(D,fun(E2,C))),Uu),Uua),Uuc)),Uub) ) ).

% ATP.lambda_425
tff(fact_6564_ATP_Olambda__426,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: list(C),Uub: C,Uuc: C] :
          aa(C,fun(list(C),list(C)),aa(C,fun(C,fun(list(C),list(C))),aa(list(C),fun(C,fun(C,fun(list(C),list(C)))),aTP_Lamp_ir(fun(C,D),fun(list(C),fun(C,fun(C,fun(list(C),list(C))))),Uu),Uua),Uub),Uuc) = aa(fun(C,fun(list(C),list(C))),fun(list(C),list(C)),
            aa(list(C),fun(fun(C,fun(list(C),list(C))),fun(list(C),list(C))),case_list(list(C),C),
              $ite(aa(D,$o,aa(D,fun(D,$o),ord_less_eq(D),aa(C,D,Uu,Uub)),aa(C,D,Uu,Uuc)),Uua,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uuc),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uub),nil(C))))),
            aa(list(C),fun(C,fun(list(C),list(C))),aTP_Lamp_iq(fun(C,D),fun(list(C),fun(C,fun(list(C),list(C)))),Uu),Uua)) ) ).

% ATP.lambda_426
tff(fact_6565_ATP_Olambda__427,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(D,$o)),Uua: fun(C,fun(D,$o)),Uub: C,Uuc: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(C,fun(D,$o)),fun(C,fun(D,$o)),aTP_Lamp_sw(fun(C,fun(D,$o)),fun(fun(C,fun(D,$o)),fun(C,fun(D,$o))),Uu),Uua),Uub),Uuc)
    <=> ( aa(D,$o,aa(C,fun(D,$o),Uu,Uub),Uuc)
        & aa(D,$o,aa(C,fun(D,$o),Uua,Uub),Uuc) ) ) ).

% ATP.lambda_427
tff(fact_6566_ATP_Olambda__428,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,fun(D,assn)),Uua: $o,Uub: C,Uuc: D] : aa(D,assn,aa(C,fun(D,assn),aa($o,fun(C,fun(D,assn)),aTP_Lamp_kg(fun(C,fun(D,assn)),fun($o,fun(C,fun(D,assn))),Uu),(Uua)),Uub),Uuc) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(D,assn,aa(C,fun(D,assn),Uu,Uub),Uuc)),pure_assn((Uua))) ).

% ATP.lambda_428
tff(fact_6567_ATP_Olambda__429,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: set(C),Uub: C,Uuc: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aa(set(C),fun(C,fun(C,$o)),aTP_Lamp_nn(set(product_prod(C,C)),fun(set(C),fun(C,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uub),Uuc),Uu)
        & ~ member2(C,Uub,Uua)
        & ~ member2(C,Uuc,Uua) ) ) ).

% ATP.lambda_429
tff(fact_6568_ATP_Olambda__430,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,option(D)),Uua: fun(product_prod(C,D),$o),Uub: C,Uuc: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aa(fun(product_prod(C,D),$o),fun(C,fun(D,$o)),aTP_Lamp_ok(fun(C,option(D)),fun(fun(product_prod(C,D),$o),fun(C,fun(D,$o))),Uu),Uua),Uub),Uuc)
    <=> ( ( aa(C,option(D),Uu,Uub) = aa(D,option(D),some(D),Uuc) )
        & aa(product_prod(C,D),$o,Uua,aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uub),Uuc)) ) ) ).

% ATP.lambda_430
tff(fact_6569_ATP_Olambda__431,axiom,
    ! [C: $tType] :
      ( comm_ring_1(C)
     => ! [Uu: C,Uua: C,Uub: nat,Uuc: nat] : aa(nat,C,aa(nat,fun(nat,C),aa(C,fun(nat,fun(nat,C)),aTP_Lamp_hc(C,fun(C,fun(nat,fun(nat,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),binomial(Uub,Uuc))),comm_s3205402744901411588hammer(C,Uu,Uuc))),comm_s3205402744901411588hammer(C,Uua,minus_minus(nat,Uub,Uuc))) ) ).

% ATP.lambda_431
tff(fact_6570_ATP_Olambda__432,axiom,
    ! [C: $tType] :
      ( comm_semiring_1(C)
     => ! [Uu: C,Uua: C,Uub: nat,Uuc: nat] : aa(nat,C,aa(nat,fun(nat,C),aa(C,fun(nat,fun(nat,C)),aTP_Lamp_hb(C,fun(C,fun(nat,fun(nat,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,semiring_1_of_nat(C),binomial(Uub,Uuc))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uu),Uuc))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uua),minus_minus(nat,Uub,Uuc))) ) ).

% ATP.lambda_432
tff(fact_6571_ATP_Olambda__433,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: nat,Uub: list(C),Uuc: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(nat,fun(list(C),fun(list(C),$o)),aTP_Lamp_js(set(product_prod(C,C)),fun(nat,fun(list(C),fun(list(C),$o))),Uu),Uua),Uub),Uuc)
    <=> ( ( aa(list(C),nat,size_size(list(C)),Uub) = Uua )
        & ( aa(list(C),nat,size_size(list(C)),Uuc) = Uua )
        & ? [Xys2: list(C),X4: C,Y3: C,Xs5: list(C),Ys5: list(C)] :
            ( ( Uub = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs5)) )
            & ( Uuc = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xys2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys5)) )
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),X4),Y3),Uu) ) ) ) ).

% ATP.lambda_433
tff(fact_6572_ATP_Olambda__434,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [Uu: C,Uua: nat,Uub: C,Uuc: nat] : aa(nat,C,aa(C,fun(nat,C),aa(nat,fun(C,fun(nat,C)),aTP_Lamp_gx(C,fun(nat,fun(C,fun(nat,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uub),minus_minus(nat,Uua,aa(nat,nat,suc,Uuc)))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uu),Uuc)) ) ).

% ATP.lambda_434
tff(fact_6573_ATP_Olambda__435,axiom,
    ! [D: $tType,C: $tType,Uu: fun(D,C),Uua: set(D),Uub: fun(C,$o),Uuc: C] :
      ( aa(C,$o,aa(fun(C,$o),fun(C,$o),aa(set(D),fun(fun(C,$o),fun(C,$o)),aTP_Lamp_bd(fun(D,C),fun(set(D),fun(fun(C,$o),fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member2(C,Uuc,aa(set(D),set(C),image2(D,C,Uu),Uua))
        & aa(C,$o,Uub,Uuc) ) ) ).

% ATP.lambda_435
tff(fact_6574_ATP_Olambda__436,axiom,
    ! [C: $tType,D: $tType,Uu: set(C),Uua: fun(C,D),Uub: D,Uuc: C] :
      ( aa(C,$o,aa(D,fun(C,$o),aa(fun(C,D),fun(D,fun(C,$o)),aTP_Lamp_gv(set(C),fun(fun(C,D),fun(D,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member2(C,Uuc,Uu)
        & ( aa(C,D,Uua,Uuc) = Uub ) ) ) ).

% ATP.lambda_436
tff(fact_6575_ATP_Olambda__437,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,D),Uua: set(C),Uub: D,Uuc: C] :
      ( aa(C,$o,aa(D,fun(C,$o),aa(set(C),fun(D,fun(C,$o)),aTP_Lamp_nh(fun(C,D),fun(set(C),fun(D,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member2(C,Uuc,Uua)
        & ( aa(C,D,Uu,Uuc) = Uub ) ) ) ).

% ATP.lambda_437
tff(fact_6576_ATP_Olambda__438,axiom,
    ! [C: $tType] :
      ( ( monoid_mult(C)
        & comm_ring(C) )
     => ! [Uu: C,Uua: nat,Uub: C,Uuc: nat] : aa(nat,C,aa(C,fun(nat,C),aa(nat,fun(C,fun(nat,C)),aTP_Lamp_gy(C,fun(nat,fun(C,fun(nat,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uu),Uuc)),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uub),minus_minus(nat,Uua,Uuc))) ) ).

% ATP.lambda_438
tff(fact_6577_ATP_Olambda__439,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: list(C),Uub: list(C),Uuc: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(list(C),fun(list(C),fun(list(C),list(C))),aTP_Lamp_io(fun(C,D),fun(list(C),fun(list(C),fun(list(C),list(C)))),Uu),Uua),Uub),Uuc) = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),Uu),Uua)),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Uub),aa(list(C),list(C),aa(fun(C,D),fun(list(C),list(C)),linorder_sort_key(C,D),Uu),Uuc))) ) ).

% ATP.lambda_439
tff(fact_6578_ATP_Olambda__440,axiom,
    ! [C: $tType,D: $tType,Uu: C,Uua: list(C),Uub: D,Uuc: list(D)] : aa(list(D),list(product_prod(C,D)),aa(D,fun(list(D),list(product_prod(C,D))),aa(list(C),fun(D,fun(list(D),list(product_prod(C,D)))),aTP_Lamp_ea(C,fun(list(C),fun(D,fun(list(D),list(product_prod(C,D))))),Uu),Uua),Uub),Uuc) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uu),Uub)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Uua),Uuc)) ).

% ATP.lambda_440
tff(fact_6579_ATP_Olambda__441,axiom,
    ! [C: $tType,D: $tType,Uu: D,Uua: list(D),Uub: C,Uuc: list(C)] : aa(list(C),list(product_prod(C,D)),aa(C,fun(list(C),list(product_prod(C,D))),aa(list(D),fun(C,fun(list(C),list(product_prod(C,D)))),aTP_Lamp_eb(D,fun(list(D),fun(C,fun(list(C),list(product_prod(C,D))))),Uu),Uua),Uub),Uuc) = aa(list(product_prod(C,D)),list(product_prod(C,D)),aa(product_prod(C,D),fun(list(product_prod(C,D)),list(product_prod(C,D))),cons(product_prod(C,D)),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uub),Uu)),aa(list(D),list(product_prod(C,D)),aa(list(C),fun(list(D),list(product_prod(C,D))),zip(C,D),Uuc),Uua)) ).

% ATP.lambda_441
tff(fact_6580_ATP_Olambda__442,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: set(D),Uub: fun(C,$o),Uuc: D] :
      ( aa(D,$o,aa(fun(C,$o),fun(D,$o),aa(set(D),fun(fun(C,$o),fun(D,$o)),aTP_Lamp_be(fun(D,C),fun(set(D),fun(fun(C,$o),fun(D,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member2(D,Uuc,Uua)
        & aa(C,$o,Uub,aa(D,C,Uu,Uuc)) ) ) ).

% ATP.lambda_442
tff(fact_6581_ATP_Olambda__443,axiom,
    ! [C: $tType,D: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: set(C),Uua: fun(C,D),Uub: fun(C,D),Uuc: C] :
          ( aa(C,$o,aa(fun(C,D),fun(C,$o),aa(fun(C,D),fun(fun(C,D),fun(C,$o)),aTP_Lamp_ci(set(C),fun(fun(C,D),fun(fun(C,D),fun(C,$o))),Uu),Uua),Uub),Uuc)
        <=> ( member2(C,Uuc,Uu)
            & ( aa(D,D,aa(D,fun(D,D),times_times(D),aa(C,D,Uua,Uuc)),aa(C,D,Uub,Uuc)) != one_one(D) ) ) ) ) ).

% ATP.lambda_443
tff(fact_6582_ATP_Olambda__444,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: nat,Uua: list(C),Uub: array(C),Uuc: C] : aa(C,assn,aa(array(C),fun(C,assn),aa(list(C),fun(array(C),fun(C,assn)),aTP_Lamp_te(nat,fun(list(C),fun(array(C),fun(C,assn))),Uu),Uua),Uub),Uuc) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),snga_assn(C,Uub,Uua)),pure_assn(Uuc = aa(nat,C,nth(C,Uua),Uu))) ) ).

% ATP.lambda_444
tff(fact_6583_ATP_Olambda__445,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_semiring_1(C)
     => ! [Uu: fun(D,C),Uua: C,Uub: list(D),Uuc: nat] : aa(nat,C,aa(list(D),fun(nat,C),aa(C,fun(list(D),fun(nat,C)),aTP_Lamp_hd(fun(D,C),fun(C,fun(list(D),fun(nat,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(D,C,Uu,aa(nat,D,nth(D,Uub),Uuc))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uua),Uuc)) ) ).

% ATP.lambda_445
tff(fact_6584_ATP_Olambda__446,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_semiring_0(C)
     => ! [Uu: fun(D,C),Uua: C,Uub: D,Uuc: C] : aa(C,C,aa(D,fun(C,C),aa(C,fun(D,fun(C,C)),aTP_Lamp_dy(fun(D,C),fun(C,fun(D,fun(C,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(D,C,Uu,Uub)),aa(C,C,aa(C,fun(C,C),times_times(C),Uua),Uuc)) ) ).

% ATP.lambda_446
tff(fact_6585_ATP_Olambda__447,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( ( semiring_0(C)
        & comm_monoid_add(D)
        & times(D) )
     => ! [Uu: fun(D,C),Uua: fun(E2,C),Uub: D,Uuc: E2] : aa(E2,C,aa(D,fun(E2,C),aa(fun(E2,C),fun(D,fun(E2,C)),aTP_Lamp_rf(fun(D,C),fun(fun(E2,C),fun(D,fun(E2,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(D,C,Uu,Uub)),aa(E2,C,Uua,Uuc)) ) ).

% ATP.lambda_447
tff(fact_6586_ATP_Olambda__448,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( semiring_0(C)
     => ! [Uu: fun(D,C),Uua: fun(E2,C),Uub: D,Uuc: E2] : aa(E2,C,aa(D,fun(E2,C),aa(fun(E2,C),fun(D,fun(E2,C)),aTP_Lamp_gg(fun(D,C),fun(fun(E2,C),fun(D,fun(E2,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(D,C,Uu,Uub)),aa(E2,C,Uua,Uuc)) ) ).

% ATP.lambda_448
tff(fact_6587_ATP_Olambda__449,axiom,
    ! [C: $tType,E2: $tType,D: $tType] :
      ( semiring_0(E2)
     => ! [Uu: fun(C,E2),Uua: fun(D,E2),Uub: C,Uuc: D] : aa(D,E2,aa(C,fun(D,E2),aa(fun(D,E2),fun(C,fun(D,E2)),aTP_Lamp_nk(fun(C,E2),fun(fun(D,E2),fun(C,fun(D,E2))),Uu),Uua),Uub),Uuc) = aa(E2,E2,aa(E2,fun(E2,E2),times_times(E2),aa(C,E2,Uu,Uub)),aa(D,E2,Uua,Uuc)) ) ).

% ATP.lambda_449
tff(fact_6588_ATP_Olambda__450,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(D,set(C)),Uua: fun(E2,set(C)),Uub: D,Uuc: E2] : aa(E2,set(C),aa(D,fun(E2,set(C)),aa(fun(E2,set(C)),fun(D,fun(E2,set(C))),aTP_Lamp_cw(fun(D,set(C)),fun(fun(E2,set(C)),fun(D,fun(E2,set(C)))),Uu),Uua),Uub),Uuc) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),inf_inf(set(C)),aa(D,set(C),Uu,Uub)),aa(E2,set(C),Uua,Uuc)) ).

% ATP.lambda_450
tff(fact_6589_ATP_Olambda__451,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( comple592849572758109894attice(C)
     => ! [Uu: fun(D,C),Uua: fun(E2,C),Uub: D,Uuc: E2] : aa(E2,C,aa(D,fun(E2,C),aa(fun(E2,C),fun(D,fun(E2,C)),aTP_Lamp_cm(fun(D,C),fun(fun(E2,C),fun(D,fun(E2,C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),inf_inf(C),aa(D,C,Uu,Uub)),aa(E2,C,Uua,Uuc)) ) ).

% ATP.lambda_451
tff(fact_6590_ATP_Olambda__452,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,Uu: fun(C,filter(E2)),Uua: fun(D,filter(F4)),Uub: C,Uuc: D] : aa(D,filter(product_prod(E2,F4)),aa(C,fun(D,filter(product_prod(E2,F4))),aa(fun(D,filter(F4)),fun(C,fun(D,filter(product_prod(E2,F4)))),aTP_Lamp_uo(fun(C,filter(E2)),fun(fun(D,filter(F4)),fun(C,fun(D,filter(product_prod(E2,F4))))),Uu),Uua),Uub),Uuc) = prod_filter(E2,F4,aa(C,filter(E2),Uu,Uub),aa(D,filter(F4),Uua,Uuc)) ).

% ATP.lambda_452
tff(fact_6591_ATP_Olambda__453,axiom,
    ! [E2: $tType,C: $tType,D: $tType,F4: $tType,Uu: fun(E2,C),Uua: fun(F4,D),Uub: E2,Uuc: F4] : aa(F4,product_prod(C,D),aa(E2,fun(F4,product_prod(C,D)),aa(fun(F4,D),fun(E2,fun(F4,product_prod(C,D))),aTP_Lamp_hw(fun(E2,C),fun(fun(F4,D),fun(E2,fun(F4,product_prod(C,D)))),Uu),Uua),Uub),Uuc) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(E2,C,Uu,Uub)),aa(F4,D,Uua,Uuc)) ).

% ATP.lambda_453
tff(fact_6592_ATP_Olambda__454,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(C)
     => ! [Uu: fun(D,C),Uua: fun(list(D),C),Uub: list(D),Uuc: D] :
          ( aa(D,$o,aa(list(D),fun(D,$o),aa(fun(list(D),C),fun(list(D),fun(D,$o)),aTP_Lamp_fk(fun(D,C),fun(fun(list(D),C),fun(list(D),fun(D,$o))),Uu),Uua),Uub),Uuc)
        <=> ( aa(D,C,Uu,Uuc) = aa(list(D),C,Uua,Uub) ) ) ) ).

% ATP.lambda_454
tff(fact_6593_ATP_Olambda__455,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: list(C),Uub: C,Uuc: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),aa(list(C),fun(C,fun(list(C),list(C))),aTP_Lamp_iq(fun(C,D),fun(list(C),fun(C,fun(list(C),list(C)))),Uu),Uua),Uub),Uuc) = aa(product_prod(list(C),product_prod(list(C),list(C))),list(C),product_case_prod(list(C),product_prod(list(C),list(C)),list(C),aTP_Lamp_ip(fun(C,D),fun(list(C),fun(product_prod(list(C),list(C)),list(C))),Uu)),linorder_part(C,D,Uu,aa(C,D,Uu,aa(nat,C,nth(C,Uua),divide_divide(nat,aa(list(C),nat,size_size(list(C)),Uua),aa(num,nat,numeral_numeral(nat),bit0(one2))))),Uua)) ) ).

% ATP.lambda_455
tff(fact_6594_ATP_Olambda__456,axiom,
    ! [C: $tType,D: $tType,Uu: fun(C,fun(C,$o)),Uua: fun(D,C),Uub: D,Uuc: D] :
      ( aa(D,$o,aa(D,fun(D,$o),aa(fun(D,C),fun(D,fun(D,$o)),aTP_Lamp_rn(fun(C,fun(C,$o)),fun(fun(D,C),fun(D,fun(D,$o))),Uu),Uua),Uub),Uuc)
    <=> ( ( aa(D,C,Uua,Uub) != aa(D,C,Uua,Uuc) )
       => aa(C,$o,aa(C,fun(C,$o),Uu,aa(D,C,Uua,Uub)),aa(D,C,Uua,Uuc)) ) ) ).

% ATP.lambda_456
tff(fact_6595_ATP_Olambda__457,axiom,
    ! [C: $tType,E2: $tType,D: $tType] :
      ( semiring_1(E2)
     => ! [Uu: set(C),Uua: fun(C,D),Uub: fun(D,E2),Uuc: D] : aa(D,E2,aa(fun(D,E2),fun(D,E2),aa(fun(C,D),fun(fun(D,E2),fun(D,E2)),aTP_Lamp_gw(set(C),fun(fun(C,D),fun(fun(D,E2),fun(D,E2))),Uu),Uua),Uub),Uuc) = aa(E2,E2,aa(E2,fun(E2,E2),times_times(E2),aa(nat,E2,semiring_1_of_nat(E2),finite_card(C,collect(C,aa(D,fun(C,$o),aa(fun(C,D),fun(D,fun(C,$o)),aTP_Lamp_gv(set(C),fun(fun(C,D),fun(D,fun(C,$o))),Uu),Uua),Uuc))))),aa(D,E2,Uub,Uuc)) ) ).

% ATP.lambda_457
tff(fact_6596_ATP_Olambda__458,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: fun(list(C),fun(list(C),$o)),Uub: list(C),Uuc: list(C)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o)),aTP_Lamp_ka(fun(C,fun(C,$o)),fun(fun(list(C),fun(list(C),$o)),fun(list(C),fun(list(C),$o))),Uu),Uua),Uub),Uuc)
    <=> ( ? [Y3: C,Ys3: list(C)] :
            ( ( Uub = nil(C) )
            & ( Uuc = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) ) )
        | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
            ( ( Uub = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( Uuc = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
            & aa(C,$o,aa(C,fun(C,$o),Uu,X4),Y3) )
        | ? [X4: C,Y3: C,Xs3: list(C),Ys3: list(C)] :
            ( ( Uub = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X4),Xs3) )
            & ( Uuc = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys3) )
            & ~ aa(C,$o,aa(C,fun(C,$o),Uu,X4),Y3)
            & ~ aa(C,$o,aa(C,fun(C,$o),Uu,Y3),X4)
            & aa(list(C),$o,aa(list(C),fun(list(C),$o),Uua,Xs3),Ys3) ) ) ) ).

% ATP.lambda_458
tff(fact_6597_ATP_Olambda__459,axiom,
    ! [C: $tType,D: $tType,Uu: $o,Uua: fun(C,fun(D,assn)),Uub: C,Uuc: D] : aa(D,assn,aa(C,fun(D,assn),aa(fun(C,fun(D,assn)),fun(C,fun(D,assn)),aTP_Lamp_kh($o,fun(fun(C,fun(D,assn)),fun(C,fun(D,assn))),(Uu)),Uua),Uub),Uuc) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),pure_assn((Uu))),aa(D,assn,aa(C,fun(D,assn),Uua,Uub),Uuc)) ).

% ATP.lambda_459
tff(fact_6598_ATP_Olambda__460,axiom,
    ! [C: $tType,Uu: C,Uua: list(C),Uub: C,Uuc: nat] : aa(nat,list(C),aa(C,fun(nat,list(C)),aa(list(C),fun(C,fun(nat,list(C))),aTP_Lamp_pz(C,fun(list(C),fun(C,fun(nat,list(C)))),Uu),Uua),Uub),Uuc) = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Uua),Uuc),Uub)) ).

% ATP.lambda_460
tff(fact_6599_ATP_Olambda__461,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(E2,C),Uua: fun(E2,D),Uub: set(E2),Uuc: C] : aa(C,set(D),aa(set(E2),fun(C,set(D)),aa(fun(E2,D),fun(set(E2),fun(C,set(D))),aTP_Lamp_my(fun(E2,C),fun(fun(E2,D),fun(set(E2),fun(C,set(D)))),Uu),Uua),Uub),Uuc) = aa(set(E2),set(D),image2(E2,D,Uua),aa(set(E2),set(E2),aa(set(E2),fun(set(E2),set(E2)),inf_inf(set(E2)),aa(set(C),set(E2),aa(fun(E2,C),fun(set(C),set(E2)),vimage(E2,C),Uu),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uuc),bot_bot(set(C))))),Uub)) ).

% ATP.lambda_461
tff(fact_6600_ATP_Olambda__462,axiom,
    ! [C: $tType,Uu: list(C),Uua: list(C),Uub: C,Uuc: list(C)] : aa(list(C),option($o),aa(C,fun(list(C),option($o)),aa(list(C),fun(C,fun(list(C),option($o))),aTP_Lamp_ov(list(C),fun(list(C),fun(C,fun(list(C),option($o)))),Uu),Uua),Uub),Uuc) = subset_eq_mset_impl(C,Uu,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Uua),Uuc)) ).

% ATP.lambda_462
tff(fact_6601_ATP_Olambda__463,axiom,
    ! [C: $tType] :
      ( ord(C)
     => ! [Uu: C,Uua: list(C),Uub: C,Uuc: list(C)] : aa(list(C),C,aa(C,fun(list(C),C),aa(list(C),fun(C,fun(list(C),C)),aTP_Lamp_dp(C,fun(list(C),fun(C,fun(list(C),C))),Uu),Uua),Uub),Uuc) = aa(C,C,aa(C,fun(C,C),ord_min(C),Uu),min_list(C,Uua)) ) ).

% ATP.lambda_463
tff(fact_6602_ATP_Olambda__464,axiom,
    ! [C: $tType,D: $tType,E2: $tType,Uu: fun(D,C),Uua: fun(E2,fun(list(E2),D)),Uub: E2,Uuc: list(E2)] : aa(list(E2),C,aa(E2,fun(list(E2),C),aa(fun(E2,fun(list(E2),D)),fun(E2,fun(list(E2),C)),aTP_Lamp_br(fun(D,C),fun(fun(E2,fun(list(E2),D)),fun(E2,fun(list(E2),C))),Uu),Uua),Uub),Uuc) = aa(D,C,Uu,aa(list(E2),D,aa(E2,fun(list(E2),D),Uua,Uub),Uuc)) ).

% ATP.lambda_464
tff(fact_6603_ATP_Olambda__465,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: nat,Uub: list(C),Uuc: nat] :
      ( aa(nat,$o,aa(list(C),fun(nat,$o),aa(nat,fun(list(C),fun(nat,$o)),aTP_Lamp_gk(fun(C,$o),fun(nat,fun(list(C),fun(nat,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(C,$o,Uu,aa(nat,C,nth(C,aa(list(C),list(C),aa(nat,fun(list(C),list(C)),take(C),Uua),Uub)),Uuc)) ) ).

% ATP.lambda_465
tff(fact_6604_ATP_Olambda__466,axiom,
    ! [C: $tType,F4: $tType,D: $tType,E2: $tType,Uu: fun(product_prod(D,E2),C),Uua: fun(F4,D),Uub: F4,Uuc: E2] : aa(E2,C,aa(F4,fun(E2,C),aa(fun(F4,D),fun(F4,fun(E2,C)),aTP_Lamp_hx(fun(product_prod(D,E2),C),fun(fun(F4,D),fun(F4,fun(E2,C))),Uu),Uua),Uub),Uuc) = aa(product_prod(D,E2),C,Uu,aa(E2,product_prod(D,E2),aa(D,fun(E2,product_prod(D,E2)),product_Pair(D,E2),aa(F4,D,Uua,Uub)),Uuc)) ).

% ATP.lambda_466
tff(fact_6605_ATP_Olambda__467,axiom,
    ! [C: $tType,D: $tType,E2: $tType,F4: $tType,Uu: fun(product_prod(D,E2),C),Uua: fun(F4,E2),Uub: D,Uuc: F4] : aa(F4,C,aa(D,fun(F4,C),aa(fun(F4,E2),fun(D,fun(F4,C)),aTP_Lamp_hy(fun(product_prod(D,E2),C),fun(fun(F4,E2),fun(D,fun(F4,C))),Uu),Uua),Uub),Uuc) = aa(product_prod(D,E2),C,Uu,aa(E2,product_prod(D,E2),aa(D,fun(E2,product_prod(D,E2)),product_Pair(D,E2),Uub),aa(F4,E2,Uua,Uuc))) ).

% ATP.lambda_467
tff(fact_6606_ATP_Olambda__468,axiom,
    ! [E2: $tType,C: $tType,D: $tType,Uu: fun(E2,fun(D,C)),Uua: fun(E2,E2),Uub: fun(fun(D,C),E2),Uuc: fun(D,C)] : aa(fun(D,C),fun(D,C),aa(fun(fun(D,C),E2),fun(fun(D,C),fun(D,C)),aa(fun(E2,E2),fun(fun(fun(D,C),E2),fun(fun(D,C),fun(D,C))),aTP_Lamp_uh(fun(E2,fun(D,C)),fun(fun(E2,E2),fun(fun(fun(D,C),E2),fun(fun(D,C),fun(D,C)))),Uu),Uua),Uub),Uuc) = aa(E2,fun(D,C),Uu,aa(E2,E2,Uua,aa(fun(D,C),E2,Uub,Uuc))) ).

% ATP.lambda_468
tff(fact_6607_ATP_Olambda__469,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(D)
     => ! [Uu: fun(C,D),Uua: D,Uub: C,Uuc: list(C)] : aa(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C)))),aa(C,fun(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C))))),aa(D,fun(C,fun(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C)))))),aTP_Lamp_ix(fun(C,D),fun(D,fun(C,fun(list(C),fun(product_prod(list(C),list(C)),product_prod(list(C),product_prod(list(C),list(C))))))),Uu),Uua),Uub),Uuc) = product_case_prod(list(C),list(C),product_prod(list(C),product_prod(list(C),list(C))),aa(list(C),fun(list(C),fun(list(C),product_prod(list(C),product_prod(list(C),list(C))))),aa(C,fun(list(C),fun(list(C),fun(list(C),product_prod(list(C),product_prod(list(C),list(C)))))),aa(D,fun(C,fun(list(C),fun(list(C),fun(list(C),product_prod(list(C),product_prod(list(C),list(C))))))),aTP_Lamp_iw(fun(C,D),fun(D,fun(C,fun(list(C),fun(list(C),fun(list(C),product_prod(list(C),product_prod(list(C),list(C)))))))),Uu),Uua),Uub),Uuc)) ) ).

% ATP.lambda_469
tff(fact_6608_ATP_Olambda__470,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( ( semiring_0(C)
        & comm_monoid_add(D)
        & times(D) )
     => ! [Uu: fun(D,C),Uua: fun(E2,C),Uub: multiset(E2),Uuc: D] : aa(D,C,aa(multiset(E2),fun(D,C),aa(fun(E2,C),fun(multiset(E2),fun(D,C)),aTP_Lamp_rg(fun(D,C),fun(fun(E2,C),fun(multiset(E2),fun(D,C))),Uu),Uua),Uub),Uuc) = comm_m7189776963980413722m_mset(C,image_mset(E2,C,aa(D,fun(E2,C),aa(fun(E2,C),fun(D,fun(E2,C)),aTP_Lamp_rf(fun(D,C),fun(fun(E2,C),fun(D,fun(E2,C))),Uu),Uua),Uuc),Uub)) ) ).

% ATP.lambda_470
tff(fact_6609_ATP_Olambda__471,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(D,set(C)),Uua: fun(E2,set(C)),Uub: set(E2),Uuc: D] : aa(D,set(C),aa(set(E2),fun(D,set(C)),aa(fun(E2,set(C)),fun(set(E2),fun(D,set(C))),aTP_Lamp_cx(fun(D,set(C)),fun(fun(E2,set(C)),fun(set(E2),fun(D,set(C)))),Uu),Uua),Uub),Uuc) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(E2),set(set(C)),image2(E2,set(C),aa(D,fun(E2,set(C)),aa(fun(E2,set(C)),fun(D,fun(E2,set(C))),aTP_Lamp_cw(fun(D,set(C)),fun(fun(E2,set(C)),fun(D,fun(E2,set(C)))),Uu),Uua),Uuc)),Uub)) ).

% ATP.lambda_471
tff(fact_6610_ATP_Olambda__472,axiom,
    ! [D: $tType,C: $tType,E2: $tType] :
      ( comple592849572758109894attice(C)
     => ! [Uu: fun(D,C),Uua: fun(E2,C),Uub: set(E2),Uuc: D] : aa(D,C,aa(set(E2),fun(D,C),aa(fun(E2,C),fun(set(E2),fun(D,C)),aTP_Lamp_cn(fun(D,C),fun(fun(E2,C),fun(set(E2),fun(D,C))),Uu),Uua),Uub),Uuc) = aa(set(C),C,complete_Sup_Sup(C),aa(set(E2),set(C),image2(E2,C,aa(D,fun(E2,C),aa(fun(E2,C),fun(D,fun(E2,C)),aTP_Lamp_cm(fun(D,C),fun(fun(E2,C),fun(D,fun(E2,C))),Uu),Uua),Uuc)),Uub)) ) ).

% ATP.lambda_472
tff(fact_6611_ATP_Olambda__473,axiom,
    ! [C: $tType,E2: $tType,F4: $tType,D: $tType,Uu: set(D),Uua: fun(C,filter(E2)),Uub: fun(D,filter(F4)),Uuc: C] : aa(C,filter(product_prod(E2,F4)),aa(fun(D,filter(F4)),fun(C,filter(product_prod(E2,F4))),aa(fun(C,filter(E2)),fun(fun(D,filter(F4)),fun(C,filter(product_prod(E2,F4)))),aTP_Lamp_up(set(D),fun(fun(C,filter(E2)),fun(fun(D,filter(F4)),fun(C,filter(product_prod(E2,F4))))),Uu),Uua),Uub),Uuc) = aa(set(filter(product_prod(E2,F4))),filter(product_prod(E2,F4)),complete_Inf_Inf(filter(product_prod(E2,F4))),aa(set(D),set(filter(product_prod(E2,F4))),image2(D,filter(product_prod(E2,F4)),aa(C,fun(D,filter(product_prod(E2,F4))),aa(fun(D,filter(F4)),fun(C,fun(D,filter(product_prod(E2,F4)))),aTP_Lamp_uo(fun(C,filter(E2)),fun(fun(D,filter(F4)),fun(C,fun(D,filter(product_prod(E2,F4))))),Uua),Uub),Uuc)),Uu)) ).

% ATP.lambda_473
tff(fact_6612_ATP_Olambda__474,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: list(C),Uub: C,Uuc: list(C)] : aa(list(C),option(product_prod(list(C),product_prod(C,list(C)))),aa(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))),aa(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),aTP_Lamp_ol(fun(C,$o),fun(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))))),Uu),Uua),Uub),Uuc) = aa(product_prod(list(C),product_prod(C,list(C))),option(product_prod(list(C),product_prod(C,list(C)))),some(product_prod(list(C),product_prod(C,list(C)))),aa(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C))),aa(list(C),fun(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C)))),product_Pair(list(C),product_prod(C,list(C))),aa(list(C),list(C),aa(fun(C,$o),fun(list(C),list(C)),takeWhile(C),comp($o,$o,C,fNot,Uu)),Uua)),aa(list(C),product_prod(C,list(C)),aa(C,fun(list(C),product_prod(C,list(C))),product_Pair(C,list(C)),Uub),Uuc))) ).

% ATP.lambda_474
tff(fact_6613_ATP_Olambda__475,axiom,
    ! [C: $tType,Uu: C,Uua: list(C),Uub: C,Uuc: list(C)] : aa(list(C),option(product_prod(list(C),product_prod(C,list(C)))),aa(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))),aa(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C)))))),aTP_Lamp_oo(C,fun(list(C),fun(C,fun(list(C),option(product_prod(list(C),product_prod(C,list(C))))))),Uu),Uua),Uub),Uuc) = aa(product_prod(list(C),product_prod(C,list(C))),option(product_prod(list(C),product_prod(C,list(C)))),some(product_prod(list(C),product_prod(C,list(C)))),aa(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C))),aa(list(C),fun(product_prod(C,list(C)),product_prod(list(C),product_prod(C,list(C)))),product_Pair(list(C),product_prod(C,list(C))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uu),Uua)),aa(list(C),product_prod(C,list(C)),aa(C,fun(list(C),product_prod(C,list(C))),product_Pair(C,list(C)),Uub),Uuc))) ).

% ATP.lambda_475
tff(fact_6614_ATP_Olambda__476,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Uu: set(product_prod(D,D)),Uua: fun(C,fun(D,set(E2))),Uub: D,Uuc: C] : aa(C,set(E2),aa(D,fun(C,set(E2)),aa(fun(C,fun(D,set(E2))),fun(D,fun(C,set(E2))),aTP_Lamp_pr(set(product_prod(D,D)),fun(fun(C,fun(D,set(E2))),fun(D,fun(C,set(E2)))),Uu),Uua),Uub),Uuc) = aa(set(set(E2)),set(E2),complete_Sup_Sup(set(E2)),aa(set(D),set(set(E2)),image2(D,set(E2),aa(C,fun(D,set(E2)),Uua,Uuc)),image(D,D,Uu,aa(set(D),set(D),aa(D,fun(set(D),set(D)),insert2(D),Uub),bot_bot(set(D)))))) ).

% ATP.lambda_476
tff(fact_6615_ATP_Olambda__477,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,C),Uua: D,Uub: set(D),Uuc: C] :
      ( aa(C,$o,aa(set(D),fun(C,$o),aa(D,fun(set(D),fun(C,$o)),aTP_Lamp_ja(fun(D,C),fun(D,fun(set(D),fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ? [L3: D] :
          ( ( Uuc = aa(D,C,Uu,L3) )
          & ( ( L3 = Uua )
            | member2(D,L3,Uub) ) ) ) ).

% ATP.lambda_477
tff(fact_6616_ATP_Olambda__478,axiom,
    ! [D: $tType,C: $tType] :
      ( linorder(C)
     => ! [Uu: C,Uua: C,Uub: fun(C,D),Uuc: D] :
          ( aa(D,$o,aa(fun(C,D),fun(D,$o),aa(C,fun(fun(C,D),fun(D,$o)),aTP_Lamp_jh(C,fun(C,fun(fun(C,D),fun(D,$o))),Uu),Uua),Uub),Uuc)
        <=> ? [I2: C] :
              ( ( Uuc = aa(C,D,Uub,I2) )
              & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),Uu),I2)
              & aa(C,$o,aa(C,fun(C,$o),ord_less(C),I2),Uua) ) ) ) ).

% ATP.lambda_478
tff(fact_6617_ATP_Olambda__479,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Uu: fun(C,fun(C,C)),Uua: C,Uub: fun(D,set(E2)),Uuc: fun(E2,C),Uud: D] : aa(D,C,aa(fun(E2,C),fun(D,C),aa(fun(D,set(E2)),fun(fun(E2,C),fun(D,C)),aa(C,fun(fun(D,set(E2)),fun(fun(E2,C),fun(D,C))),aTP_Lamp_rw(fun(C,fun(C,C)),fun(C,fun(fun(D,set(E2)),fun(fun(E2,C),fun(D,C)))),Uu),Uua),Uub),Uuc),Uud) = aa(set(E2),C,aa(fun(E2,C),fun(set(E2),C),groups_comm_monoid_F(C,E2,Uu,Uua),Uuc),aa(D,set(E2),Uub,Uud)) ).

% ATP.lambda_479
tff(fact_6618_ATP_Olambda__480,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: list(C),Uub: C,Uuc: list(C),Uud: list(C)] : aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),aa(C,fun(list(C),fun(list(C),list(C))),aa(list(C),fun(C,fun(list(C),fun(list(C),list(C)))),aTP_Lamp_ng(fun(C,fun(C,$o)),fun(list(C),fun(C,fun(list(C),fun(list(C),list(C))))),Uu),Uua),Uub),Uuc),Uud) = aa(list(C),list(C),quicksort_by_rel(C,Uu,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Uub),aa(list(C),list(C),quicksort_by_rel(C,Uu,Uua),Uud))),Uuc) ).

% ATP.lambda_480
tff(fact_6619_ATP_Olambda__481,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Uu: fun(E2,fun(D,C)),Uua: fun(E2,E2),Uub: fun(fun(D,C),E2),Uuc: D,Uud: fun(D,C)] : aa(fun(D,C),C,aa(D,fun(fun(D,C),C),aa(fun(fun(D,C),E2),fun(D,fun(fun(D,C),C)),aa(fun(E2,E2),fun(fun(fun(D,C),E2),fun(D,fun(fun(D,C),C))),aTP_Lamp_ug(fun(E2,fun(D,C)),fun(fun(E2,E2),fun(fun(fun(D,C),E2),fun(D,fun(fun(D,C),C)))),Uu),Uua),Uub),Uuc),Uud) = aa(D,C,aa(E2,fun(D,C),Uu,aa(E2,E2,Uua,aa(fun(D,C),E2,Uub,Uud))),Uuc) ).

% ATP.lambda_481
tff(fact_6620_ATP_Olambda__482,axiom,
    ! [D: $tType,C: $tType,E2: $tType,Uu: fun(C,fun(E2,C)),Uua: fun(C,fun(D,fun(E2,D))),Uub: C,Uuc: D,Uud: E2] : aa(E2,product_prod(C,D),aa(D,fun(E2,product_prod(C,D)),aa(C,fun(D,fun(E2,product_prod(C,D))),aa(fun(C,fun(D,fun(E2,D))),fun(C,fun(D,fun(E2,product_prod(C,D)))),aTP_Lamp_lm(fun(C,fun(E2,C)),fun(fun(C,fun(D,fun(E2,D))),fun(C,fun(D,fun(E2,product_prod(C,D))))),Uu),Uua),Uub),Uuc),Uud) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(E2,C,aa(C,fun(E2,C),Uu,Uub),Uud)),aa(E2,D,aa(D,fun(E2,D),aa(C,fun(D,fun(E2,D)),Uua,Uub),Uuc),Uud)) ).

% ATP.lambda_482
tff(fact_6621_ATP_Olambda__483,axiom,
    ! [C: $tType,Uu: fun(C,fun(C,$o)),Uua: C,Uub: $o,Uuc: C,Uud: list(C)] :
      ( aa(list(C),$o,aa(C,fun(list(C),$o),aa($o,fun(C,fun(list(C),$o)),aa(C,fun($o,fun(C,fun(list(C),$o))),aTP_Lamp_ra(fun(C,fun(C,$o)),fun(C,fun($o,fun(C,fun(list(C),$o)))),Uu),Uua),(Uub)),Uuc),Uud)
    <=> ( aa(C,$o,aa(C,fun(C,$o),Uu,Uua),Uuc)
        & (Uub) ) ) ).

% ATP.lambda_483
tff(fact_6622_ATP_Olambda__484,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: nat,Uua: C,Uub: C,Uuc: C,Uud: nat] : aa(nat,C,aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hi(nat,fun(C,fun(C,fun(C,fun(nat,C)))),Uu),Uua),Uub),Uuc),Uud) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,minus_minus(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),Uud)),Uua),one_one(C))),Uud)),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uub),Uud))),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),Uub),Uuc)),minus_minus(nat,Uu,Uud))) ) ).

% ATP.lambda_484
tff(fact_6623_ATP_Olambda__485,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: nat,Uua: C,Uub: C,Uuc: C,Uud: nat] : aa(nat,C,aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hf(nat,fun(C,fun(C,fun(C,fun(nat,C)))),Uu),Uua),Uub),Uuc),Uud) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(nat,C,semiring_1_of_nat(C),Uu)),Uua)),Uud)),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uub),Uud))),aa(nat,C,aa(C,fun(nat,C),power_power(C),Uuc),minus_minus(nat,Uu,Uud))) ) ).

% ATP.lambda_485
tff(fact_6624_ATP_Olambda__486,axiom,
    ! [C: $tType] :
      ( field_char_0(C)
     => ! [Uu: nat,Uua: C,Uub: C,Uuc: C,Uud: nat] : aa(nat,C,aa(C,fun(nat,C),aa(C,fun(C,fun(nat,C)),aa(C,fun(C,fun(C,fun(nat,C))),aTP_Lamp_hg(nat,fun(C,fun(C,fun(C,fun(nat,C)))),Uu),Uua),Uub),Uuc),Uud) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),times_times(C),aa(nat,C,gbinomial(C,aa(C,C,uminus_uminus(C),Uua)),Uud)),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,uminus_uminus(C),Uub)),Uud))),aa(nat,C,aa(C,fun(nat,C),power_power(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),Uub),Uuc)),minus_minus(nat,Uu,Uud))) ) ).

% ATP.lambda_486
tff(fact_6625_ATP_Olambda__487,axiom,
    ! [C: $tType,Uu: set(product_prod(C,C)),Uua: C,Uub: C,Uuc: C,Uud: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aa(C,fun(C,fun(C,$o)),aa(C,fun(C,fun(C,fun(C,$o))),aTP_Lamp_qs(set(product_prod(C,C)),fun(C,fun(C,fun(C,fun(C,$o)))),Uu),Uua),Uub),Uuc),Uud)
    <=> ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uua),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uub),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uuc),aa(set(C),set(C),aa(C,fun(set(C),set(C)),insert2(C),Uud),bot_bot(set(C))))))),field2(C,Uu))
        & ( ( ( Uua = Uuc )
            & ( Uub = Uud ) )
          | member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),bNF_We1388413361240627857o_max2(C,Uu,Uua,Uub)),bNF_We1388413361240627857o_max2(C,Uu,Uuc,Uud)),minus_minus(set(product_prod(C,C)),Uu,id2(C)))
          | ( ( bNF_We1388413361240627857o_max2(C,Uu,Uua,Uub) = bNF_We1388413361240627857o_max2(C,Uu,Uuc,Uud) )
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uua),Uuc),minus_minus(set(product_prod(C,C)),Uu,id2(C))) )
          | ( ( bNF_We1388413361240627857o_max2(C,Uu,Uua,Uub) = bNF_We1388413361240627857o_max2(C,Uu,Uuc,Uud) )
            & ( Uua = Uuc )
            & member2(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uub),Uud),minus_minus(set(product_prod(C,C)),Uu,id2(C))) ) ) ) ) ).

% ATP.lambda_487
tff(fact_6626_ATP_Olambda__488,axiom,
    ! [C: $tType] :
      ( heap(C)
     => ! [Uu: nat,Uua: list(C),Uub: array(C),Uuc: C,Uud: array(C)] : aa(array(C),assn,aa(C,fun(array(C),assn),aa(array(C),fun(C,fun(array(C),assn)),aa(list(C),fun(array(C),fun(C,fun(array(C),assn))),aTP_Lamp_th(nat,fun(list(C),fun(array(C),fun(C,fun(array(C),assn)))),Uu),Uua),Uub),Uuc),Uud) = aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),snga_assn(C,Uub,aa(C,list(C),aa(nat,fun(C,list(C)),aa(list(C),fun(nat,fun(C,list(C))),list_update(C),Uua),Uu),Uuc))),pure_assn(Uud = Uub)) ) ).

% ATP.lambda_488
tff(fact_6627_ATP_Olambda__489,axiom,
    ! [C: $tType,E2: $tType,D: $tType] :
      ( semiring_0(E2)
     => ! [Uu: fun(C,E2),Uua: fun(D,E2),Uub: set(C),Uuc: set(D),Uud: E2] :
          ( aa(E2,$o,aa(set(D),fun(E2,$o),aa(set(C),fun(set(D),fun(E2,$o)),aa(fun(D,E2),fun(set(C),fun(set(D),fun(E2,$o))),aTP_Lamp_nl(fun(C,E2),fun(fun(D,E2),fun(set(C),fun(set(D),fun(E2,$o)))),Uu),Uua),Uub),Uuc),Uud)
        <=> ? [A6: C,B5: D] :
              ( ( Uud = aa(E2,E2,aa(E2,fun(E2,E2),times_times(E2),aa(C,E2,Uu,A6)),aa(D,E2,Uua,B5)) )
              & member2(C,A6,Uub)
              & member2(D,B5,Uuc) ) ) ) ).

% ATP.lambda_489
tff(fact_6628_ATP_Olambda__490,axiom,
    ! [Uu: fun(c,d),Uua: d,Uub: c,Uuc: list(c),Uud: list(c),Uue: list(c)] :
      aa(list(c),product_prod(list(c),product_prod(list(c),list(c))),aa(list(c),fun(list(c),product_prod(list(c),product_prod(list(c),list(c)))),aa(list(c),fun(list(c),fun(list(c),product_prod(list(c),product_prod(list(c),list(c))))),aa(c,fun(list(c),fun(list(c),fun(list(c),product_prod(list(c),product_prod(list(c),list(c)))))),aa(d,fun(c,fun(list(c),fun(list(c),fun(list(c),product_prod(list(c),product_prod(list(c),list(c))))))),aTP_Lamp_iw(fun(c,d),fun(d,fun(c,fun(list(c),fun(list(c),fun(list(c),product_prod(list(c),product_prod(list(c),list(c)))))))),Uu),Uua),Uub),Uuc),Uud),Uue) = $let(
        x: d,
        x:= aa(c,d,Uu,Uub),
        $ite(
          aa(d,$o,aa(d,fun(d,$o),ord_less(d),x),Uua),
          aa(product_prod(list(c),list(c)),product_prod(list(c),product_prod(list(c),list(c))),aa(list(c),fun(product_prod(list(c),list(c)),product_prod(list(c),product_prod(list(c),list(c)))),product_Pair(list(c),product_prod(list(c),list(c))),aa(list(c),list(c),aa(c,fun(list(c),list(c)),cons(c),Uub),Uuc)),aa(list(c),product_prod(list(c),list(c)),aa(list(c),fun(list(c),product_prod(list(c),list(c))),product_Pair(list(c),list(c)),Uud),Uue)),
          $ite(aa(d,$o,aa(d,fun(d,$o),ord_less(d),Uua),x),aa(product_prod(list(c),list(c)),product_prod(list(c),product_prod(list(c),list(c))),aa(list(c),fun(product_prod(list(c),list(c)),product_prod(list(c),product_prod(list(c),list(c)))),product_Pair(list(c),product_prod(list(c),list(c))),Uuc),aa(list(c),product_prod(list(c),list(c)),aa(list(c),fun(list(c),product_prod(list(c),list(c))),product_Pair(list(c),list(c)),Uud),aa(list(c),list(c),aa(c,fun(list(c),list(c)),cons(c),Uub),Uue))),aa(product_prod(list(c),list(c)),product_prod(list(c),product_prod(list(c),list(c))),aa(list(c),fun(product_prod(list(c),list(c)),product_prod(list(c),product_prod(list(c),list(c)))),product_Pair(list(c),product_prod(list(c),list(c))),Uuc),aa(list(c),product_prod(list(c),list(c)),aa(list(c),fun(list(c),product_prod(list(c),list(c))),product_Pair(list(c),list(c)),aa(list(c),list(c),aa(c,fun(list(c),list(c)),cons(c),Uub),Uud)),Uue))) ) ) ).

% ATP.lambda_490
tff(fact_6629_ATP_Olambda__491,axiom,
    ! [C: $tType,D: $tType,Uu: multiset(D),Uua: C] : aa(C,multiset(D),aTP_Lamp_ac(multiset(D),fun(C,multiset(D)),Uu),Uua) = Uu ).

% ATP.lambda_491
tff(fact_6630_ATP_Olambda__492,axiom,
    ! [C: $tType,Uu: assn,Uua: C] : aa(C,assn,aTP_Lamp_sc(assn,fun(C,assn),Uu),Uua) = Uu ).

% ATP.lambda_492
tff(fact_6631_ATP_Olambda__493,axiom,
    ! [C: $tType,Uu: $o,Uua: C] :
      ( aa(C,$o,aTP_Lamp_kt($o,fun(C,$o),(Uu)),Uua)
    <=> (Uu) ) ).

% ATP.lambda_493
tff(fact_6632_ATP_Olambda__494,axiom,
    ! [D: $tType,E2: $tType,Uu: set(E2),Uua: D] : aa(D,set(E2),aTP_Lamp_nc(set(E2),fun(D,set(E2)),Uu),Uua) = Uu ).

% ATP.lambda_494
tff(fact_6633_ATP_Olambda__495,axiom,
    ! [D: $tType,Uu: set(D),Uua: D] : aa(D,set(D),aTP_Lamp_me(set(D),fun(D,set(D)),Uu),Uua) = Uu ).

% ATP.lambda_495
tff(fact_6634_ATP_Olambda__496,axiom,
    ! [C: $tType,D: $tType,Uu: set(D),Uua: C] : aa(C,set(D),aTP_Lamp_mb(set(D),fun(C,set(D)),Uu),Uua) = Uu ).

% ATP.lambda_496
tff(fact_6635_ATP_Olambda__497,axiom,
    ! [C: $tType,Uu: set(C),Uua: list(C)] : aa(list(C),set(C),aTP_Lamp_mr(set(C),fun(list(C),set(C)),Uu),Uua) = Uu ).

% ATP.lambda_497
tff(fact_6636_ATP_Olambda__498,axiom,
    ! [D: $tType,C: $tType,Uu: set(C),Uua: D] : aa(D,set(C),aTP_Lamp_an(set(C),fun(D,set(C)),Uu),Uua) = Uu ).

% ATP.lambda_498
tff(fact_6637_ATP_Olambda__499,axiom,
    ! [C: $tType,Uu: set(C),Uua: C] : aa(C,set(C),aTP_Lamp_mg(set(C),fun(C,set(C)),Uu),Uua) = Uu ).

% ATP.lambda_499
tff(fact_6638_ATP_Olambda__500,axiom,
    ! [C: $tType,D: $tType,Uu: fun(D,$o),Uua: C] : aa(C,fun(D,$o),aTP_Lamp_sx(fun(D,$o),fun(C,fun(D,$o)),Uu),Uua) = Uu ).

% ATP.lambda_500
tff(fact_6639_ATP_Olambda__501,axiom,
    ! [C: $tType,E2: $tType,D: $tType,Uu: fun(D,E2),Uua: C] : aa(C,fun(D,E2),aTP_Lamp_lh(fun(D,E2),fun(C,fun(D,E2)),Uu),Uua) = Uu ).

% ATP.lambda_501
tff(fact_6640_ATP_Olambda__502,axiom,
    ! [D: $tType,E2: $tType,C: $tType,Uu: fun(C,fun(E2,E2)),Uua: D] : aa(D,fun(C,fun(E2,E2)),aTP_Lamp_ij(fun(C,fun(E2,E2)),fun(D,fun(C,fun(E2,E2))),Uu),Uua) = Uu ).

% ATP.lambda_502
tff(fact_6641_ATP_Olambda__503,axiom,
    ! [C: $tType,D: $tType] :
      ( condit1219197933456340205attice(D)
     => ! [Uu: D,Uua: C] : aa(C,D,aTP_Lamp_ag(D,fun(C,D),Uu),Uua) = Uu ) ).

% ATP.lambda_503
tff(fact_6642_ATP_Olambda__504,axiom,
    ! [C: $tType,D: $tType] :
      ( comple6319245703460814977attice(D)
     => ! [Uu: D,Uua: C] : aa(C,D,aTP_Lamp_ah(D,fun(C,D),Uu),Uua) = Uu ) ).

% ATP.lambda_504
tff(fact_6643_ATP_Olambda__505,axiom,
    ! [C: $tType,D: $tType] :
      ( linorder(D)
     => ! [Uu: D,Uua: C] : aa(C,D,aTP_Lamp_at(D,fun(C,D),Uu),Uua) = Uu ) ).

% ATP.lambda_505
tff(fact_6644_ATP_Olambda__506,axiom,
    ! [C: $tType,D: $tType,Uu: D,Uua: C] : aa(C,D,aTP_Lamp_ck(D,fun(C,D),Uu),Uua) = Uu ).

% ATP.lambda_506
tff(fact_6645_ATP_Olambda__507,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [Uu: C,Uua: D] : aa(D,C,aTP_Lamp_dg(C,fun(D,C),Uu),Uua) = Uu ) ).

% ATP.lambda_507
tff(fact_6646_ATP_Olambda__508,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: C,Uua: list(C)] : aa(list(C),C,aa(C,fun(list(C),C),aTP_Lamp_iy(C,fun(list(C),C)),Uu),Uua) = Uu ) ).

% ATP.lambda_508
tff(fact_6647_ATP_Olambda__509,axiom,
    ! [D: $tType,C: $tType] :
      ( semiring_1(C)
     => ! [Uu: C,Uua: D] : aa(D,C,aTP_Lamp_fy(C,fun(D,C),Uu),Uua) = Uu ) ).

% ATP.lambda_509
tff(fact_6648_ATP_Olambda__510,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),C,aa(C,fun(list(C),C),aTP_Lamp_ke(C,fun(list(C),C)),Uu),Uua) = Uu ).

% ATP.lambda_510
tff(fact_6649_ATP_Olambda__511,axiom,
    ! [C: $tType,Uu: C,Uua: nat] : aa(nat,C,aTP_Lamp_ky(C,fun(nat,C),Uu),Uua) = Uu ).

% ATP.lambda_511
tff(fact_6650_ATP_Olambda__512,axiom,
    ! [D: $tType,C: $tType,Uu: C,Uua: D] : aa(D,C,aTP_Lamp_cj(C,fun(D,C),Uu),Uua) = Uu ).

% ATP.lambda_512
tff(fact_6651_ATP_Olambda__513,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] : aa(list(C),list(C),aa(C,fun(list(C),list(C)),aTP_Lamp_ce(C,fun(list(C),list(C))),Uu),Uua) = Uua ).

% ATP.lambda_513
tff(fact_6652_ATP_Olambda__514,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] :
      ( aa(list(C),$o,aa(C,fun(list(C),$o),aTP_Lamp_cc(C,fun(list(C),$o)),Uu),Uua)
    <=> $false ) ).

% ATP.lambda_514
tff(fact_6653_ATP_Olambda__515,axiom,
    ! [C: $tType,Uu: C,Uua: list(C)] :
      ( aa(list(C),$o,aa(C,fun(list(C),$o),aTP_Lamp_cd(C,fun(list(C),$o)),Uu),Uua)
    <=> $true ) ).

% ATP.lambda_515
tff(fact_6654_ATP_Olambda__516,axiom,
    ! [C: $tType,Uu: C,Uua: C] :
      ( aa(C,$o,aa(C,fun(C,$o),aTP_Lamp_ax(C,fun(C,$o)),Uu),Uua)
    <=> $true ) ).

% ATP.lambda_516
tff(fact_6655_ATP_Olambda__517,axiom,
    ! [Uu: nat] : aa(nat,nat,aTP_Lamp_ez(nat,nat),Uu) = Uu ).

% ATP.lambda_517
tff(fact_6656_ATP_Olambda__518,axiom,
    ! [Uu: int] : aa(int,int,aTP_Lamp_iu(int,int),Uu) = Uu ).

% ATP.lambda_518
tff(fact_6657_ATP_Olambda__519,axiom,
    ! [C: $tType] :
      ( linorder(C)
     => ! [Uu: C] : aa(C,C,aTP_Lamp_az(C,C),Uu) = Uu ) ).

% ATP.lambda_519
tff(fact_6658_ATP_Olambda__520,axiom,
    ! [C: $tType] :
      ( monoid_mult(C)
     => ! [Uu: C] : aa(C,C,aTP_Lamp_bz(C,C),Uu) = Uu ) ).

% ATP.lambda_520
tff(fact_6659_ATP_Olambda__521,axiom,
    ! [C: $tType] :
      ( semiring_Gcd(C)
     => ! [Uu: C] : aa(C,C,aTP_Lamp_ru(C,C),Uu) = Uu ) ).

% ATP.lambda_521
tff(fact_6660_ATP_Olambda__522,axiom,
    ! [C: $tType,Uu: C] : aa(C,C,aTP_Lamp_ab(C,C),Uu) = Uu ).

% ATP.lambda_522
tff(fact_6661_ATP_Olambda__523,axiom,
    ! [C: $tType,D: $tType,Uu: C] : aa(C,set(D),aTP_Lamp_mc(C,set(D)),Uu) = top_top(set(D)) ).

% ATP.lambda_523
tff(fact_6662_ATP_Olambda__524,axiom,
    ! [E2: $tType,D: $tType,Uu: E2] : aa(E2,set(D),aTP_Lamp_ly(E2,set(D)),Uu) = bot_bot(set(D)) ).

% ATP.lambda_524
tff(fact_6663_ATP_Olambda__525,axiom,
    ! [D: $tType,C: $tType,Uu: D] : aa(D,set(C),aTP_Lamp_cs(D,set(C)),Uu) = bot_bot(set(C)) ).

% ATP.lambda_525
tff(fact_6664_ATP_Olambda__526,axiom,
    ! [D: $tType,C: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [Uu: D] : aa(D,C,aTP_Lamp_af(D,C),Uu) = bot_bot(C) ) ).

% ATP.lambda_526
tff(fact_6665_ATP_Olambda__527,axiom,
    ! [C: $tType,F4: $tType,Uu: C] : aa(C,set(F4),aTP_Lamp_lz(C,set(F4)),Uu) = bot_bot(set(F4)) ).

% ATP.lambda_527
tff(fact_6666_ATP_Olambda__528,axiom,
    ! [C: $tType,D: $tType,Uu: C] : aa(C,set(D),aTP_Lamp_ms(C,set(D)),Uu) = bot_bot(set(D)) ).

% ATP.lambda_528
tff(fact_6667_ATP_Olambda__529,axiom,
    ! [D: $tType,C: $tType] :
      ( monoid_add(C)
     => ! [Uu: D] : aa(D,C,aTP_Lamp_rj(D,C),Uu) = zero_zero(C) ) ).

% ATP.lambda_529
tff(fact_6668_ATP_Olambda__530,axiom,
    ! [C: $tType] :
      ( mult_zero(C)
     => ! [Uu: C] : aa(C,C,aTP_Lamp_ca(C,C),Uu) = zero_zero(C) ) ).

% ATP.lambda_530
tff(fact_6669_ATP_Olambda__531,axiom,
    ! [Uu: product_unit] : aa(product_unit,assn,aTP_Lamp_tp(product_unit,assn),Uu) = one_one(assn) ).

% ATP.lambda_531
tff(fact_6670_ATP_Olambda__532,axiom,
    ! [D: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: D] : aa(D,C,aTP_Lamp_ae(D,C),Uu) = one_one(C) ) ).

% ATP.lambda_532
tff(fact_6671_ATP_Olambda__533,axiom,
    ! [D: $tType,C: $tType,Uu: D] : aa(D,option(C),aTP_Lamp_oe(D,option(C)),Uu) = none(C) ).

% ATP.lambda_533
tff(fact_6672_ATP_Olambda__534,axiom,
    ! [C: $tType,D: $tType,Uu: C] : aa(C,option(D),aTP_Lamp_od(C,option(D)),Uu) = none(D) ).

% ATP.lambda_534
tff(fact_6673_ATP_Olambda__535,axiom,
    ! [C: $tType,D: $tType,Uu: C] : aa(C,D,aTP_Lamp_rs(C,D),Uu) = undefined(D) ).

% ATP.lambda_535
tff(fact_6674_ATP_Olambda__536,axiom,
    ! [Uu: product_prod(heap_ext(product_unit),set(nat))] :
      ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,aTP_Lamp_rx(product_prod(heap_ext(product_unit),set(nat)),$o),Uu)
    <=> $false ) ).

% ATP.lambda_536
tff(fact_6675_ATP_Olambda__537,axiom,
    ! [C: $tType,Uu: C] :
      ( aa(C,$o,aTP_Lamp_bo(C,$o),Uu)
    <=> $false ) ).

% ATP.lambda_537
tff(fact_6676_ATP_Olambda__538,axiom,
    ! [C: $tType,Uu: C] :
      ( aa(C,$o,aTP_Lamp_ku(C,$o),Uu)
    <=> $true ) ).

% ATP.lambda_538
tff(fact_6677_ATP_Olambda__539,axiom,
    ! [C: $tType,Uu: C] : aa(C,fun(nat,nat),aTP_Lamp_au(C,fun(nat,nat)),Uu) = suc ).

% ATP.lambda_539

% Type constructors (565)
tff(tcon_fun___Conditionally__Complete__Lattices_Oconditionally__complete__lattice,axiom,
    ! [A18: $tType,A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => condit1219197933456340205attice(fun(A18,A19)) ) ).

tff(tcon_fun___Complete__Lattices_Ocomplete__distrib__lattice,axiom,
    ! [A18: $tType,A19: $tType] :
      ( comple592849572758109894attice(A19)
     => comple592849572758109894attice(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Obounded__semilattice__sup__bot,axiom,
    ! [A18: $tType,A19: $tType] :
      ( bounded_lattice(A19)
     => bounde4967611905675639751up_bot(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Obounded__semilattice__inf__top,axiom,
    ! [A18: $tType,A19: $tType] :
      ( bounded_lattice(A19)
     => bounde4346867609351753570nf_top(fun(A18,A19)) ) ).

tff(tcon_fun___Complete__Lattices_Ocomplete__lattice,axiom,
    ! [A18: $tType,A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => comple6319245703460814977attice(fun(A18,A19)) ) ).

tff(tcon_fun___Boolean__Algebras_Oboolean__algebra,axiom,
    ! [A18: $tType,A19: $tType] :
      ( boolea8198339166811842893lgebra(A19)
     => boolea8198339166811842893lgebra(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Obounded__lattice__top,axiom,
    ! [A18: $tType,A19: $tType] :
      ( bounded_lattice(A19)
     => bounded_lattice_top(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Obounded__lattice__bot,axiom,
    ! [A18: $tType,A19: $tType] :
      ( bounded_lattice(A19)
     => bounded_lattice_bot(fun(A18,A19)) ) ).

tff(tcon_fun___Complete__Partial__Order_Occpo,axiom,
    ! [A18: $tType,A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => comple9053668089753744459l_ccpo(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Osemilattice__sup,axiom,
    ! [A18: $tType,A19: $tType] :
      ( semilattice_sup(A19)
     => semilattice_sup(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Osemilattice__inf,axiom,
    ! [A18: $tType,A19: $tType] :
      ( semilattice_inf(A19)
     => semilattice_inf(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Odistrib__lattice,axiom,
    ! [A18: $tType,A19: $tType] :
      ( distrib_lattice(A19)
     => distrib_lattice(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Obounded__lattice,axiom,
    ! [A18: $tType,A19: $tType] :
      ( bounded_lattice(A19)
     => bounded_lattice(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Oorder__top,axiom,
    ! [A18: $tType,A19: $tType] :
      ( order_top(A19)
     => order_top(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Oorder__bot,axiom,
    ! [A18: $tType,A19: $tType] :
      ( order_bot(A19)
     => order_bot(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Opreorder,axiom,
    ! [A18: $tType,A19: $tType] :
      ( preorder(A19)
     => preorder(fun(A18,A19)) ) ).

tff(tcon_fun___Finite__Set_Ofinite,axiom,
    ! [A18: $tType,A19: $tType] :
      ( ( finite_finite(A18)
        & finite_finite(A19) )
     => finite_finite(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Olattice,axiom,
    ! [A18: $tType,A19: $tType] :
      ( lattice(A19)
     => lattice(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Oorder,axiom,
    ! [A18: $tType,A19: $tType] :
      ( order(A19)
     => order(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Otop,axiom,
    ! [A18: $tType,A19: $tType] :
      ( top(A19)
     => top(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Oord,axiom,
    ! [A18: $tType,A19: $tType] :
      ( ord(A19)
     => ord(fun(A18,A19)) ) ).

tff(tcon_fun___Orderings_Obot,axiom,
    ! [A18: $tType,A19: $tType] :
      ( bot(A19)
     => bot(fun(A18,A19)) ) ).

tff(tcon_fun___Groups_Ouminus,axiom,
    ! [A18: $tType,A19: $tType] :
      ( uminus(A19)
     => uminus(fun(A18,A19)) ) ).

tff(tcon_fun___Lattices_Oinf,axiom,
    ! [A18: $tType,A19: $tType] :
      ( semilattice_inf(A19)
     => inf(fun(A18,A19)) ) ).

tff(tcon_fun___Groups_Ominus,axiom,
    ! [A18: $tType,A19: $tType] :
      ( minus(A19)
     => minus(fun(A18,A19)) ) ).

tff(tcon_Int_Oint___Conditionally__Complete__Lattices_Oconditionally__complete__linorder,axiom,
    condit6923001295902523014norder(int) ).

tff(tcon_Int_Oint___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_1,axiom,
    condit1219197933456340205attice(int) ).

tff(tcon_Int_Oint___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations,axiom,
    bit_un5681908812861735899ations(int) ).

tff(tcon_Int_Oint___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct,axiom,
    semiri1453513574482234551roduct(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Ounique__euclidean__semiring__with__nat,axiom,
    euclid5411537665997757685th_nat(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Ounique__euclidean__ring__with__nat,axiom,
    euclid8789492081693882211th_nat(int) ).

tff(tcon_Int_Oint___Groups_Oordered__ab__semigroup__monoid__add__imp__le,axiom,
    ordere1937475149494474687imp_le(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Ounique__euclidean__semiring,axiom,
    euclid3128863361964157862miring(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Oeuclidean__semiring__cancel,axiom,
    euclid4440199948858584721cancel(int) ).

tff(tcon_Int_Oint___Rings_Onormalization__semidom__multiplicative,axiom,
    normal6328177297339901930cative(int) ).

tff(tcon_Int_Oint___Divides_Ounique__euclidean__semiring__numeral,axiom,
    unique1627219031080169319umeral(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Oeuclidean__ring__cancel,axiom,
    euclid8851590272496341667cancel(int) ).

tff(tcon_Int_Oint___Rings_Osemiring__no__zero__divisors__cancel,axiom,
    semiri6575147826004484403cancel(int) ).

tff(tcon_Int_Oint___Groups_Ostrict__ordered__ab__semigroup__add,axiom,
    strict9044650504122735259up_add(int) ).

tff(tcon_Int_Oint___Groups_Oordered__cancel__ab__semigroup__add,axiom,
    ordere580206878836729694up_add(int) ).

tff(tcon_Int_Oint___Groups_Oordered__ab__semigroup__add__imp__le,axiom,
    ordere2412721322843649153imp_le(int) ).

tff(tcon_Int_Oint___Bit__Operations_Osemiring__bit__operations,axiom,
    bit_se359711467146920520ations(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__comm__semiring__strict,axiom,
    linord2810124833399127020strict(int) ).

tff(tcon_Int_Oint___Groups_Ostrict__ordered__comm__monoid__add,axiom,
    strict7427464778891057005id_add(int) ).

tff(tcon_Int_Oint___Groups_Oordered__cancel__comm__monoid__add,axiom,
    ordere8940638589300402666id_add(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Oeuclidean__semiring,axiom,
    euclid3725896446679973847miring(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__semiring__1__strict,axiom,
    linord715952674999750819strict(int) ).

tff(tcon_Int_Oint___Groups_Olinordered__ab__semigroup__add,axiom,
    linord4140545234300271783up_add(int) ).

tff(tcon_Int_Oint___Bit__Operations_Oring__bit__operations,axiom,
    bit_ri3973907225187159222ations(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__nonzero__semiring,axiom,
    linord181362715937106298miring(int) ).

tff(tcon_Int_Oint___Rings_Osemidom__divide__unit__factor,axiom,
    semido2269285787275462019factor(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__semiring__strict,axiom,
    linord8928482502909563296strict(int) ).

tff(tcon_Int_Oint___Rings_Osemiring__no__zero__divisors,axiom,
    semiri3467727345109120633visors(int) ).

tff(tcon_Int_Oint___Groups_Oordered__ab__semigroup__add,axiom,
    ordere6658533253407199908up_add(int) ).

tff(tcon_Int_Oint___Groups_Oordered__ab__group__add__abs,axiom,
    ordere166539214618696060dd_abs(int) ).

tff(tcon_Int_Oint___GCD_Osemiring__gcd__mult__normalize,axiom,
    semiri6843258321239162965malize(int) ).

tff(tcon_Int_Oint___Groups_Oordered__comm__monoid__add,axiom,
    ordere6911136660526730532id_add(int) ).

tff(tcon_Int_Oint___Groups_Olinordered__ab__group__add,axiom,
    linord5086331880401160121up_add(int) ).

tff(tcon_Int_Oint___Groups_Ocancel__ab__semigroup__add,axiom,
    cancel2418104881723323429up_add(int) ).

tff(tcon_Int_Oint___Rings_Oring__1__no__zero__divisors,axiom,
    ring_15535105094025558882visors(int) ).

tff(tcon_Int_Oint___Groups_Ocancel__comm__monoid__add,axiom,
    cancel1802427076303600483id_add(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__ring__strict,axiom,
    linord4710134922213307826strict(int) ).

tff(tcon_Int_Oint___Rings_Ocomm__semiring__1__cancel,axiom,
    comm_s4317794764714335236cancel(int) ).

tff(tcon_Int_Oint___Bit__Operations_Osemiring__bits,axiom,
    bit_semiring_bits(int) ).

tff(tcon_Int_Oint___Rings_Oordered__comm__semiring,axiom,
    ordere2520102378445227354miring(int) ).

tff(tcon_Int_Oint___Rings_Onormalization__semidom,axiom,
    normal8620421768224518004emidom(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__semiring__1,axiom,
    linord6961819062388156250ring_1(int) ).

tff(tcon_Int_Oint___Groups_Oordered__ab__group__add,axiom,
    ordered_ab_group_add(int) ).

tff(tcon_Int_Oint___Groups_Ocancel__semigroup__add,axiom,
    cancel_semigroup_add(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__semiring,axiom,
    linordered_semiring(int) ).

tff(tcon_Int_Oint___Rings_Oordered__semiring__0,axiom,
    ordered_semiring_0(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__semidom,axiom,
    linordered_semidom(int) ).

tff(tcon_Int_Oint___Lattices_Osemilattice__sup_2,axiom,
    semilattice_sup(int) ).

tff(tcon_Int_Oint___Lattices_Osemilattice__inf_3,axiom,
    semilattice_inf(int) ).

tff(tcon_Int_Oint___Lattices_Odistrib__lattice_4,axiom,
    distrib_lattice(int) ).

tff(tcon_Int_Oint___Groups_Oab__semigroup__mult,axiom,
    ab_semigroup_mult(int) ).

tff(tcon_Int_Oint___Rings_Oalgebraic__semidom,axiom,
    algebraic_semidom(int) ).

tff(tcon_Int_Oint___Groups_Ocomm__monoid__mult,axiom,
    comm_monoid_mult(int) ).

tff(tcon_Int_Oint___Groups_Oab__semigroup__add,axiom,
    ab_semigroup_add(int) ).

tff(tcon_Int_Oint___Rings_Oordered__semiring,axiom,
    ordered_semiring(int) ).

tff(tcon_Int_Oint___Rings_Oordered__ring__abs,axiom,
    ordered_ring_abs(int) ).

tff(tcon_Int_Oint___Parity_Osemiring__parity,axiom,
    semiring_parity(int) ).

tff(tcon_Int_Oint___Groups_Ocomm__monoid__add,axiom,
    comm_monoid_add(int) ).

tff(tcon_Int_Oint___Rings_Osemiring__modulo,axiom,
    semiring_modulo(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__ring,axiom,
    linordered_ring(int) ).

tff(tcon_Int_Oint___Rings_Olinordered__idom,axiom,
    linordered_idom(int) ).

tff(tcon_Int_Oint___Rings_Ocomm__semiring__1,axiom,
    comm_semiring_1(int) ).

tff(tcon_Int_Oint___Rings_Ocomm__semiring__0,axiom,
    comm_semiring_0(int) ).

tff(tcon_Int_Oint___Groups_Osemigroup__mult,axiom,
    semigroup_mult(int) ).

tff(tcon_Int_Oint___Rings_Osemidom__modulo,axiom,
    semidom_modulo(int) ).

tff(tcon_Int_Oint___Rings_Osemidom__divide,axiom,
    semidom_divide(int) ).

tff(tcon_Int_Oint___Num_Osemiring__numeral,axiom,
    semiring_numeral(int) ).

tff(tcon_Int_Oint___Groups_Osemigroup__add,axiom,
    semigroup_add(int) ).

tff(tcon_Int_Oint___Rings_Ozero__less__one,axiom,
    zero_less_one(int) ).

tff(tcon_Int_Oint___Rings_Ocomm__semiring,axiom,
    comm_semiring(int) ).

tff(tcon_Int_Oint___Nat_Osemiring__char__0,axiom,
    semiring_char_0(int) ).

tff(tcon_Int_Oint___Groups_Oab__group__add,axiom,
    ab_group_add(int) ).

tff(tcon_Int_Oint___Rings_Ozero__neq__one,axiom,
    zero_neq_one(int) ).

tff(tcon_Int_Oint___Rings_Oordered__ring,axiom,
    ordered_ring(int) ).

tff(tcon_Int_Oint___Rings_Oidom__abs__sgn,axiom,
    idom_abs_sgn(int) ).

tff(tcon_Int_Oint___Orderings_Opreorder_5,axiom,
    preorder(int) ).

tff(tcon_Int_Oint___Orderings_Olinorder,axiom,
    linorder(int) ).

tff(tcon_Int_Oint___Groups_Omonoid__mult,axiom,
    monoid_mult(int) ).

tff(tcon_Int_Oint___Rings_Ocomm__ring__1,axiom,
    comm_ring_1(int) ).

tff(tcon_Int_Oint___Groups_Omonoid__add,axiom,
    monoid_add(int) ).

tff(tcon_Int_Oint___Rings_Osemiring__1,axiom,
    semiring_1(int) ).

tff(tcon_Int_Oint___Rings_Osemiring__0,axiom,
    semiring_0(int) ).

tff(tcon_Int_Oint___Orderings_Ono__top,axiom,
    no_top(int) ).

tff(tcon_Int_Oint___Orderings_Ono__bot,axiom,
    no_bot(int) ).

tff(tcon_Int_Oint___Lattices_Olattice_6,axiom,
    lattice(int) ).

tff(tcon_Int_Oint___Groups_Ogroup__add,axiom,
    group_add(int) ).

tff(tcon_Int_Oint___GCD_Osemiring__gcd,axiom,
    semiring_gcd(int) ).

tff(tcon_Int_Oint___GCD_Osemiring__Gcd,axiom,
    semiring_Gcd(int) ).

tff(tcon_Int_Oint___Rings_Omult__zero,axiom,
    mult_zero(int) ).

tff(tcon_Int_Oint___Rings_Ocomm__ring,axiom,
    comm_ring(int) ).

tff(tcon_Int_Oint___Orderings_Oorder_7,axiom,
    order(int) ).

tff(tcon_Int_Oint___Num_Oneg__numeral,axiom,
    neg_numeral(int) ).

tff(tcon_Int_Oint___Nat_Oring__char__0,axiom,
    ring_char_0(int) ).

tff(tcon_Int_Oint___Rings_Osemiring,axiom,
    semiring(int) ).

tff(tcon_Int_Oint___Orderings_Oord_8,axiom,
    ord(int) ).

tff(tcon_Int_Oint___Groups_Ouminus_9,axiom,
    uminus(int) ).

tff(tcon_Int_Oint___Rings_Oring__1,axiom,
    ring_1(int) ).

tff(tcon_Int_Oint___Lattices_Oinf_10,axiom,
    inf(int) ).

tff(tcon_Int_Oint___Groups_Otimes,axiom,
    times(int) ).

tff(tcon_Int_Oint___Groups_Ominus_11,axiom,
    minus(int) ).

tff(tcon_Int_Oint___GCD_Oring__gcd,axiom,
    ring_gcd(int) ).

tff(tcon_Int_Oint___Power_Opower,axiom,
    power(int) ).

tff(tcon_Int_Oint___Num_Onumeral,axiom,
    numeral(int) ).

tff(tcon_Int_Oint___Groups_Ozero,axiom,
    zero(int) ).

tff(tcon_Int_Oint___Rings_Oring,axiom,
    ring(int) ).

tff(tcon_Int_Oint___Rings_Oidom,axiom,
    idom(int) ).

tff(tcon_Int_Oint___Groups_Oone,axiom,
    one(int) ).

tff(tcon_Int_Oint___Rings_Odvd,axiom,
    dvd(int) ).

tff(tcon_Int_Oint___Heap_Oheap,axiom,
    heap(int) ).

tff(tcon_Nat_Onat___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_12,axiom,
    condit6923001295902523014norder(nat) ).

tff(tcon_Nat_Onat___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_13,axiom,
    condit1219197933456340205attice(nat) ).

tff(tcon_Nat_Onat___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations_14,axiom,
    bit_un5681908812861735899ations(nat) ).

tff(tcon_Nat_Onat___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_15,axiom,
    semiri1453513574482234551roduct(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Ounique__euclidean__semiring__with__nat_16,axiom,
    euclid5411537665997757685th_nat(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__monoid__add__imp__le_17,axiom,
    ordere1937475149494474687imp_le(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Ounique__euclidean__semiring_18,axiom,
    euclid3128863361964157862miring(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Oeuclidean__semiring__cancel_19,axiom,
    euclid4440199948858584721cancel(nat) ).

tff(tcon_Nat_Onat___Rings_Onormalization__semidom__multiplicative_20,axiom,
    normal6328177297339901930cative(nat) ).

tff(tcon_Nat_Onat___Divides_Ounique__euclidean__semiring__numeral_21,axiom,
    unique1627219031080169319umeral(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__no__zero__divisors__cancel_22,axiom,
    semiri6575147826004484403cancel(nat) ).

tff(tcon_Nat_Onat___Groups_Ostrict__ordered__ab__semigroup__add_23,axiom,
    strict9044650504122735259up_add(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__cancel__comm__monoid__diff,axiom,
    ordere1170586879665033532d_diff(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__cancel__ab__semigroup__add_24,axiom,
    ordere580206878836729694up_add(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add__imp__le_25,axiom,
    ordere2412721322843649153imp_le(nat) ).

tff(tcon_Nat_Onat___Bit__Operations_Osemiring__bit__operations_26,axiom,
    bit_se359711467146920520ations(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__comm__semiring__strict_27,axiom,
    linord2810124833399127020strict(nat) ).

tff(tcon_Nat_Onat___Groups_Ostrict__ordered__comm__monoid__add_28,axiom,
    strict7427464778891057005id_add(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__cancel__comm__monoid__add_29,axiom,
    ordere8940638589300402666id_add(nat) ).

tff(tcon_Nat_Onat___Groups_Ocanonically__ordered__monoid__add,axiom,
    canoni5634975068530333245id_add(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Oeuclidean__semiring_30,axiom,
    euclid3725896446679973847miring(nat) ).

tff(tcon_Nat_Onat___Groups_Olinordered__ab__semigroup__add_31,axiom,
    linord4140545234300271783up_add(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__nonzero__semiring_32,axiom,
    linord181362715937106298miring(nat) ).

tff(tcon_Nat_Onat___Rings_Osemidom__divide__unit__factor_33,axiom,
    semido2269285787275462019factor(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__semiring__strict_34,axiom,
    linord8928482502909563296strict(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__no__zero__divisors_35,axiom,
    semiri3467727345109120633visors(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add_36,axiom,
    ordere6658533253407199908up_add(nat) ).

tff(tcon_Nat_Onat___GCD_Osemiring__gcd__mult__normalize_37,axiom,
    semiri6843258321239162965malize(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__comm__monoid__add_38,axiom,
    ordere6911136660526730532id_add(nat) ).

tff(tcon_Nat_Onat___Groups_Ocancel__ab__semigroup__add_39,axiom,
    cancel2418104881723323429up_add(nat) ).

tff(tcon_Nat_Onat___Groups_Ocancel__comm__monoid__add_40,axiom,
    cancel1802427076303600483id_add(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring__1__cancel_41,axiom,
    comm_s4317794764714335236cancel(nat) ).

tff(tcon_Nat_Onat___Bit__Operations_Osemiring__bits_42,axiom,
    bit_semiring_bits(nat) ).

tff(tcon_Nat_Onat___Rings_Oordered__comm__semiring_43,axiom,
    ordere2520102378445227354miring(nat) ).

tff(tcon_Nat_Onat___Rings_Onormalization__semidom_44,axiom,
    normal8620421768224518004emidom(nat) ).

tff(tcon_Nat_Onat___Groups_Ocancel__semigroup__add_45,axiom,
    cancel_semigroup_add(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__semiring_46,axiom,
    linordered_semiring(nat) ).

tff(tcon_Nat_Onat___Rings_Oordered__semiring__0_47,axiom,
    ordered_semiring_0(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__semidom_48,axiom,
    linordered_semidom(nat) ).

tff(tcon_Nat_Onat___Lattices_Osemilattice__sup_49,axiom,
    semilattice_sup(nat) ).

tff(tcon_Nat_Onat___Lattices_Osemilattice__inf_50,axiom,
    semilattice_inf(nat) ).

tff(tcon_Nat_Onat___Lattices_Odistrib__lattice_51,axiom,
    distrib_lattice(nat) ).

tff(tcon_Nat_Onat___Groups_Oab__semigroup__mult_52,axiom,
    ab_semigroup_mult(nat) ).

tff(tcon_Nat_Onat___Rings_Oalgebraic__semidom_53,axiom,
    algebraic_semidom(nat) ).

tff(tcon_Nat_Onat___Groups_Ocomm__monoid__mult_54,axiom,
    comm_monoid_mult(nat) ).

tff(tcon_Nat_Onat___Groups_Ocomm__monoid__diff,axiom,
    comm_monoid_diff(nat) ).

tff(tcon_Nat_Onat___Groups_Oab__semigroup__add_55,axiom,
    ab_semigroup_add(nat) ).

tff(tcon_Nat_Onat___Rings_Oordered__semiring_56,axiom,
    ordered_semiring(nat) ).

tff(tcon_Nat_Onat___Parity_Osemiring__parity_57,axiom,
    semiring_parity(nat) ).

tff(tcon_Nat_Onat___Groups_Ocomm__monoid__add_58,axiom,
    comm_monoid_add(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__modulo_59,axiom,
    semiring_modulo(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring__1_60,axiom,
    comm_semiring_1(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring__0_61,axiom,
    comm_semiring_0(nat) ).

tff(tcon_Nat_Onat___Groups_Osemigroup__mult_62,axiom,
    semigroup_mult(nat) ).

tff(tcon_Nat_Onat___Rings_Osemidom__modulo_63,axiom,
    semidom_modulo(nat) ).

tff(tcon_Nat_Onat___Rings_Osemidom__divide_64,axiom,
    semidom_divide(nat) ).

tff(tcon_Nat_Onat___Num_Osemiring__numeral_65,axiom,
    semiring_numeral(nat) ).

tff(tcon_Nat_Onat___Groups_Osemigroup__add_66,axiom,
    semigroup_add(nat) ).

tff(tcon_Nat_Onat___Rings_Ozero__less__one_67,axiom,
    zero_less_one(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring_68,axiom,
    comm_semiring(nat) ).

tff(tcon_Nat_Onat___Orderings_Owellorder,axiom,
    wellorder(nat) ).

tff(tcon_Nat_Onat___Orderings_Oorder__bot_69,axiom,
    order_bot(nat) ).

tff(tcon_Nat_Onat___Nat_Osemiring__char__0_70,axiom,
    semiring_char_0(nat) ).

tff(tcon_Nat_Onat___Rings_Ozero__neq__one_71,axiom,
    zero_neq_one(nat) ).

tff(tcon_Nat_Onat___Orderings_Opreorder_72,axiom,
    preorder(nat) ).

tff(tcon_Nat_Onat___Orderings_Olinorder_73,axiom,
    linorder(nat) ).

tff(tcon_Nat_Onat___Groups_Omonoid__mult_74,axiom,
    monoid_mult(nat) ).

tff(tcon_Nat_Onat___Groups_Omonoid__add_75,axiom,
    monoid_add(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__1_76,axiom,
    semiring_1(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__0_77,axiom,
    semiring_0(nat) ).

tff(tcon_Nat_Onat___Orderings_Ono__top_78,axiom,
    no_top(nat) ).

tff(tcon_Nat_Onat___Lattices_Olattice_79,axiom,
    lattice(nat) ).

tff(tcon_Nat_Onat___GCD_Osemiring__gcd_80,axiom,
    semiring_gcd(nat) ).

tff(tcon_Nat_Onat___GCD_Osemiring__Gcd_81,axiom,
    semiring_Gcd(nat) ).

tff(tcon_Nat_Onat___Rings_Omult__zero_82,axiom,
    mult_zero(nat) ).

tff(tcon_Nat_Onat___Orderings_Oorder_83,axiom,
    order(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring_84,axiom,
    semiring(nat) ).

tff(tcon_Nat_Onat___Orderings_Oord_85,axiom,
    ord(nat) ).

tff(tcon_Nat_Onat___Orderings_Obot_86,axiom,
    bot(nat) ).

tff(tcon_Nat_Onat___Lattices_Oinf_87,axiom,
    inf(nat) ).

tff(tcon_Nat_Onat___Groups_Otimes_88,axiom,
    times(nat) ).

tff(tcon_Nat_Onat___Groups_Ominus_89,axiom,
    minus(nat) ).

tff(tcon_Nat_Onat___Power_Opower_90,axiom,
    power(nat) ).

tff(tcon_Nat_Onat___Num_Onumeral_91,axiom,
    numeral(nat) ).

tff(tcon_Nat_Onat___Groups_Ozero_92,axiom,
    zero(nat) ).

tff(tcon_Nat_Onat___Groups_Oone_93,axiom,
    one(nat) ).

tff(tcon_Nat_Onat___Rings_Odvd_94,axiom,
    dvd(nat) ).

tff(tcon_Nat_Onat___Heap_Oheap_95,axiom,
    heap(nat) ).

tff(tcon_Num_Onum___Orderings_Opreorder_96,axiom,
    preorder(num) ).

tff(tcon_Num_Onum___Orderings_Olinorder_97,axiom,
    linorder(num) ).

tff(tcon_Num_Onum___Orderings_Oorder_98,axiom,
    order(num) ).

tff(tcon_Num_Onum___Orderings_Oord_99,axiom,
    ord(num) ).

tff(tcon_Num_Onum___Groups_Otimes_100,axiom,
    times(num) ).

tff(tcon_Rat_Orat___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_101,axiom,
    semiri1453513574482234551roduct(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__semigroup__monoid__add__imp__le_102,axiom,
    ordere1937475149494474687imp_le(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__no__zero__divisors__cancel_103,axiom,
    semiri6575147826004484403cancel(rat) ).

tff(tcon_Rat_Orat___Groups_Ostrict__ordered__ab__semigroup__add_104,axiom,
    strict9044650504122735259up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__cancel__ab__semigroup__add_105,axiom,
    ordere580206878836729694up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__semigroup__add__imp__le_106,axiom,
    ordere2412721322843649153imp_le(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__comm__semiring__strict_107,axiom,
    linord2810124833399127020strict(rat) ).

tff(tcon_Rat_Orat___Groups_Ostrict__ordered__comm__monoid__add_108,axiom,
    strict7427464778891057005id_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__cancel__comm__monoid__add_109,axiom,
    ordere8940638589300402666id_add(rat) ).

tff(tcon_Rat_Orat___Archimedean__Field_Oarchimedean__field,axiom,
    archim462609752435547400_field(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semiring__1__strict_110,axiom,
    linord715952674999750819strict(rat) ).

tff(tcon_Rat_Orat___Groups_Olinordered__ab__semigroup__add_111,axiom,
    linord4140545234300271783up_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__nonzero__semiring_112,axiom,
    linord181362715937106298miring(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semiring__strict_113,axiom,
    linord8928482502909563296strict(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__no__zero__divisors_114,axiom,
    semiri3467727345109120633visors(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__semigroup__add_115,axiom,
    ordere6658533253407199908up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__group__add__abs_116,axiom,
    ordere166539214618696060dd_abs(rat) ).

tff(tcon_Rat_Orat___Archimedean__Field_Ofloor__ceiling,axiom,
    archim2362893244070406136eiling(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__comm__monoid__add_117,axiom,
    ordere6911136660526730532id_add(rat) ).

tff(tcon_Rat_Orat___Groups_Olinordered__ab__group__add_118,axiom,
    linord5086331880401160121up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Ocancel__ab__semigroup__add_119,axiom,
    cancel2418104881723323429up_add(rat) ).

tff(tcon_Rat_Orat___Rings_Oring__1__no__zero__divisors_120,axiom,
    ring_15535105094025558882visors(rat) ).

tff(tcon_Rat_Orat___Groups_Ocancel__comm__monoid__add_121,axiom,
    cancel1802427076303600483id_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__ring__strict_122,axiom,
    linord4710134922213307826strict(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring__1__cancel_123,axiom,
    comm_s4317794764714335236cancel(rat) ).

tff(tcon_Rat_Orat___Rings_Oordered__comm__semiring_124,axiom,
    ordere2520102378445227354miring(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semiring__1_125,axiom,
    linord6961819062388156250ring_1(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__group__add_126,axiom,
    ordered_ab_group_add(rat) ).

tff(tcon_Rat_Orat___Groups_Ocancel__semigroup__add_127,axiom,
    cancel_semigroup_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semiring_128,axiom,
    linordered_semiring(rat) ).

tff(tcon_Rat_Orat___Rings_Oordered__semiring__0_129,axiom,
    ordered_semiring_0(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semidom_130,axiom,
    linordered_semidom(rat) ).

tff(tcon_Rat_Orat___Orderings_Odense__linorder,axiom,
    dense_linorder(rat) ).

tff(tcon_Rat_Orat___Lattices_Osemilattice__sup_131,axiom,
    semilattice_sup(rat) ).

tff(tcon_Rat_Orat___Lattices_Osemilattice__inf_132,axiom,
    semilattice_inf(rat) ).

tff(tcon_Rat_Orat___Lattices_Odistrib__lattice_133,axiom,
    distrib_lattice(rat) ).

tff(tcon_Rat_Orat___Groups_Oab__semigroup__mult_134,axiom,
    ab_semigroup_mult(rat) ).

tff(tcon_Rat_Orat___Groups_Ocomm__monoid__mult_135,axiom,
    comm_monoid_mult(rat) ).

tff(tcon_Rat_Orat___Groups_Oab__semigroup__add_136,axiom,
    ab_semigroup_add(rat) ).

tff(tcon_Rat_Orat___Fields_Olinordered__field,axiom,
    linordered_field(rat) ).

tff(tcon_Rat_Orat___Rings_Oordered__semiring_137,axiom,
    ordered_semiring(rat) ).

tff(tcon_Rat_Orat___Rings_Oordered__ring__abs_138,axiom,
    ordered_ring_abs(rat) ).

tff(tcon_Rat_Orat___Groups_Ocomm__monoid__add_139,axiom,
    comm_monoid_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__ring_140,axiom,
    linordered_ring(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__idom_141,axiom,
    linordered_idom(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring__1_142,axiom,
    comm_semiring_1(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring__0_143,axiom,
    comm_semiring_0(rat) ).

tff(tcon_Rat_Orat___Orderings_Odense__order,axiom,
    dense_order(rat) ).

tff(tcon_Rat_Orat___Groups_Osemigroup__mult_144,axiom,
    semigroup_mult(rat) ).

tff(tcon_Rat_Orat___Rings_Osemidom__divide_145,axiom,
    semidom_divide(rat) ).

tff(tcon_Rat_Orat___Num_Osemiring__numeral_146,axiom,
    semiring_numeral(rat) ).

tff(tcon_Rat_Orat___Groups_Osemigroup__add_147,axiom,
    semigroup_add(rat) ).

tff(tcon_Rat_Orat___Fields_Odivision__ring,axiom,
    division_ring(rat) ).

tff(tcon_Rat_Orat___Rings_Ozero__less__one_148,axiom,
    zero_less_one(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring_149,axiom,
    comm_semiring(rat) ).

tff(tcon_Rat_Orat___Nat_Osemiring__char__0_150,axiom,
    semiring_char_0(rat) ).

tff(tcon_Rat_Orat___Groups_Oab__group__add_151,axiom,
    ab_group_add(rat) ).

tff(tcon_Rat_Orat___Fields_Ofield__char__0,axiom,
    field_char_0(rat) ).

tff(tcon_Rat_Orat___Rings_Ozero__neq__one_152,axiom,
    zero_neq_one(rat) ).

tff(tcon_Rat_Orat___Rings_Oordered__ring_153,axiom,
    ordered_ring(rat) ).

tff(tcon_Rat_Orat___Rings_Oidom__abs__sgn_154,axiom,
    idom_abs_sgn(rat) ).

tff(tcon_Rat_Orat___Orderings_Opreorder_155,axiom,
    preorder(rat) ).

tff(tcon_Rat_Orat___Orderings_Olinorder_156,axiom,
    linorder(rat) ).

tff(tcon_Rat_Orat___Groups_Omonoid__mult_157,axiom,
    monoid_mult(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__ring__1_158,axiom,
    comm_ring_1(rat) ).

tff(tcon_Rat_Orat___Groups_Omonoid__add_159,axiom,
    monoid_add(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__1_160,axiom,
    semiring_1(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__0_161,axiom,
    semiring_0(rat) ).

tff(tcon_Rat_Orat___Orderings_Ono__top_162,axiom,
    no_top(rat) ).

tff(tcon_Rat_Orat___Orderings_Ono__bot_163,axiom,
    no_bot(rat) ).

tff(tcon_Rat_Orat___Lattices_Olattice_164,axiom,
    lattice(rat) ).

tff(tcon_Rat_Orat___Groups_Ogroup__add_165,axiom,
    group_add(rat) ).

tff(tcon_Rat_Orat___Rings_Omult__zero_166,axiom,
    mult_zero(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__ring_167,axiom,
    comm_ring(rat) ).

tff(tcon_Rat_Orat___Orderings_Oorder_168,axiom,
    order(rat) ).

tff(tcon_Rat_Orat___Num_Oneg__numeral_169,axiom,
    neg_numeral(rat) ).

tff(tcon_Rat_Orat___Nat_Oring__char__0_170,axiom,
    ring_char_0(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring_171,axiom,
    semiring(rat) ).

tff(tcon_Rat_Orat___Fields_Oinverse,axiom,
    inverse(rat) ).

tff(tcon_Rat_Orat___Orderings_Oord_172,axiom,
    ord(rat) ).

tff(tcon_Rat_Orat___Groups_Ouminus_173,axiom,
    uminus(rat) ).

tff(tcon_Rat_Orat___Rings_Oring__1_174,axiom,
    ring_1(rat) ).

tff(tcon_Rat_Orat___Lattices_Oinf_175,axiom,
    inf(rat) ).

tff(tcon_Rat_Orat___Groups_Otimes_176,axiom,
    times(rat) ).

tff(tcon_Rat_Orat___Groups_Ominus_177,axiom,
    minus(rat) ).

tff(tcon_Rat_Orat___Fields_Ofield,axiom,
    field(rat) ).

tff(tcon_Rat_Orat___Power_Opower_178,axiom,
    power(rat) ).

tff(tcon_Rat_Orat___Num_Onumeral_179,axiom,
    numeral(rat) ).

tff(tcon_Rat_Orat___Groups_Ozero_180,axiom,
    zero(rat) ).

tff(tcon_Rat_Orat___Rings_Oring_181,axiom,
    ring(rat) ).

tff(tcon_Rat_Orat___Rings_Oidom_182,axiom,
    idom(rat) ).

tff(tcon_Rat_Orat___Groups_Oone_183,axiom,
    one(rat) ).

tff(tcon_Rat_Orat___Rings_Odvd_184,axiom,
    dvd(rat) ).

tff(tcon_Set_Oset___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_185,axiom,
    ! [A18: $tType] : condit1219197933456340205attice(set(A18)) ).

tff(tcon_Set_Oset___Complete__Lattices_Ocomplete__distrib__lattice_186,axiom,
    ! [A18: $tType] : comple592849572758109894attice(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Obounded__semilattice__sup__bot_187,axiom,
    ! [A18: $tType] : bounde4967611905675639751up_bot(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Obounded__semilattice__inf__top_188,axiom,
    ! [A18: $tType] : bounde4346867609351753570nf_top(set(A18)) ).

tff(tcon_Set_Oset___Complete__Lattices_Ocomplete__lattice_189,axiom,
    ! [A18: $tType] : comple6319245703460814977attice(set(A18)) ).

tff(tcon_Set_Oset___Boolean__Algebras_Oboolean__algebra_190,axiom,
    ! [A18: $tType] : boolea8198339166811842893lgebra(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Obounded__lattice__top_191,axiom,
    ! [A18: $tType] : bounded_lattice_top(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Obounded__lattice__bot_192,axiom,
    ! [A18: $tType] : bounded_lattice_bot(set(A18)) ).

tff(tcon_Set_Oset___Complete__Partial__Order_Occpo_193,axiom,
    ! [A18: $tType] : comple9053668089753744459l_ccpo(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Osemilattice__sup_194,axiom,
    ! [A18: $tType] : semilattice_sup(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Osemilattice__inf_195,axiom,
    ! [A18: $tType] : semilattice_inf(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Odistrib__lattice_196,axiom,
    ! [A18: $tType] : distrib_lattice(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Obounded__lattice_197,axiom,
    ! [A18: $tType] : bounded_lattice(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Oorder__top_198,axiom,
    ! [A18: $tType] : order_top(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Oorder__bot_199,axiom,
    ! [A18: $tType] : order_bot(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Opreorder_200,axiom,
    ! [A18: $tType] : preorder(set(A18)) ).

tff(tcon_Set_Oset___Finite__Set_Ofinite_201,axiom,
    ! [A18: $tType] :
      ( finite_finite(A18)
     => finite_finite(set(A18)) ) ).

tff(tcon_Set_Oset___Lattices_Olattice_202,axiom,
    ! [A18: $tType] : lattice(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Oorder_203,axiom,
    ! [A18: $tType] : order(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Otop_204,axiom,
    ! [A18: $tType] : top(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Oord_205,axiom,
    ! [A18: $tType] : ord(set(A18)) ).

tff(tcon_Set_Oset___Orderings_Obot_206,axiom,
    ! [A18: $tType] : bot(set(A18)) ).

tff(tcon_Set_Oset___Groups_Ouminus_207,axiom,
    ! [A18: $tType] : uminus(set(A18)) ).

tff(tcon_Set_Oset___Lattices_Oinf_208,axiom,
    ! [A18: $tType] : inf(set(A18)) ).

tff(tcon_Set_Oset___Groups_Ominus_209,axiom,
    ! [A18: $tType] : minus(set(A18)) ).

tff(tcon_HOL_Obool___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_210,axiom,
    condit1219197933456340205attice($o) ).

tff(tcon_HOL_Obool___Complete__Lattices_Ocomplete__distrib__lattice_211,axiom,
    comple592849572758109894attice($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__semilattice__sup__bot_212,axiom,
    bounde4967611905675639751up_bot($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__semilattice__inf__top_213,axiom,
    bounde4346867609351753570nf_top($o) ).

tff(tcon_HOL_Obool___Complete__Lattices_Ocomplete__lattice_214,axiom,
    comple6319245703460814977attice($o) ).

tff(tcon_HOL_Obool___Boolean__Algebras_Oboolean__algebra_215,axiom,
    boolea8198339166811842893lgebra($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__lattice__top_216,axiom,
    bounded_lattice_top($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__lattice__bot_217,axiom,
    bounded_lattice_bot($o) ).

tff(tcon_HOL_Obool___Complete__Partial__Order_Occpo_218,axiom,
    comple9053668089753744459l_ccpo($o) ).

tff(tcon_HOL_Obool___Lattices_Osemilattice__sup_219,axiom,
    semilattice_sup($o) ).

tff(tcon_HOL_Obool___Lattices_Osemilattice__inf_220,axiom,
    semilattice_inf($o) ).

tff(tcon_HOL_Obool___Lattices_Odistrib__lattice_221,axiom,
    distrib_lattice($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__lattice_222,axiom,
    bounded_lattice($o) ).

tff(tcon_HOL_Obool___Orderings_Oorder__top_223,axiom,
    order_top($o) ).

tff(tcon_HOL_Obool___Orderings_Oorder__bot_224,axiom,
    order_bot($o) ).

tff(tcon_HOL_Obool___Orderings_Opreorder_225,axiom,
    preorder($o) ).

tff(tcon_HOL_Obool___Orderings_Olinorder_226,axiom,
    linorder($o) ).

tff(tcon_HOL_Obool___Finite__Set_Ofinite_227,axiom,
    finite_finite($o) ).

tff(tcon_HOL_Obool___Lattices_Olattice_228,axiom,
    lattice($o) ).

tff(tcon_HOL_Obool___Orderings_Oorder_229,axiom,
    order($o) ).

tff(tcon_HOL_Obool___Orderings_Otop_230,axiom,
    top($o) ).

tff(tcon_HOL_Obool___Orderings_Oord_231,axiom,
    ord($o) ).

tff(tcon_HOL_Obool___Orderings_Obot_232,axiom,
    bot($o) ).

tff(tcon_HOL_Obool___Groups_Ouminus_233,axiom,
    uminus($o) ).

tff(tcon_HOL_Obool___Lattices_Oinf_234,axiom,
    inf($o) ).

tff(tcon_HOL_Obool___Groups_Ominus_235,axiom,
    minus($o) ).

tff(tcon_HOL_Obool___Heap_Oheap_236,axiom,
    heap($o) ).

tff(tcon_Heap_Oref___Heap_Oheap_237,axiom,
    ! [A18: $tType] : heap(ref(A18)) ).

tff(tcon_List_Olist___Heap_Oheap_238,axiom,
    ! [A18: $tType] :
      ( heap(A18)
     => heap(list(A18)) ) ).

tff(tcon_Heap_Oarray___Heap_Oheap_239,axiom,
    ! [A18: $tType] : heap(array(A18)) ).

tff(tcon_Sum__Type_Osum___Finite__Set_Ofinite_240,axiom,
    ! [A18: $tType,A19: $tType] :
      ( ( finite_finite(A18)
        & finite_finite(A19) )
     => finite_finite(sum_sum(A18,A19)) ) ).

tff(tcon_Sum__Type_Osum___Heap_Oheap_241,axiom,
    ! [A18: $tType,A19: $tType] :
      ( ( heap(A18)
        & heap(A19) )
     => heap(sum_sum(A18,A19)) ) ).

tff(tcon_Filter_Ofilter___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_242,axiom,
    ! [A18: $tType] : condit1219197933456340205attice(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Obounded__semilattice__sup__bot_243,axiom,
    ! [A18: $tType] : bounde4967611905675639751up_bot(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Obounded__semilattice__inf__top_244,axiom,
    ! [A18: $tType] : bounde4346867609351753570nf_top(filter(A18)) ).

tff(tcon_Filter_Ofilter___Complete__Lattices_Ocomplete__lattice_245,axiom,
    ! [A18: $tType] : comple6319245703460814977attice(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Obounded__lattice__top_246,axiom,
    ! [A18: $tType] : bounded_lattice_top(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Obounded__lattice__bot_247,axiom,
    ! [A18: $tType] : bounded_lattice_bot(filter(A18)) ).

tff(tcon_Filter_Ofilter___Complete__Partial__Order_Occpo_248,axiom,
    ! [A18: $tType] : comple9053668089753744459l_ccpo(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Osemilattice__sup_249,axiom,
    ! [A18: $tType] : semilattice_sup(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Osemilattice__inf_250,axiom,
    ! [A18: $tType] : semilattice_inf(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Odistrib__lattice_251,axiom,
    ! [A18: $tType] : distrib_lattice(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Obounded__lattice_252,axiom,
    ! [A18: $tType] : bounded_lattice(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Oorder__top_253,axiom,
    ! [A18: $tType] : order_top(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Oorder__bot_254,axiom,
    ! [A18: $tType] : order_bot(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Opreorder_255,axiom,
    ! [A18: $tType] : preorder(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Olattice_256,axiom,
    ! [A18: $tType] : lattice(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Oorder_257,axiom,
    ! [A18: $tType] : order(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Otop_258,axiom,
    ! [A18: $tType] : top(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Oord_259,axiom,
    ! [A18: $tType] : ord(filter(A18)) ).

tff(tcon_Filter_Ofilter___Orderings_Obot_260,axiom,
    ! [A18: $tType] : bot(filter(A18)) ).

tff(tcon_Filter_Ofilter___Lattices_Oinf_261,axiom,
    ! [A18: $tType] : inf(filter(A18)) ).

tff(tcon_Option_Ooption___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_262,axiom,
    ! [A18: $tType] :
      ( comple5582772986160207858norder(A18)
     => condit6923001295902523014norder(option(A18)) ) ).

tff(tcon_Option_Ooption___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_263,axiom,
    ! [A18: $tType] :
      ( comple6319245703460814977attice(A18)
     => condit1219197933456340205attice(option(A18)) ) ).

tff(tcon_Option_Ooption___Complete__Lattices_Ocomplete__distrib__lattice_264,axiom,
    ! [A18: $tType] :
      ( comple592849572758109894attice(A18)
     => comple592849572758109894attice(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__semilattice__sup__bot_265,axiom,
    ! [A18: $tType] :
      ( lattice(A18)
     => bounde4967611905675639751up_bot(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__semilattice__inf__top_266,axiom,
    ! [A18: $tType] :
      ( bounded_lattice_top(A18)
     => bounde4346867609351753570nf_top(option(A18)) ) ).

tff(tcon_Option_Ooption___Complete__Lattices_Ocomplete__linorder,axiom,
    ! [A18: $tType] :
      ( comple5582772986160207858norder(A18)
     => comple5582772986160207858norder(option(A18)) ) ).

tff(tcon_Option_Ooption___Complete__Lattices_Ocomplete__lattice_267,axiom,
    ! [A18: $tType] :
      ( comple6319245703460814977attice(A18)
     => comple6319245703460814977attice(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__lattice__top_268,axiom,
    ! [A18: $tType] :
      ( bounded_lattice_top(A18)
     => bounded_lattice_top(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__lattice__bot_269,axiom,
    ! [A18: $tType] :
      ( lattice(A18)
     => bounded_lattice_bot(option(A18)) ) ).

tff(tcon_Option_Ooption___Complete__Partial__Order_Occpo_270,axiom,
    ! [A18: $tType] :
      ( comple6319245703460814977attice(A18)
     => comple9053668089753744459l_ccpo(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Osemilattice__sup_271,axiom,
    ! [A18: $tType] :
      ( semilattice_sup(A18)
     => semilattice_sup(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Osemilattice__inf_272,axiom,
    ! [A18: $tType] :
      ( semilattice_inf(A18)
     => semilattice_inf(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Odistrib__lattice_273,axiom,
    ! [A18: $tType] :
      ( distrib_lattice(A18)
     => distrib_lattice(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__lattice_274,axiom,
    ! [A18: $tType] :
      ( bounded_lattice_top(A18)
     => bounded_lattice(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Owellorder_275,axiom,
    ! [A18: $tType] :
      ( wellorder(A18)
     => wellorder(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Oorder__top_276,axiom,
    ! [A18: $tType] :
      ( order_top(A18)
     => order_top(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Oorder__bot_277,axiom,
    ! [A18: $tType] :
      ( order(A18)
     => order_bot(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Opreorder_278,axiom,
    ! [A18: $tType] :
      ( preorder(A18)
     => preorder(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Olinorder_279,axiom,
    ! [A18: $tType] :
      ( linorder(A18)
     => linorder(option(A18)) ) ).

tff(tcon_Option_Ooption___Finite__Set_Ofinite_280,axiom,
    ! [A18: $tType] :
      ( finite_finite(A18)
     => finite_finite(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Olattice_281,axiom,
    ! [A18: $tType] :
      ( lattice(A18)
     => lattice(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Oorder_282,axiom,
    ! [A18: $tType] :
      ( order(A18)
     => order(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Otop_283,axiom,
    ! [A18: $tType] :
      ( order_top(A18)
     => top(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Oord_284,axiom,
    ! [A18: $tType] :
      ( preorder(A18)
     => ord(option(A18)) ) ).

tff(tcon_Option_Ooption___Orderings_Obot_285,axiom,
    ! [A18: $tType] :
      ( order(A18)
     => bot(option(A18)) ) ).

tff(tcon_Option_Ooption___Lattices_Oinf_286,axiom,
    ! [A18: $tType] :
      ( inf(A18)
     => inf(option(A18)) ) ).

tff(tcon_Option_Ooption___Heap_Oheap_287,axiom,
    ! [A18: $tType] :
      ( heap(A18)
     => heap(option(A18)) ) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__semilattice__sup__bot_288,axiom,
    bounde4967611905675639751up_bot(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__semilattice__inf__top_289,axiom,
    bounde4346867609351753570nf_top(assn) ).

tff(tcon_Assertions_Oassn___Boolean__Algebras_Oboolean__algebra_290,axiom,
    boolea8198339166811842893lgebra(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__lattice__top_291,axiom,
    bounded_lattice_top(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__lattice__bot_292,axiom,
    bounded_lattice_bot(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Osemilattice__sup_293,axiom,
    semilattice_sup(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Osemilattice__inf_294,axiom,
    semilattice_inf(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Odistrib__lattice_295,axiom,
    distrib_lattice(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__lattice_296,axiom,
    bounded_lattice(assn) ).

tff(tcon_Assertions_Oassn___Groups_Oab__semigroup__mult_297,axiom,
    ab_semigroup_mult(assn) ).

tff(tcon_Assertions_Oassn___Groups_Ocomm__monoid__mult_298,axiom,
    comm_monoid_mult(assn) ).

tff(tcon_Assertions_Oassn___Groups_Osemigroup__mult_299,axiom,
    semigroup_mult(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oorder__top_300,axiom,
    order_top(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oorder__bot_301,axiom,
    order_bot(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Opreorder_302,axiom,
    preorder(assn) ).

tff(tcon_Assertions_Oassn___Groups_Omonoid__mult_303,axiom,
    monoid_mult(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Olattice_304,axiom,
    lattice(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oorder_305,axiom,
    order(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Otop_306,axiom,
    top(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oord_307,axiom,
    ord(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Obot_308,axiom,
    bot(assn) ).

tff(tcon_Assertions_Oassn___Groups_Ouminus_309,axiom,
    uminus(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Oinf_310,axiom,
    inf(assn) ).

tff(tcon_Assertions_Oassn___Groups_Otimes_311,axiom,
    times(assn) ).

tff(tcon_Assertions_Oassn___Groups_Ominus_312,axiom,
    minus(assn) ).

tff(tcon_Assertions_Oassn___Power_Opower_313,axiom,
    power(assn) ).

tff(tcon_Assertions_Oassn___Groups_Oone_314,axiom,
    one(assn) ).

tff(tcon_Assertions_Oassn___Rings_Odvd_315,axiom,
    dvd(assn) ).

tff(tcon_Typerep_Otyperep___Heap_Oheap_316,axiom,
    heap(typerep) ).

tff(tcon_Multiset_Omultiset___Groups_Oordered__ab__semigroup__add_317,axiom,
    ! [A18: $tType] :
      ( preorder(A18)
     => ordere6658533253407199908up_add(multiset(A18)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Ocancel__ab__semigroup__add_318,axiom,
    ! [A18: $tType] : cancel2418104881723323429up_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocancel__comm__monoid__add_319,axiom,
    ! [A18: $tType] : cancel1802427076303600483id_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocancel__semigroup__add_320,axiom,
    ! [A18: $tType] : cancel_semigroup_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocomm__monoid__diff_321,axiom,
    ! [A18: $tType] : comm_monoid_diff(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Oab__semigroup__add_322,axiom,
    ! [A18: $tType] : ab_semigroup_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocomm__monoid__add_323,axiom,
    ! [A18: $tType] : comm_monoid_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Osemigroup__add_324,axiom,
    ! [A18: $tType] : semigroup_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Orderings_Opreorder_325,axiom,
    ! [A18: $tType] :
      ( preorder(A18)
     => preorder(multiset(A18)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Omonoid__add_326,axiom,
    ! [A18: $tType] : monoid_add(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Orderings_Oorder_327,axiom,
    ! [A18: $tType] :
      ( preorder(A18)
     => order(multiset(A18)) ) ).

tff(tcon_Multiset_Omultiset___Orderings_Oord_328,axiom,
    ! [A18: $tType] :
      ( preorder(A18)
     => ord(multiset(A18)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Ominus_329,axiom,
    ! [A18: $tType] : minus(multiset(A18)) ).

tff(tcon_Multiset_Omultiset___Groups_Ozero_330,axiom,
    ! [A18: $tType] : zero(multiset(A18)) ).

tff(tcon_Product__Type_Oprod___Finite__Set_Ofinite_331,axiom,
    ! [A18: $tType,A19: $tType] :
      ( ( finite_finite(A18)
        & finite_finite(A19) )
     => finite_finite(product_prod(A18,A19)) ) ).

tff(tcon_Product__Type_Oprod___Heap_Oheap_332,axiom,
    ! [A18: $tType,A19: $tType] :
      ( ( heap(A18)
        & heap(A19) )
     => heap(product_prod(A18,A19)) ) ).

tff(tcon_Product__Type_Ounit___Conditionally__Complete__Lattices_Oconditionally__complete__linorder_333,axiom,
    condit6923001295902523014norder(product_unit) ).

tff(tcon_Product__Type_Ounit___Conditionally__Complete__Lattices_Oconditionally__complete__lattice_334,axiom,
    condit1219197933456340205attice(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__distrib__lattice_335,axiom,
    comple592849572758109894attice(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__semilattice__sup__bot_336,axiom,
    bounde4967611905675639751up_bot(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__semilattice__inf__top_337,axiom,
    bounde4346867609351753570nf_top(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__linorder_338,axiom,
    comple5582772986160207858norder(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__lattice_339,axiom,
    comple6319245703460814977attice(product_unit) ).

tff(tcon_Product__Type_Ounit___Boolean__Algebras_Oboolean__algebra_340,axiom,
    boolea8198339166811842893lgebra(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__lattice__top_341,axiom,
    bounded_lattice_top(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__lattice__bot_342,axiom,
    bounded_lattice_bot(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Partial__Order_Occpo_343,axiom,
    comple9053668089753744459l_ccpo(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Osemilattice__sup_344,axiom,
    semilattice_sup(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Osemilattice__inf_345,axiom,
    semilattice_inf(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Odistrib__lattice_346,axiom,
    distrib_lattice(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__lattice_347,axiom,
    bounded_lattice(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Owellorder_348,axiom,
    wellorder(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oorder__top_349,axiom,
    order_top(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oorder__bot_350,axiom,
    order_bot(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Opreorder_351,axiom,
    preorder(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Olinorder_352,axiom,
    linorder(product_unit) ).

tff(tcon_Product__Type_Ounit___Finite__Set_Ofinite_353,axiom,
    finite_finite(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Olattice_354,axiom,
    lattice(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oorder_355,axiom,
    order(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Otop_356,axiom,
    top(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oord_357,axiom,
    ord(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Obot_358,axiom,
    bot(product_unit) ).

tff(tcon_Product__Type_Ounit___Groups_Ouminus_359,axiom,
    uminus(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Oinf_360,axiom,
    inf(product_unit) ).

tff(tcon_Product__Type_Ounit___Groups_Ominus_361,axiom,
    minus(product_unit) ).

tff(tcon_Product__Type_Ounit___Heap_Oheap_362,axiom,
    heap(product_unit) ).

tff(tcon_Code__Numeral_Onatural___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations_363,axiom,
    bit_un5681908812861735899ations(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Ounique__euclidean__semiring__with__nat_364,axiom,
    euclid5411537665997757685th_nat(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__ab__semigroup__monoid__add__imp__le_365,axiom,
    ordere1937475149494474687imp_le(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Ounique__euclidean__semiring_366,axiom,
    euclid3128863361964157862miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Oeuclidean__semiring__cancel_367,axiom,
    euclid4440199948858584721cancel(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__no__zero__divisors__cancel_368,axiom,
    semiri6575147826004484403cancel(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ostrict__ordered__ab__semigroup__add_369,axiom,
    strict9044650504122735259up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__cancel__ab__semigroup__add_370,axiom,
    ordere580206878836729694up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__ab__semigroup__add__imp__le_371,axiom,
    ordere2412721322843649153imp_le(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Bit__Operations_Osemiring__bit__operations_372,axiom,
    bit_se359711467146920520ations(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__comm__semiring__strict_373,axiom,
    linord2810124833399127020strict(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ostrict__ordered__comm__monoid__add_374,axiom,
    strict7427464778891057005id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__cancel__comm__monoid__add_375,axiom,
    ordere8940638589300402666id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Oeuclidean__semiring_376,axiom,
    euclid3725896446679973847miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Olinordered__ab__semigroup__add_377,axiom,
    linord4140545234300271783up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__nonzero__semiring_378,axiom,
    linord181362715937106298miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__semiring__strict_379,axiom,
    linord8928482502909563296strict(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__no__zero__divisors_380,axiom,
    semiri3467727345109120633visors(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__ab__semigroup__add_381,axiom,
    ordere6658533253407199908up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__comm__monoid__add_382,axiom,
    ordere6911136660526730532id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocancel__ab__semigroup__add_383,axiom,
    cancel2418104881723323429up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocancel__comm__monoid__add_384,axiom,
    cancel1802427076303600483id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring__1__cancel_385,axiom,
    comm_s4317794764714335236cancel(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Bit__Operations_Osemiring__bits_386,axiom,
    bit_semiring_bits(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Oordered__comm__semiring_387,axiom,
    ordere2520102378445227354miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocancel__semigroup__add_388,axiom,
    cancel_semigroup_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__semiring_389,axiom,
    linordered_semiring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Oordered__semiring__0_390,axiom,
    ordered_semiring_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__semidom_391,axiom,
    linordered_semidom(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oab__semigroup__mult_392,axiom,
    ab_semigroup_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Oalgebraic__semidom_393,axiom,
    algebraic_semidom(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocomm__monoid__mult_394,axiom,
    comm_monoid_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocomm__monoid__diff_395,axiom,
    comm_monoid_diff(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oab__semigroup__add_396,axiom,
    ab_semigroup_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Oordered__semiring_397,axiom,
    ordered_semiring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Parity_Osemiring__parity_398,axiom,
    semiring_parity(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocomm__monoid__add_399,axiom,
    comm_monoid_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__modulo_400,axiom,
    semiring_modulo(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring__1_401,axiom,
    comm_semiring_1(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring__0_402,axiom,
    comm_semiring_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Osemigroup__mult_403,axiom,
    semigroup_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemidom__modulo_404,axiom,
    semidom_modulo(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemidom__divide_405,axiom,
    semidom_divide(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Num_Osemiring__numeral_406,axiom,
    semiring_numeral(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Osemigroup__add_407,axiom,
    semigroup_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ozero__less__one_408,axiom,
    zero_less_one(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring_409,axiom,
    comm_semiring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Nat_Osemiring__char__0_410,axiom,
    semiring_char_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ozero__neq__one_411,axiom,
    zero_neq_one(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Opreorder_412,axiom,
    preorder(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Olinorder_413,axiom,
    linorder(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Omonoid__mult_414,axiom,
    monoid_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Omonoid__add_415,axiom,
    monoid_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__1_416,axiom,
    semiring_1(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__0_417,axiom,
    semiring_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Omult__zero_418,axiom,
    mult_zero(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Oorder_419,axiom,
    order(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring_420,axiom,
    semiring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Oord_421,axiom,
    ord(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Otimes_422,axiom,
    times(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ominus_423,axiom,
    minus(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Power_Opower_424,axiom,
    power(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Num_Onumeral_425,axiom,
    numeral(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ozero_426,axiom,
    zero(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oone_427,axiom,
    one(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Odvd_428,axiom,
    dvd(code_natural) ).

% Helper facts (5)
tff(help_fNot_2_1_U,axiom,
    ! [P7: $o] :
      ( (P7)
      | aa($o,$o,fNot,(P7)) ) ).

tff(help_fNot_1_1_U,axiom,
    ! [P7: $o] :
      ( ~ aa($o,$o,fNot,(P7))
      | ~ (P7) ) ).

tff(help_fequal_2_1_T,axiom,
    ! [A: $tType,X: A,Y: A] :
      ( ( X != Y )
      | aa(A,$o,aa(A,fun(A,$o),fequal(A),X),Y) ) ).

tff(help_fequal_1_1_T,axiom,
    ! [A: $tType,X: A,Y: A] :
      ( ~ aa(A,$o,aa(A,fun(A,$o),fequal(A),X),Y)
      | ( X = Y ) ) ).

tff(help_fChoice_1_1_T,axiom,
    ! [A: $tType,P7: fun(A,$o)] :
      ( aa(A,$o,P7,fChoice(A,P7))
      = ( ? [X9: A] : aa(A,$o,P7,X9) ) ) ).

% Free types (1)
tff(tfree_0,hypothesis,
    linorder(d) ).

% Conjectures (1)
tff(conj_0,conjecture,
    vEBT_List_list_assn(a,b,p,nil(a),l) = pure_assn(l = nil(b)) ).

%------------------------------------------------------------------------------