TPTP Problem File: ITP216_4.p

View Solutions - Solve Problem

%------------------------------------------------------------------------------
% File     : ITP216_4 : TPTP v8.2.0. Released v8.0.0.
% Domain   : Interactive Theorem Proving
% Problem  : Sledgehammer problem Time_Reasoning 00074_002979
% 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    : 0029_Time_Reasoning_00074_002979 [Des22]

% Status   : Theorem
% Rating   : 1.00 v8.1.0
% Syntax   : Number of formulae    : 8886 (3179 unt;1551 typ;   0 def)
%            Number of atoms       : 14142 (6574 equ)
%            Maximal formula atoms :   28 (   1 avg)
%            Number of connectives : 12073 (1664   ~; 173   |; 979   &)
%                                         (1222 <=>;8035  =>;   0  <=;   0 <~>)
%            Maximal formula depth :   31 (   6 avg)
%            Maximal term depth    :   37 (   2 avg)
%            Number of FOOLs       :  540 ( 383 fml; 157 var)
%            Number of X terms     :  316 (   0  []; 290 ite;  26 let)
%            Number of types       :   15 (  14 usr)
%            Number of type conns  : 1500 (1068   >; 432   *;   0   +;   0  <<)
%            Number of predicates  :  260 ( 257 usr;   2 prp; 0-7 aty)
%            Number of functors    : 1293 (1293 usr;  89 con; 0-8 aty)
%            Number of variables   : 27593 (24952   !; 380   ?;27593   :)
%                                         (2261  !>;   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:14:01.973
%------------------------------------------------------------------------------
% Could-be-implicit typings (29)
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_Code__Numeral_Ointeger,type,
    code_integer: $tType ).

tff(ty_t_Code__Evaluation_Oterm,type,
    code_term: $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_Old__Datatype_Onode,type,
    old_node: ( $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_Predicate_Opred,type,
    pred: $tType > $tType ).

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

tff(ty_t_Predicate_Oseq,type,
    seq: $tType > $tType ).

tff(ty_t_Option_Ooption,type,
    option: $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_c,type,
    c: $tType ).

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

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

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

tff(sy_cl_Typerep_Otyperep,type,
    typerep2: 
      !>[A: $tType] : $o ).

tff(sy_cl_Enum_Oenum,type,
    enum: 
      !>[A: $tType] : $o ).

tff(sy_cl_Code__Evaluation_Oterm__of,type,
    code_term_of: 
      !>[A: $tType] : $o ).

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

tff(sy_cl_HOL_Oequal,type,
    cl_HOL_Oequal: 
      !>[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_Oring,type,
    ring: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Oplus,type,
    plus: 
      !>[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_Lattices_Oinf,type,
    inf: 
      !>[A: $tType] : $o ).

tff(sy_cl_Lattices_Osup,type,
    sup: 
      !>[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_Oord,type,
    ord: 
      !>[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_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_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_Parity_Oring__parity,type,
    ring_parity: 
      !>[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_Countable_Ocountable,type,
    countable: 
      !>[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_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_Complete__Lattices_OInf,type,
    complete_Inf: 
      !>[A: $tType] : $o ).

tff(sy_cl_Complete__Lattices_OSup,type,
    complete_Sup: 
      !>[A: $tType] : $o ).

tff(sy_cl_Groups_Osemigroup__mult,type,
    semigroup_mult: 
      !>[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_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_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_Quickcheck__Random_Orandom,type,
    quickcheck_random: 
      !>[A: $tType] : $o ).

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

tff(sy_cl_Complete__Partial__Order_Occpo,type,
    comple9053668089753744459l_ccpo: 
      !>[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_Bit__Operations_Osemiring__bits,type,
    bit_semiring_bits: 
      !>[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_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_Quickcheck__Exhaustive_Oexhaustive,type,
    quickc658316121487927005ustive: 
      !>[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_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_Quickcheck__Exhaustive_Ofull__exhaustive,type,
    quickc3360725361186068524ustive: 
      !>[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_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_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_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] : ( 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] : fun(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] : ( 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] : ( 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] : ( 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] : ( A > B ) ).

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

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

tff(sy_c_ATP_058Lamp__ba____,type,
    aTP_Lamp_ba: 
      !>[A: $tType,B: $tType] : fun(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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__bg____,type,
    aTP_Lamp_bg: 
      !>[A: $tType,B: $tType] : fun(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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__bk____,type,
    aTP_Lamp_bk: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : ( 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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__ce____,type,
    aTP_Lamp_ce: 
      !>[A: $tType,B: $tType] : ( 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] : fun(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] : fun(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] : fun(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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__ct____,type,
    aTP_Lamp_ct: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : ( 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] : fun(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] : fun(A,B) ).

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

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

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

tff(sy_c_ATP_058Lamp__dk____,type,
    aTP_Lamp_dk: 
      !>[A: $tType,B: $tType] : fun(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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__dr____,type,
    aTP_Lamp_dr: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : ( 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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__er____,type,
    aTP_Lamp_er: 
      !>[A: $tType,B: $tType] : ( 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] : ( 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] : fun(A,B) ).

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

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

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

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

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

tff(sy_c_ATP_058Lamp__fl____,type,
    aTP_Lamp_fl: 
      !>[A: $tType,B: $tType] : fun(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] : ( 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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__fs____,type,
    aTP_Lamp_fs: 
      !>[A: $tType,B: $tType] : ( 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] : fun(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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__gw____,type,
    aTP_Lamp_gw: 
      !>[A: $tType,B: $tType] : fun(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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__hf____,type,
    aTP_Lamp_hf: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : ( 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] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__hs____,type,
    aTP_Lamp_hs: 
      !>[A: $tType,B: $tType] : ( 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] : fun(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] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ie____,type,
    aTP_Lamp_ie: 
      !>[A: $tType,B: $tType] : ( 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] : ( 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] : fun(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] : fun(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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__iu____,type,
    aTP_Lamp_iu: 
      !>[A: $tType,B: $tType] : ( 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] : fun(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] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__iz____,type,
    aTP_Lamp_iz: 
      !>[A: $tType,B: $tType] : fun(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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__jf____,type,
    aTP_Lamp_jf: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : fun(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] : ( 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] : ( 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] : ( 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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__ke____,type,
    aTP_Lamp_ke: 
      !>[A: $tType,B: $tType] : ( 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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__kk____,type,
    aTP_Lamp_kk: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__ku____,type,
    aTP_Lamp_ku: 
      !>[A: $tType,B: $tType] : ( 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] : fun(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] : ( 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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__lk____,type,
    aTP_Lamp_lk: 
      !>[A: $tType,B: $tType] : fun(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] : ( 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] : ( 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] : fun(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] : ( 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] : fun(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] : fun(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] : ( 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] : ( 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] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__oe____,type,
    aTP_Lamp_oe: 
      !>[A: $tType,B: $tType] : ( 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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ok____,type,
    aTP_Lamp_ok: 
      !>[A: $tType,B: $tType] : fun(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] : ( 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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ou____,type,
    aTP_Lamp_ou: 
      !>[A: $tType,B: $tType] : ( 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] : ( 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] : fun(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] : fun(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] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__pl____,type,
    aTP_Lamp_pl: 
      !>[A: $tType,B: $tType] : ( 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] : fun(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] : fun(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] : fun(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] : fun(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] : fun(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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__qk____,type,
    aTP_Lamp_qk: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : fun(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] : fun(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] : fun(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] : ( 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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__ru____,type,
    aTP_Lamp_ru: 
      !>[A: $tType,B: $tType] : ( 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] : fun(A,B) ).

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

tff(sy_c_ATP_058Lamp__ry____,type,
    aTP_Lamp_ry: 
      !>[A: $tType,B: $tType] : fun(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] : fun(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] : fun(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] : fun(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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__ss____,type,
    aTP_Lamp_ss: 
      !>[A: $tType,B: $tType] : ( 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] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__td____,type,
    aTP_Lamp_td: 
      !>[A: $tType,B: $tType] : ( 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] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__tq____,type,
    aTP_Lamp_tq: 
      !>[A: $tType,B: $tType] : fun(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] : fun(A,B) ).

tff(sy_c_ATP_058Lamp__ue____,type,
    aTP_Lamp_ue: 
      !>[A: $tType,B: $tType] : fun(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_ATP_058Lamp__us____,type,
    aTP_Lamp_us: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__uu____,type,
    aTP_Lamp_uu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uv____,type,
    aTP_Lamp_uv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__ux____,type,
    aTP_Lamp_ux: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uy____,type,
    aTP_Lamp_uy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__uz____,type,
    aTP_Lamp_uz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__va____,type,
    aTP_Lamp_va: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vb____,type,
    aTP_Lamp_vb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vc____,type,
    aTP_Lamp_vc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vd____,type,
    aTP_Lamp_vd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ve____,type,
    aTP_Lamp_ve: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vf____,type,
    aTP_Lamp_vf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__vh____,type,
    aTP_Lamp_vh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vi____,type,
    aTP_Lamp_vi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__vk____,type,
    aTP_Lamp_vk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vl____,type,
    aTP_Lamp_vl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vm____,type,
    aTP_Lamp_vm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vn____,type,
    aTP_Lamp_vn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vo____,type,
    aTP_Lamp_vo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__vq____,type,
    aTP_Lamp_vq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vr____,type,
    aTP_Lamp_vr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vs____,type,
    aTP_Lamp_vs: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vt____,type,
    aTP_Lamp_vt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vu____,type,
    aTP_Lamp_vu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vv____,type,
    aTP_Lamp_vv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vw____,type,
    aTP_Lamp_vw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vx____,type,
    aTP_Lamp_vx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vy____,type,
    aTP_Lamp_vy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__vz____,type,
    aTP_Lamp_vz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wa____,type,
    aTP_Lamp_wa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wb____,type,
    aTP_Lamp_wb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wc____,type,
    aTP_Lamp_wc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wd____,type,
    aTP_Lamp_wd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

tff(sy_c_ATP_058Lamp__wf____,type,
    aTP_Lamp_wf: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wg____,type,
    aTP_Lamp_wg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wh____,type,
    aTP_Lamp_wh: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wi____,type,
    aTP_Lamp_wi: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wj____,type,
    aTP_Lamp_wj: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wk____,type,
    aTP_Lamp_wk: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wl____,type,
    aTP_Lamp_wl: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wm____,type,
    aTP_Lamp_wm: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wn____,type,
    aTP_Lamp_wn: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wo____,type,
    aTP_Lamp_wo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wp____,type,
    aTP_Lamp_wp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wq____,type,
    aTP_Lamp_wq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wr____,type,
    aTP_Lamp_wr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ws____,type,
    aTP_Lamp_ws: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wt____,type,
    aTP_Lamp_wt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wu____,type,
    aTP_Lamp_wu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wv____,type,
    aTP_Lamp_wv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ww____,type,
    aTP_Lamp_ww: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wx____,type,
    aTP_Lamp_wx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wy____,type,
    aTP_Lamp_wy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__wz____,type,
    aTP_Lamp_wz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xa____,type,
    aTP_Lamp_xa: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xb____,type,
    aTP_Lamp_xb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

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

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

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

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

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

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

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

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

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

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

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

tff(sy_c_ATP_058Lamp__xo____,type,
    aTP_Lamp_xo: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xp____,type,
    aTP_Lamp_xp: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xq____,type,
    aTP_Lamp_xq: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xr____,type,
    aTP_Lamp_xr: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xs____,type,
    aTP_Lamp_xs: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xt____,type,
    aTP_Lamp_xt: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xu____,type,
    aTP_Lamp_xu: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xv____,type,
    aTP_Lamp_xv: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xw____,type,
    aTP_Lamp_xw: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xx____,type,
    aTP_Lamp_xx: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xy____,type,
    aTP_Lamp_xy: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__xz____,type,
    aTP_Lamp_xz: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__ya____,type,
    aTP_Lamp_ya: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__yb____,type,
    aTP_Lamp_yb: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__yc____,type,
    aTP_Lamp_yc: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__yd____,type,
    aTP_Lamp_yd: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

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

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

tff(sy_c_ATP_058Lamp__yg____,type,
    aTP_Lamp_yg: 
      !>[A: $tType,B: $tType] : ( A > B ) ).

tff(sy_c_ATP_058Lamp__yh____,type,
    aTP_Lamp_yh: 
      !>[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_Oalloc,type,
    array_alloc: 
      !>[A: $tType] : ( ( list(A) * heap_ext(product_unit) ) > product_prod(array(A),heap_ext(product_unit)) ) ).

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_Olen_H,type,
    array_len2: 
      !>[B: $tType,A: $tType] : ( array(B) > heap_Time_Heap(A) ) ).

tff(sy_c_Array__Time_Olength,type,
    array_length: 
      !>[A: $tType] : ( heap_ext(product_unit) > fun(array(A),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_Omake_H,type,
    array_make2: 
      !>[B: $tType,A: $tType] : ( ( code_integer * fun(B,A) ) > heap_Time_Heap(array(A)) ) ).

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

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

tff(sy_c_Array__Time_Onew_H,type,
    array_new2: 
      !>[A: $tType] : fun(code_integer,fun(A,heap_Time_Heap(array(A)))) ).

tff(sy_c_Array__Time_Onoteq,type,
    array_noteq: 
      !>[A: $tType,B: $tType] : ( ( array(A) * array(B) ) > $o ) ).

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

tff(sy_c_Array__Time_Onth_H,type,
    array_nth2: 
      !>[A: $tType] : ( array(A) > fun(code_integer,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_Opresent,type,
    array_present: 
      !>[A: $tType] : ( heap_ext(product_unit) > fun(array(A),$o) ) ).

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

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

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

tff(sy_c_Array__Time_Oupd_H,type,
    array_upd2: 
      !>[A: $tType] : ( ( array(A) * code_integer * A ) > heap_Time_Heap(product_unit) ) ).

tff(sy_c_Array__Time_Oupdate,type,
    array_update: 
      !>[A: $tType] : ( ( array(A) * nat * A * heap_ext(product_unit) ) > heap_ext(product_unit) ) ).

tff(sy_c_Assertions_Oassn_ORep__assn,type,
    rep_assn: ( assn * product_prod(heap_ext(product_unit),set(nat)) ) > $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: 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_Oone__assn__raw,type,
    one_assn_raw: 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_Oproper,type,
    proper: 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 * 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) * 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 * 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) * 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) * 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_BNF__Cardinal__Arithmetic_OCsum,type,
    bNF_Cardinal_Csum: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,A)) * fun(A,set(product_prod(B,B))) ) > set(product_prod(product_prod(A,B),product_prod(A,B))) ) ).

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_Ocfinite,type,
    bNF_Cardinal_cfinite: 
      !>[A: $tType] : ( set(product_prod(A,A)) > $o ) ).

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

tff(sy_c_BNF__Cardinal__Arithmetic_Ocone,type,
    bNF_Cardinal_cone: set(product_prod(product_unit,product_unit)) ).

tff(sy_c_BNF__Cardinal__Arithmetic_Ocprod,type,
    bNF_Cardinal_cprod: 
      !>[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_BNF__Cardinal__Arithmetic_Ocsum,type,
    bNF_Cardinal_csum: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,A)) * set(product_prod(B,B)) ) > set(product_prod(sum_sum(A,B),sum_sum(A,B))) ) ).

tff(sy_c_BNF__Cardinal__Arithmetic_Octwo,type,
    bNF_Cardinal_ctwo: set(product_prod($o,$o)) ).

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_OcardSuc,type,
    bNF_Ca8387033319878233205ardSuc: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(set(A),set(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_Ocofinal,type,
    bNF_Ca7293521722713021262ofinal: 
      !>[A: $tType] : ( ( set(A) * set(product_prod(A,A)) ) > $o ) ).

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

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

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

tff(sy_c_BNF__Cardinal__Order__Relation_OrelChain,type,
    bNF_Ca3754400796208372196lChain: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,A)) * fun(A,B) ) > $o ) ).

tff(sy_c_BNF__Def_OGr,type,
    bNF_Gr: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,B) ) > set(product_prod(A,B)) ) ).

tff(sy_c_BNF__Def_OGrp,type,
    bNF_Grp: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,B) ) > fun(A,fun(B,$o)) ) ).

tff(sy_c_BNF__Def_Ocollect,type,
    bNF_collect: 
      !>[B: $tType,A: $tType] : ( set(fun(B,set(A))) > fun(B,set(A)) ) ).

tff(sy_c_BNF__Def_Oconvol,type,
    bNF_convol: 
      !>[A: $tType,B: $tType,C: $tType] : ( ( fun(A,B) * fun(A,C) ) > fun(A,product_prod(B,C)) ) ).

tff(sy_c_BNF__Def_Oeq__onp,type,
    bNF_eq_onp: 
      !>[A: $tType] : ( fun(A,$o) > fun(A,fun(A,$o)) ) ).

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

tff(sy_c_BNF__Def_Opick__middlep,type,
    bNF_pick_middlep: 
      !>[B: $tType,A: $tType,C: $tType] : ( ( fun(B,fun(A,$o)) * fun(A,fun(C,$o)) * B * C ) > 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_OsndOp,type,
    bNF_sndOp: 
      !>[C: $tType,A: $tType,B: $tType] : ( ( fun(C,fun(A,$o)) * fun(A,fun(B,$o)) * product_prod(C,B) ) > product_prod(A,B) ) ).

tff(sy_c_BNF__Def_Ovimage2p,type,
    bNF_vimage2p: 
      !>[A: $tType,D: $tType,B: $tType,E: $tType,C: $tType] : ( ( fun(A,D) * fun(B,E) ) > fun(fun(D,fun(E,C)),fun(A,fun(B,C))) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OfromCard,type,
    bNF_Gr5436034075474128252omCard: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(product_prod(B,B)) * B ) > A ) ).

tff(sy_c_BNF__Greatest__Fixpoint_Oimage2,type,
    bNF_Greatest_image2: 
      !>[C: $tType,A: $tType,B: $tType] : ( ( set(C) * fun(C,A) * fun(C,B) ) > set(product_prod(A,B)) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OrelImage,type,
    bNF_Gr4221423524335903396lImage: 
      !>[B: $tType,A: $tType] : ( ( set(product_prod(B,B)) * fun(B,A) ) > set(product_prod(A,A)) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OrelInvImage,type,
    bNF_Gr7122648621184425601vImage: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(product_prod(B,B)) * fun(A,B) ) > set(product_prod(A,A)) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OtoCard,type,
    bNF_Greatest_toCard: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(product_prod(B,B)) ) > fun(A,B) ) ).

tff(sy_c_BNF__Greatest__Fixpoint_OtoCard__pred,type,
    bNF_Gr1419584066657907630d_pred: 
      !>[A: $tType,B: $tType] : ( ( set(A) * set(product_prod(B,B)) * fun(A,B) ) > $o ) ).

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_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_Ocurr,type,
    bNF_Wellorder_curr: 
      !>[A: $tType,B: $tType,C: $tType] : ( ( set(A) * fun(product_prod(A,B),C) * A ) > fun(B,C) ) ).

tff(sy_c_BNF__Wellorder__Constructions_Odir__image,type,
    bNF_We2720479622203943262_image: 
      !>[A: $tType,A2: $tType] : ( ( set(product_prod(A,A)) * fun(A,A2) ) > set(product_prod(A2,A2)) ) ).

tff(sy_c_BNF__Wellorder__Constructions_OofilterIncl,type,
    bNF_We413866401316099525erIncl: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(set(A),set(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_Ocompat,type,
    bNF_Wellorder_compat: 
      !>[A: $tType,A2: $tType] : ( ( set(product_prod(A,A)) * set(product_prod(A2,A2)) * fun(A,A2) ) > $o ) ).

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__BNF__LFPs_Oprod_Osize__prod,type,
    basic_BNF_size_prod: 
      !>[A: $tType,B: $tType] : ( ( fun(A,nat) * fun(B,nat) * product_prod(A,B) ) > nat ) ).

tff(sy_c_Basic__BNF__LFPs_Osum_Osize__sum,type,
    basic_BNF_size_sum: 
      !>[A: $tType,B: $tType] : ( ( fun(A,nat) * fun(B,nat) * sum_sum(A,B) ) > nat ) ).

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

tff(sy_c_Basic__BNFs_Opred__fun,type,
    basic_pred_fun: 
      !>[A: $tType,B: $tType] : ( ( fun(A,$o) * fun(B,$o) * fun(A,B) ) > $o ) ).

tff(sy_c_Basic__BNFs_Opred__prod,type,
    basic_pred_prod: 
      !>[A: $tType,B: $tType] : ( ( fun(A,$o) * fun(B,$o) ) > fun(product_prod(A,B),$o) ) ).

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 > fun(nat,nat) ).

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

tff(sy_c_Bit__Operations_Oand__int__rel,type,
    bit_and_int_rel: fun(product_prod(int,int),fun(product_prod(int,int),$o)) ).

tff(sy_c_Bit__Operations_Oand__not__num,type,
    bit_and_not_num: ( num * num ) > option(num) ).

tff(sy_c_Bit__Operations_Oand__not__num__rel,type,
    bit_and_not_num_rel: fun(product_prod(num,num),fun(product_prod(num,num),$o)) ).

tff(sy_c_Bit__Operations_Oconcat__bit,type,
    bit_concat_bit: ( nat * int * int ) > int ).

tff(sy_c_Bit__Operations_Oor__not__num__neg,type,
    bit_or_not_num_neg: ( num * num ) > num ).

tff(sy_c_Bit__Operations_Oor__not__num__neg__rel,type,
    bit_or3848514188828904588eg_rel: fun(product_prod(num,num),fun(product_prod(num,num),$o)) ).

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] : fun(nat,fun(A,A)) ).

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

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Omask,type,
    bit_se2239418461657761734s_mask: 
      !>[A: $tType] : fun(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] : fun(nat,fun(A,A)) ).

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

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

tff(sy_c_Bit__Operations_Osemiring__bit__operations__class_Ounset__bit,type,
    bit_se2638667681897837118et_bit: 
      !>[A: $tType] : fun(nat,fun(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] : fun(A,fun(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_Bit__Operations_Otake__bit__num,type,
    bit_take_bit_num: ( nat * num ) > option(num) ).

tff(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oand__num,type,
    bit_un7362597486090784418nd_num: ( num * num ) > option(num) ).

tff(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oand__num__rel,type,
    bit_un4731106466462545111um_rel: fun(product_prod(num,num),fun(product_prod(num,num),$o)) ).

tff(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oor__num,type,
    bit_un6697907153464112080or_num: ( num * num ) > num ).

tff(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oor__num__rel,type,
    bit_un4773296044027857193um_rel: fun(product_prod(num,num),fun(product_prod(num,num),$o)) ).

tff(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oxor__num,type,
    bit_un2480387367778600638or_num: ( num * num ) > option(num) ).

tff(sy_c_Bit__Operations_Ounique__euclidean__semiring__with__bit__operations__class_Oxor__num__rel,type,
    bit_un2901131394128224187um_rel: fun(product_prod(num,num),fun(product_prod(num,num),$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__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_Cancellation_Oiterate__add,type,
    iterate_add: 
      !>[A: $tType] : ( ( nat * A ) > A ) ).

tff(sy_c_Code__Numeral_ONat,type,
    code_Nat: fun(code_integer,code_natural) ).

tff(sy_c_Code__Numeral_ONeg,type,
    code_Neg: num > code_integer ).

tff(sy_c_Code__Numeral_OPos,type,
    code_Pos: fun(num,code_integer) ).

tff(sy_c_Code__Numeral_OSuc,type,
    code_Suc: fun(code_natural,code_natural) ).

tff(sy_c_Code__Numeral_Obit__cut__integer,type,
    code_bit_cut_integer: code_integer > product_prod(code_integer,$o) ).

tff(sy_c_Code__Numeral_Ocr__integer,type,
    code_cr_integer: fun(int,fun(code_integer,$o)) ).

tff(sy_c_Code__Numeral_Ocr__natural,type,
    code_cr_natural: fun(nat,fun(code_natural,$o)) ).

tff(sy_c_Code__Numeral_Odivmod__abs,type,
    code_divmod_abs: ( code_integer * code_integer ) > product_prod(code_integer,code_integer) ).

tff(sy_c_Code__Numeral_Odivmod__integer,type,
    code_divmod_integer: ( code_integer * code_integer ) > product_prod(code_integer,code_integer) ).

tff(sy_c_Code__Numeral_Odup,type,
    code_dup: fun(code_integer,code_integer) ).

tff(sy_c_Code__Numeral_Ointeger_Oint__of__integer,type,
    code_int_of_integer: fun(code_integer,int) ).

tff(sy_c_Code__Numeral_Ointeger_Ointeger__of__int,type,
    code_integer_of_int: fun(int,code_integer) ).

tff(sy_c_Code__Numeral_Ointeger__of__nat,type,
    code_integer_of_nat: fun(nat,code_integer) ).

tff(sy_c_Code__Numeral_Ointeger__of__natural,type,
    code_i5400310926305786745atural: fun(code_natural,code_integer) ).

tff(sy_c_Code__Numeral_Ointeger__of__num,type,
    code_integer_of_num: fun(num,code_integer) ).

tff(sy_c_Code__Numeral_Onat__of__integer,type,
    code_nat_of_integer: fun(code_integer,nat) ).

tff(sy_c_Code__Numeral_Onatural_Ocase__natural,type,
    code_case_natural: 
      !>[T: $tType] : ( ( T * fun(code_natural,T) ) > fun(code_natural,T) ) ).

tff(sy_c_Code__Numeral_Onatural_Onat__of__natural,type,
    code_nat_of_natural: fun(code_natural,nat) ).

tff(sy_c_Code__Numeral_Onatural_Onatural__of__nat,type,
    code_natural_of_nat: fun(nat,code_natural) ).

tff(sy_c_Code__Numeral_Onatural_Orec__natural,type,
    code_rec_natural: 
      !>[T: $tType] : ( ( T * fun(code_natural,fun(T,T)) ) > fun(code_natural,T) ) ).

tff(sy_c_Code__Numeral_Onatural_Orec__set__natural,type,
    code_rec_set_natural: 
      !>[T: $tType] : ( ( T * fun(code_natural,fun(T,T)) * code_natural ) > fun(T,$o) ) ).

tff(sy_c_Code__Numeral_Onatural__of__integer,type,
    code_n4118661773612635043nteger: fun(code_integer,code_natural) ).

tff(sy_c_Code__Numeral_Onegative,type,
    code_negative: fun(num,code_integer) ).

tff(sy_c_Code__Numeral_Onum__of__integer,type,
    code_num_of_integer: fun(code_integer,num) ).

tff(sy_c_Code__Numeral_Opcr__integer,type,
    code_pcr_integer: fun(int,fun(code_integer,$o)) ).

tff(sy_c_Code__Numeral_Opcr__natural,type,
    code_pcr_natural: fun(nat,fun(code_natural,$o)) ).

tff(sy_c_Code__Numeral_Opositive,type,
    code_positive: fun(num,code_integer) ).

tff(sy_c_Code__Numeral_Osize__nat,type,
    code_size_nat: fun(code_natural,nat) ).

tff(sy_c_Code__Numeral_Osub,type,
    code_sub: fun(num,fun(num,code_integer)) ).

tff(sy_c_Complete__Lattices_OInf__class_OInf,type,
    complete_Inf_Inf: 
      !>[A: $tType] : ( 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_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(A,fun(A,$o)) * fun(B,fun(B,$o)) * fun(A,B) ) > $o ) ).

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

tff(sy_c_Countable_Onth__item,type,
    nth_item: 
      !>[A: $tType] : ( nat > set(old_node(A,product_unit)) ) ).

tff(sy_c_Countable_Onth__item__rel,type,
    nth_item_rel: fun(nat,fun(nat,$o)) ).

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

tff(sy_c_Divides_Oadjust__div,type,
    adjust_div: product_prod(int,int) > int ).

tff(sy_c_Divides_Odivmod__nat,type,
    divmod_nat: ( nat * nat ) > product_prod(nat,nat) ).

tff(sy_c_Divides_Oeucl__rel__int,type,
    eucl_rel_int: ( int * int * product_prod(int,int) ) > $o ).

tff(sy_c_Divides_Ounique__euclidean__semiring__numeral__class_Odivides__aux,type,
    unique5940410009612947441es_aux: 
      !>[A: $tType] : ( product_prod(A,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_Oequivp,type,
    equiv_equivp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $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] : fun(A,nat) ).

tff(sy_c_Euclidean__Division_Ounique__euclidean__semiring__class_Odivision__segment,type,
    euclid7384307370059645450egment: 
      !>[A: $tType] : fun(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] : fun(A,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__idem__axioms,type,
    finite1981172056906289455axioms: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,B)) > $o ) ).

tff(sy_c_Finite__Set_Ocomp__fun__idem__on__axioms,type,
    finite4980608107308702382axioms: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,fun(B,B)) ) > $o ) ).

tff(sy_c_Finite__Set_Ofinite,type,
    finite_finite2: 
      !>[A: $tType] : ( 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_Ofolding,type,
    finite_folding: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,B)) > $o ) ).

tff(sy_c_Finite__Set_Ofolding__idem,type,
    finite_folding_idem: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,B)) > $o ) ).

tff(sy_c_Finite__Set_Ofolding__idem__axioms,type,
    finite7837460588564673216axioms: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,B)) > $o ) ).

tff(sy_c_Finite__Set_Ofolding__idem__on,type,
    finite1890593828518410140dem_on: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,fun(B,B)) ) > $o ) ).

tff(sy_c_Finite__Set_Ofolding__idem__on__axioms,type,
    finite6916993218817215295axioms: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,fun(B,B)) ) > $o ) ).

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

tff(sy_c_Fun_Ofcomp,type,
    fcomp: 
      !>[A: $tType,B: $tType,C: $tType] : ( ( fun(A,B) * fun(B,C) ) > 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_Omap__fun,type,
    map_fun: 
      !>[C: $tType,A: $tType,B: $tType,D: $tType] : ( ( fun(C,A) * fun(B,D) ) > fun(fun(A,B),fun(C,D)) ) ).

tff(sy_c_Fun_Omono__on,type,
    mono_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_Ostrict__mono__on,type,
    strict_mono_on: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * set(A) ) > $o ) ).

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

tff(sy_c_Fun__Def_Omax__strict,type,
    fun_max_strict: set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))) ).

tff(sy_c_Fun__Def_Omax__weak,type,
    fun_max_weak: set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))) ).

tff(sy_c_Fun__Def_Omin__strict,type,
    fun_min_strict: set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))) ).

tff(sy_c_Fun__Def_Omin__weak,type,
    fun_min_weak: set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))) ).

tff(sy_c_Fun__Def_Opair__leq,type,
    fun_pair_leq: set(product_prod(product_prod(nat,nat),product_prod(nat,nat))) ).

tff(sy_c_Fun__Def_Opair__less,type,
    fun_pair_less: set(product_prod(product_prod(nat,nat),product_prod(nat,nat))) ).

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

tff(sy_c_Fun__Def_Orp__inv__image,type,
    fun_rp_inv_image: 
      !>[A: $tType,B: $tType] : fun(product_prod(set(product_prod(A,A)),set(product_prod(A,A))),fun(fun(B,A),product_prod(set(product_prod(B,B)),set(product_prod(B,B))))) ).

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_Obezw,type,
    bezw: ( nat * nat ) > product_prod(int,int) ).

tff(sy_c_GCD_Obezw__rel,type,
    bezw_rel: fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)) ).

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_Ogcd__nat__rel,type,
    gcd_nat_rel: fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)) ).

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] : fun(A,fun(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] : fun(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_Osum,type,
    groups3894954378712506084id_sum: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(A,A)) * A * fun(B,A) * set(B) ) > 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(fun(C,A),fun(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_Osum__list,type,
    groups4543113879258116180m_list: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * list(A) ) > A ) ).

tff(sy_c_Groups__List_Omonoid__add__class_Osum__list,type,
    groups8242544230860333062m_list: 
      !>[A: $tType] : fun(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_Odefault__class_Odefault,type,
    default_default: 
      !>[A: $tType] : A ).

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_Oarray_OArray,type,
    array2: 
      !>[A: $tType] : ( nat > array(A) ) ).

tff(sy_c_Heap_Oheap_Oarrays,type,
    arrays: 
      !>[Z: $tType] : ( ( heap_ext(Z) * typerep * nat ) > list(nat) ) ).

tff(sy_c_Heap_Oheap_Oarrays__update,type,
    arrays_update: 
      !>[Z: $tType] : ( fun(fun(typerep,fun(nat,list(nat))),fun(typerep,fun(nat,list(nat)))) > fun(heap_ext(Z),heap_ext(Z)) ) ).

tff(sy_c_Heap_Oheap_Olim,type,
    lim: 
      !>[Z: $tType] : ( heap_ext(Z) > nat ) ).

tff(sy_c_Heap_Oheap_Olim__update,type,
    lim_update: 
      !>[Z: $tType] : ( ( fun(nat,nat) * heap_ext(Z) ) > heap_ext(Z) ) ).

tff(sy_c_Heap_Oheap_Orefs,type,
    refs: 
      !>[Z: $tType] : ( ( heap_ext(Z) * typerep * nat ) > nat ) ).

tff(sy_c_Heap_Oref_ORef,type,
    ref2: 
      !>[A: $tType] : ( nat > ref(A) ) ).

tff(sy_c_Heap__Time__Monad_OHeap_OHeap,type,
    heap_Time_Heap2: 
      !>[A: $tType] : fun(fun(heap_ext(product_unit),option(product_prod(A,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(A)) ).

tff(sy_c_Heap__Time__Monad_OHeap_Ocase__Heap,type,
    heap_Time_case_Heap: 
      !>[A: $tType,B: $tType] : fun(fun(fun(heap_ext(product_unit),option(product_prod(A,product_prod(heap_ext(product_unit),nat)))),B),fun(heap_Time_Heap(A),B)) ).

tff(sy_c_Heap__Time__Monad_OHeap_Omap__Heap,type,
    heap_Time_map_Heap: 
      !>[A: $tType,Aa: $tType] : fun(fun(A,Aa),fun(heap_Time_Heap(A),heap_Time_Heap(Aa))) ).

tff(sy_c_Heap__Time__Monad_OHeap_Opred__Heap,type,
    heap_Time_pred_Heap: 
      !>[A: $tType] : fun(fun(A,$o),fun(heap_Time_Heap(A),$o)) ).

tff(sy_c_Heap__Time__Monad_OHeap_Orec__Heap,type,
    heap_Time_rec_Heap: 
      !>[A: $tType,C: $tType] : fun(fun(fun(heap_ext(product_unit),option(product_prod(A,product_prod(heap_ext(product_unit),nat)))),C),fun(heap_Time_Heap(A),C)) ).

tff(sy_c_Heap__Time__Monad_OHeap_Orel__Heap,type,
    heap_Time_rel_Heap: 
      !>[A: $tType,B: $tType] : fun(fun(A,fun(B,$o)),fun(heap_Time_Heap(A),fun(heap_Time_Heap(B),$o))) ).

tff(sy_c_Heap__Time__Monad_OHeap_Oset__Heap,type,
    heap_Time_set_Heap: 
      !>[A: $tType] : ( heap_Time_Heap(A) > set(A) ) ).

tff(sy_c_Heap__Time__Monad_OHeap_Osize__Heap,type,
    heap_Time_size_Heap: 
      !>[A: $tType] : ( fun(A,nat) > fun(heap_Time_Heap(A),nat) ) ).

tff(sy_c_Heap__Time__Monad_OHeap__lub,type,
    heap_Time_Heap_lub: 
      !>[A: $tType] : fun(set(heap_Time_Heap(A)),heap_Time_Heap(A)) ).

tff(sy_c_Heap__Time__Monad_OHeap__ord,type,
    heap_Time_Heap_ord: 
      !>[A: $tType] : fun(heap_Time_Heap(A),fun(heap_Time_Heap(A),$o)) ).

tff(sy_c_Heap__Time__Monad_Oassert,type,
    heap_Time_assert: 
      !>[A: $tType] : ( ( fun(A,$o) * A ) > heap_Time_Heap(A) ) ).

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_Oeffect,type,
    heap_Time_effect: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_ext(product_unit) * heap_ext(product_unit) * A * nat ) > $o ) ).

tff(sy_c_Heap__Time__Monad_Oexecute,type,
    heap_Time_execute: 
      !>[A: $tType] : fun(heap_Time_Heap(A),fun(heap_ext(product_unit),option(product_prod(A,product_prod(heap_ext(product_unit),nat))))) ).

tff(sy_c_Heap__Time__Monad_Oguard,type,
    heap_Time_guard: 
      !>[A: $tType] : ( ( fun(heap_ext(product_unit),$o) * fun(heap_ext(product_unit),product_prod(A,product_prod(heap_ext(product_unit),nat))) ) > heap_Time_Heap(A) ) ).

tff(sy_c_Heap__Time__Monad_Oheap,type,
    heap_Time_heap: 
      !>[A: $tType] : ( fun(heap_ext(product_unit),product_prod(A,product_prod(heap_ext(product_unit),nat))) > heap_Time_Heap(A) ) ).

tff(sy_c_Heap__Time__Monad_Olift,type,
    heap_Time_lift: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > fun(A,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] : fun(A,heap_Time_Heap(A)) ).

tff(sy_c_Heap__Time__Monad_Osuccess,type,
    heap_Time_success: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_ext(product_unit) ) > $o ) ).

tff(sy_c_Heap__Time__Monad_Otap,type,
    heap_Time_tap: 
      !>[A: $tType] : ( fun(heap_ext(product_unit),A) > heap_Time_Heap(A) ) ).

tff(sy_c_Heap__Time__Monad_OtimeFrame,type,
    heap_Time_timeFrame: 
      !>[A: $tType] : ( ( nat * option(product_prod(A,product_prod(heap_ext(product_unit),nat))) ) > option(product_prod(A,product_prod(heap_ext(product_unit),nat))) ) ).

tff(sy_c_Heap__Time__Monad_OtimeFrame__rel,type,
    heap_T5500966940807335491me_rel: 
      !>[A: $tType] : fun(product_prod(nat,option(product_prod(A,product_prod(heap_ext(product_unit),nat)))),fun(product_prod(nat,option(product_prod(A,product_prod(heap_ext(product_unit),nat)))),$o)) ).

tff(sy_c_Heap__Time__Monad_Oureturn,type,
    heap_Time_ureturn: 
      !>[A: $tType] : fun(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_Obijection,type,
    hilbert_bijection: 
      !>[A: $tType] : ( fun(A,A) > $o ) ).

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_Hoare__Triple_Onew__addrs,type,
    hoare_new_addrs: ( heap_ext(product_unit) * set(nat) * heap_ext(product_unit) ) > set(nat) ).

tff(sy_c_Inductive_Ocomplete__lattice__class_Olfp,type,
    complete_lattice_lfp: 
      !>[A: $tType] : ( fun(A,A) > A ) ).

tff(sy_c_Int_OAbs__Integ,type,
    abs_Integ: fun(product_prod(nat,nat),int) ).

tff(sy_c_Int_ONeg,type,
    neg: num > int ).

tff(sy_c_Int_OPos,type,
    pos: num > int ).

tff(sy_c_Int_ORep__Integ,type,
    rep_Integ: fun(int,product_prod(nat,nat)) ).

tff(sy_c_Int_Odup,type,
    dup: int > int ).

tff(sy_c_Int_Ointrel,type,
    intrel: fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)) ).

tff(sy_c_Int_Onat,type,
    nat2: fun(int,nat) ).

tff(sy_c_Int_Opcr__int,type,
    pcr_int: fun(product_prod(nat,nat),fun(int,$o)) ).

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_Int_Osub,type,
    sub: ( num * num ) > int ).

tff(sy_c_Lattices_Oinf__class_Oinf,type,
    inf_inf: 
      !>[A: $tType] : ( A > fun(A,A) ) ).

tff(sy_c_Lattices_Osemilattice__neutr,type,
    semilattice_neutr: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A ) > $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_Osemilattice__inf__class_OInf__fin,type,
    lattic7752659483105999362nf_fin: 
      !>[A: $tType] : ( set(A) > A ) ).

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__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)) * set(A) ) > A ) ).

tff(sy_c_Lattices__Big_Osemilattice__sup__class_OSup__fin,type,
    lattic5882676163264333800up_fin: 
      !>[A: $tType] : ( set(A) > A ) ).

tff(sy_c_Lifting_OQuotient,type,
    quotient: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,B) * fun(B,A) * fun(A,fun(B,$o)) ) > $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_Obutlast,type,
    butlast: 
      !>[A: $tType] : ( list(A) > list(A) ) ).

tff(sy_c_List_Oconcat,type,
    concat: 
      !>[A: $tType] : ( list(list(A)) > list(A) ) ).

tff(sy_c_List_Ocount__list,type,
    count_list: 
      !>[A: $tType] : ( ( list(A) * A ) > nat ) ).

tff(sy_c_List_Odistinct,type,
    distinct: 
      !>[A: $tType] : ( list(A) > $o ) ).

tff(sy_c_List_Odrop,type,
    drop: 
      !>[A: $tType] : ( ( nat * list(A) ) > list(A) ) ).

tff(sy_c_List_OdropWhile,type,
    dropWhile: 
      !>[A: $tType] : ( ( fun(A,$o) * 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,
    filter: 
      !>[A: $tType] : ( ( fun(A,$o) * list(A) ) > list(A) ) ).

tff(sy_c_List_Ofind,type,
    find: 
      !>[A: $tType] : ( ( fun(A,$o) * list(A) ) > option(A) ) ).

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

tff(sy_c_List_Ofoldl,type,
    foldl: 
      !>[B: $tType,A: $tType] : ( fun(B,fun(A,B)) > fun(B,fun(list(A),B)) ) ).

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

tff(sy_c_List_Ogen__length,type,
    gen_length: 
      !>[A: $tType] : ( ( nat * list(A) ) > nat ) ).

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)) * 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__class_Osort__key,type,
    linorder_sort_key: 
      !>[B: $tType,A: $tType] : ( fun(B,A) > fun(list(B),list(B)) ) ).

tff(sy_c_List_Olinorder__class_Osorted__list__of__set,type,
    linord4507533701916653071of_set: 
      !>[A: $tType] : ( set(A) > list(A) ) ).

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] : ( ( B * fun(A,fun(list(A),B)) ) > fun(list(A),B) ) ).

tff(sy_c_List_Olist_Ohd,type,
    hd: 
      !>[A: $tType] : ( list(A) > A ) ).

tff(sy_c_List_Olist_Olist__all,type,
    list_all: 
      !>[A: $tType] : ( ( fun(A,$o) * list(A) ) > $o ) ).

tff(sy_c_List_Olist_Olist__all2,type,
    list_all2: 
      !>[A: $tType,B: $tType] : ( 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(A,Aa) > fun(list(A),list(Aa)) ) ).

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) * list(A) ) > nat ) ).

tff(sy_c_List_Olist_Otl,type,
    tl: 
      !>[A: $tType] : ( list(A) > list(A) ) ).

tff(sy_c_List_Olist__update,type,
    list_update: 
      !>[A: $tType] : ( ( list(A) * nat * 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] : ( set(A) > set(list(A)) ) ).

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__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_Omeasures,type,
    measures: 
      !>[A: $tType] : ( list(fun(A,nat)) > set(product_prod(A,A)) ) ).

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_Onth,type,
    nth: 
      !>[A: $tType] : ( list(A) > fun(nat,A) ) ).

tff(sy_c_List_Onths,type,
    nths: 
      !>[A: $tType] : ( ( list(A) * set(nat) ) > list(A) ) ).

tff(sy_c_List_Oord__class_Olexordp,type,
    ord_lexordp: 
      !>[A: $tType] : ( ( list(A) * list(A) ) > $o ) ).

tff(sy_c_List_Opartition,type,
    partition: 
      !>[A: $tType] : ( fun(A,$o) > fun(list(A),product_prod(list(A),list(A))) ) ).

tff(sy_c_List_Oproduct,type,
    product: 
      !>[A: $tType,B: $tType] : ( ( list(A) * list(B) ) > list(product_prod(A,B)) ) ).

tff(sy_c_List_Oproduct__lists,type,
    product_lists: 
      !>[A: $tType] : ( 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] : ( 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] : ( ( A * list(A) ) > list(A) ) ).

tff(sy_c_List_Oreplicate,type,
    replicate: 
      !>[A: $tType] : ( ( nat * A ) > list(A) ) ).

tff(sy_c_List_Orev,type,
    rev: 
      !>[A: $tType] : ( list(A) > list(A) ) ).

tff(sy_c_List_Orotate,type,
    rotate: 
      !>[A: $tType] : ( nat > fun(list(A),list(A)) ) ).

tff(sy_c_List_Orotate1,type,
    rotate1: 
      !>[A: $tType] : ( list(A) > list(A) ) ).

tff(sy_c_List_Oshuffles,type,
    shuffles: 
      !>[A: $tType] : ( ( list(A) * 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] : ( ( list(A) * 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_Osuccessively,type,
    successively: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * 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] : ( ( nat * list(A) ) > list(A) ) ).

tff(sy_c_List_OtakeWhile,type,
    takeWhile: 
      !>[A: $tType] : ( ( fun(A,$o) * list(A) ) > list(A) ) ).

tff(sy_c_List_Othose,type,
    those: 
      !>[A: $tType] : ( 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_Oupt,type,
    upt: ( nat * nat ) > list(nat) ).

tff(sy_c_List_Oupto,type,
    upto: ( int * 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] : ( ( list(A) * 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__comp,type,
    map_comp: 
      !>[B: $tType,C: $tType,A: $tType] : ( ( fun(B,option(C)) * fun(A,option(B)) * A ) > option(C) ) ).

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] : fun(A,fun(multiset(A),multiset(A))) ).

tff(sy_c_Multiset_Ocomm__monoid__add_Osum__mset,type,
    comm_monoid_sum_mset: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * A * multiset(A) ) > A ) ).

tff(sy_c_Multiset_Ocomm__monoid__add__class_Osum__mset,type,
    comm_m7189776963980413722m_mset: 
      !>[A: $tType] : fun(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_Ofilter__mset,type,
    filter_mset: 
      !>[A: $tType] : ( ( fun(A,$o) * multiset(A) ) > multiset(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) > fun(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_Oms__strict,type,
    ms_strict: set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))) ).

tff(sy_c_Multiset_Oms__weak,type,
    ms_weak: set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))) ).

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_Omult,type,
    mult: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(multiset(A),multiset(A))) ) ).

tff(sy_c_Multiset_Omult1,type,
    mult1: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(product_prod(multiset(A),multiset(A))) ) ).

tff(sy_c_Multiset_Omulteqp__code,type,
    multeqp_code: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * multiset(A) * multiset(A) ) > $o ) ).

tff(sy_c_Multiset_Omultiset_OAbs__multiset,type,
    abs_multiset: 
      !>[A: $tType] : fun(fun(A,nat),multiset(A)) ).

tff(sy_c_Multiset_Omultiset_Ocount,type,
    count: 
      !>[A: $tType] : fun(multiset(A),fun(A,nat)) ).

tff(sy_c_Multiset_Omultp,type,
    multp: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * multiset(A) * multiset(A) ) > $o ) ).

tff(sy_c_Multiset_Omultp__code,type,
    multp_code: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * multiset(A) * multiset(A) ) > $o ) ).

tff(sy_c_Multiset_Opcr__multiset,type,
    pcr_multiset: 
      !>[C: $tType,B: $tType] : ( fun(C,fun(B,$o)) > fun(fun(C,nat),fun(multiset(B),$o)) ) ).

tff(sy_c_Multiset_Opw__leq,type,
    pw_leq: ( multiset(product_prod(nat,nat)) * multiset(product_prod(nat,nat)) ) > $o ).

tff(sy_c_Multiset_Orepeat__mset,type,
    repeat_mset: 
      !>[A: $tType] : ( ( nat * multiset(A) ) > multiset(A) ) ).

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_Osize__multiset,type,
    size_multiset: 
      !>[A: $tType] : ( ( fun(A,nat) * multiset(A) ) > nat ) ).

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_Osubset__mset,type,
    subset_mset: 
      !>[A: $tType] : ( ( multiset(A) * multiset(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) * 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_Oold_Onat_Orec__nat,type,
    rec_nat: 
      !>[T: $tType] : ( ( T * fun(nat,fun(T,T)) * nat ) > T ) ).

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_Nat__Bijection_Olist__decode,type,
    nat_list_decode: nat > list(nat) ).

tff(sy_c_Nat__Bijection_Olist__decode__rel,type,
    nat_list_decode_rel: fun(nat,fun(nat,$o)) ).

tff(sy_c_Nat__Bijection_Olist__encode,type,
    nat_list_encode: list(nat) > nat ).

tff(sy_c_Nat__Bijection_Olist__encode__rel,type,
    nat_list_encode_rel: fun(list(nat),fun(list(nat),$o)) ).

tff(sy_c_Nat__Bijection_Oprod__decode,type,
    nat_prod_decode: nat > product_prod(nat,nat) ).

tff(sy_c_Nat__Bijection_Oprod__decode__aux,type,
    nat_prod_decode_aux: ( nat * nat ) > product_prod(nat,nat) ).

tff(sy_c_Nat__Bijection_Oprod__decode__aux__rel,type,
    nat_pr5047031295181774490ux_rel: fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)) ).

tff(sy_c_Nat__Bijection_Oprod__encode,type,
    nat_prod_encode: fun(product_prod(nat,nat),nat) ).

tff(sy_c_Nat__Bijection_Oset__decode,type,
    nat_set_decode: nat > set(nat) ).

tff(sy_c_Nat__Bijection_Oset__encode,type,
    nat_set_encode: set(nat) > nat ).

tff(sy_c_Nat__Bijection_Osum__decode,type,
    nat_sum_decode: nat > sum_sum(nat,nat) ).

tff(sy_c_Nat__Bijection_Otriangle,type,
    nat_triangle: nat > nat ).

tff(sy_c_Num_OBitM,type,
    bitM: num > num ).

tff(sy_c_Num_Oinc,type,
    inc: num > num ).

tff(sy_c_Num_Onat__of__num,type,
    nat_of_num: num > nat ).

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: fun(num,num) ).

tff(sy_c_Num_Onum_OBit1,type,
    bit1: fun(num,num) ).

tff(sy_c_Num_Onum_OOne,type,
    one2: num ).

tff(sy_c_Num_Onum_Ocase__num,type,
    case_num: 
      !>[A: $tType] : ( ( A * fun(num,A) * fun(num,A) * num ) > A ) ).

tff(sy_c_Num_Onum_Osize__num,type,
    size_num: num > nat ).

tff(sy_c_Num_Onum__of__nat,type,
    num_of_nat: fun(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_Old__Datatype_OAtom,type,
    old_Atom: 
      !>[A: $tType,B: $tType] : ( sum_sum(A,nat) > set(old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_OIn0,type,
    old_In0: 
      !>[A: $tType,B: $tType] : ( set(old_node(A,B)) > set(old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_OIn1,type,
    old_In1: 
      !>[A: $tType,B: $tType] : ( set(old_node(A,B)) > set(old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_OLeaf,type,
    old_Leaf: 
      !>[A: $tType,B: $tType] : ( A > set(old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_ONode,type,
    old_Node: 
      !>[B: $tType,A: $tType] : set(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(A,nat))) ).

tff(sy_c_Old__Datatype_ONumb,type,
    old_Numb: 
      !>[A: $tType,B: $tType] : ( nat > set(old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_OPush__Node,type,
    old_Push_Node: 
      !>[B: $tType,A: $tType] : ( sum_sum(B,nat) > fun(old_node(A,B),old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_OScons,type,
    old_Scons: 
      !>[A: $tType,B: $tType] : ( ( set(old_node(A,B)) * set(old_node(A,B)) ) > set(old_node(A,B)) ) ).

tff(sy_c_Old__Datatype_Odprod,type,
    old_dprod: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(set(old_node(A,B)),set(old_node(A,B)))) * set(product_prod(set(old_node(A,B)),set(old_node(A,B)))) ) > set(product_prod(set(old_node(A,B)),set(old_node(A,B)))) ) ).

tff(sy_c_Old__Datatype_Odsum,type,
    old_dsum: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(set(old_node(A,B)),set(old_node(A,B)))) * set(product_prod(set(old_node(A,B)),set(old_node(A,B)))) ) > set(product_prod(set(old_node(A,B)),set(old_node(A,B)))) ) ).

tff(sy_c_Old__Datatype_Ondepth,type,
    old_ndepth: 
      !>[A: $tType,B: $tType] : ( old_node(A,B) > nat ) ).

tff(sy_c_Old__Datatype_Onode_OAbs__Node,type,
    old_Abs_Node: 
      !>[B: $tType,A: $tType] : ( product_prod(fun(nat,sum_sum(B,nat)),sum_sum(A,nat)) > old_node(A,B) ) ).

tff(sy_c_Option_Obind,type,
    bind: 
      !>[A: $tType,B: $tType] : fun(option(A),fun(fun(A,option(B)),option(B))) ).

tff(sy_c_Option_Ocombine__options,type,
    combine_options: 
      !>[A: $tType] : ( ( fun(A,fun(A,A)) * option(A) * option(A) ) > option(A) ) ).

tff(sy_c_Option_Ois__none,type,
    is_none: 
      !>[A: $tType] : ( option(A) > $o ) ).

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] : fun(B,fun(fun(A,B),fun(option(A),B))) ).

tff(sy_c_Option_Ooption_Omap__option,type,
    map_option: 
      !>[A: $tType,Aa: $tType] : fun(fun(A,Aa),fun(option(A),option(Aa))) ).

tff(sy_c_Option_Ooption_Opred__option,type,
    pred_option: 
      !>[A: $tType] : fun(fun(A,$o),fun(option(A),$o)) ).

tff(sy_c_Option_Ooption_Orec__option,type,
    rec_option: 
      !>[C: $tType,A: $tType] : fun(C,fun(fun(A,C),fun(option(A),C))) ).

tff(sy_c_Option_Ooption_Orel__option,type,
    rel_option: 
      !>[A: $tType,B: $tType] : fun(fun(A,fun(B,$o)),fun(option(A),fun(option(B),$o))) ).

tff(sy_c_Option_Ooption_Oset__option,type,
    set_option: 
      !>[A: $tType] : fun(option(A),set(A)) ).

tff(sy_c_Option_Ooption_Osize__option,type,
    size_option: 
      !>[A: $tType] : ( fun(A,nat) > fun(option(A),nat) ) ).

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_OAbove,type,
    order_Above: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(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_OUnder,type,
    order_Under: 
      !>[A: $tType] : ( ( set(product_prod(A,A)) * set(A) ) > set(A) ) ).

tff(sy_c_Order__Relation_OUnderS,type,
    order_UnderS: 
      !>[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_OaboveS,type,
    order_aboveS: 
      !>[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_Orelation__of,type,
    order_relation_of: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * set(A) ) > set(product_prod(A,A)) ) ).

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_Omax,type,
    max: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * A * A ) > A ) ).

tff(sy_c_Orderings_Oord_Omin,type,
    min: 
      !>[A: $tType] : ( ( fun(A,fun(A,$o)) * A * A ) > 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] : ( A > fun(A,A) ) ).

tff(sy_c_Orderings_Oord__class_Omin,type,
    ord_min: 
      !>[A: $tType] : ( A > fun(A,A) ) ).

tff(sy_c_Orderings_Oorder__class_Omono,type,
    order_mono: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > $o ) ).

tff(sy_c_Orderings_Oorder__class_Ostrict__mono,type,
    order_strict_mono: 
      !>[A: $tType,B: $tType] : ( fun(A,B) > $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 > fun(set(A),A) ) ).

tff(sy_c_Partial__Function_Oflat__ord,type,
    partial_flat_ord: 
      !>[A: $tType] : ( A > fun(A,fun(A,$o)) ) ).

tff(sy_c_Partial__Function_Ofun__lub,type,
    partial_fun_lub: 
      !>[C: $tType,B: $tType,A: $tType] : ( 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(A,fun(B,$o)) > fun(fun(C,A),fun(fun(C,B),$o)) ) ).

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

tff(sy_c_Partial__Function_Oimg__ord,type,
    partial_img_ord: 
      !>[A: $tType,C: $tType,B: $tType] : ( ( fun(A,C) * fun(C,fun(C,B)) ) > fun(A,fun(A,B)) ) ).

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_Opower,type,
    power2: 
      !>[A: $tType] : ( ( A * fun(A,fun(A,A)) * A * nat ) > A ) ).

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

tff(sy_c_Predicate_OSeq,type,
    seq2: 
      !>[A: $tType] : ( fun(product_unit,seq(A)) > pred(A) ) ).

tff(sy_c_Predicate_Obind,type,
    bind2: 
      !>[A: $tType,B: $tType] : ( ( pred(A) * fun(A,pred(B)) ) > pred(B) ) ).

tff(sy_c_Predicate_Oiterate__upto,type,
    iterate_upto: 
      !>[A: $tType] : ( ( fun(code_natural,A) * code_natural * code_natural ) > pred(A) ) ).

tff(sy_c_Predicate_Oiterate__upto__rel,type,
    iterate_upto_rel: 
      !>[A: $tType] : fun(product_prod(fun(code_natural,A),product_prod(code_natural,code_natural)),fun(product_prod(fun(code_natural,A),product_prod(code_natural,code_natural)),$o)) ).

tff(sy_c_Predicate_Oseq_OEmpty,type,
    empty: 
      !>[A: $tType] : seq(A) ).

tff(sy_c_Predicate_Oseq_OInsert,type,
    insert: 
      !>[A: $tType] : ( ( A * pred(A) ) > seq(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_Oapsnd,type,
    product_apsnd: 
      !>[B: $tType,C: $tType,A: $tType] : fun(fun(B,C),fun(product_prod(A,B),product_prod(A,C))) ).

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_Ointernal__case__prod,type,
    produc5280177257484947105e_prod: 
      !>[A: $tType,B: $tType,C: $tType] : fun(fun(A,fun(B,C)),fun(product_prod(A,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_Oold_Obool_Orec__bool,type,
    product_rec_bool: 
      !>[T: $tType] : ( ( T * T * $o ) > T ) ).

tff(sy_c_Product__Type_Oold_Obool_Orec__set__bool,type,
    product_rec_set_bool: 
      !>[T: $tType] : ( ( T * T * $o ) > fun(T,$o) ) ).

tff(sy_c_Product__Type_Oold_Oprod_Orec__prod,type,
    product_rec_prod: 
      !>[A: $tType,B: $tType,T: $tType] : ( ( fun(A,fun(B,T)) * product_prod(A,B) ) > T ) ).

tff(sy_c_Product__Type_Oold_Oprod_Orec__set__prod,type,
    product_rec_set_prod: 
      !>[A: $tType,B: $tType,T: $tType] : ( ( fun(A,fun(B,T)) * product_prod(A,B) ) > fun(T,$o) ) ).

tff(sy_c_Product__Type_Oold_Ounit_Orec__set__unit,type,
    product_rec_set_unit: 
      !>[T: $tType] : ( ( T * product_unit ) > fun(T,$o) ) ).

tff(sy_c_Product__Type_Oold_Ounit_Orec__unit,type,
    product_rec_unit: 
      !>[T: $tType] : ( ( T * product_unit ) > T ) ).

tff(sy_c_Product__Type_Oprod_Ocase__prod,type,
    product_case_prod: 
      !>[A: $tType,B: $tType,C: $tType] : fun(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_Oprod_Oswap,type,
    product_swap: 
      !>[A: $tType,B: $tType] : fun(product_prod(A,B),product_prod(B,A)) ).

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_Product__Type_Oscomp,type,
    product_scomp: 
      !>[A: $tType,B: $tType,C: $tType,D: $tType] : ( ( fun(A,product_prod(B,C)) * fun(B,fun(C,D)) ) > fun(A,D) ) ).

tff(sy_c_Product__Type_Ounit_OAbs__unit,type,
    product_Abs_unit: fun($o,product_unit) ).

tff(sy_c_Product__Type_Ounit_ORep__unit,type,
    product_Rep_unit: fun(product_unit,$o) ).

tff(sy_c_Product__Type_Ounit_Ocase__unit,type,
    product_case_unit: 
      !>[A: $tType] : ( ( A * product_unit ) > A ) ).

tff(sy_c_Pure_Otype,type,
    type2: 
      !>[A: $tType] : itself(A) ).

tff(sy_c_Quicksort_Olinorder__class_Oquicksort,type,
    linorder_quicksort: 
      !>[A: $tType] : ( 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_Quotient_OQuotient3,type,
    quotient3: 
      !>[A: $tType,B: $tType] : ( ( fun(A,fun(A,$o)) * fun(A,B) * fun(B,A) ) > $o ) ).

tff(sy_c_Random_Oinc__shift,type,
    inc_shift: ( code_natural * code_natural ) > code_natural ).

tff(sy_c_Random_Oiterate,type,
    iterate: 
      !>[B: $tType,A: $tType] : ( ( code_natural * fun(B,fun(A,product_prod(B,A))) ) > fun(B,fun(A,product_prod(B,A))) ) ).

tff(sy_c_Random_Oiterate__rel,type,
    iterate_rel: 
      !>[B: $tType,A: $tType] : fun(product_prod(code_natural,product_prod(fun(B,fun(A,product_prod(B,A))),B)),fun(product_prod(code_natural,product_prod(fun(B,fun(A,product_prod(B,A))),B)),$o)) ).

tff(sy_c_Random_Olog,type,
    log: ( code_natural * code_natural ) > code_natural ).

tff(sy_c_Random_Olog__rel,type,
    log_rel: fun(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),$o)) ).

tff(sy_c_Random_Ominus__shift,type,
    minus_shift: ( code_natural * code_natural * code_natural ) > code_natural ).

tff(sy_c_Random_Onext,type,
    next: fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))) ).

tff(sy_c_Random_Opick,type,
    pick: 
      !>[A: $tType] : ( ( list(product_prod(code_natural,A)) * code_natural ) > A ) ).

tff(sy_c_Random_Orange,type,
    range: code_natural > fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))) ).

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_Random_Osplit__seed,type,
    split_seed: product_prod(code_natural,code_natural) > product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)) ).

tff(sy_c_Random__Pred_Obind,type,
    random_bind: 
      !>[A: $tType,B: $tType] : ( ( fun(product_prod(code_natural,code_natural),product_prod(pred(A),product_prod(code_natural,code_natural))) * fun(A,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))) * product_prod(code_natural,code_natural) ) > product_prod(pred(B),product_prod(code_natural,code_natural)) ) ).

tff(sy_c_Random__Pred_Oempty,type,
    random_empty: 
      !>[A: $tType] : fun(product_prod(code_natural,code_natural),product_prod(pred(A),product_prod(code_natural,code_natural))) ).

tff(sy_c_Random__Pred_Oiterate__upto,type,
    random_iterate_upto: 
      !>[A: $tType] : ( ( fun(code_natural,A) * code_natural * code_natural ) > fun(product_prod(code_natural,code_natural),product_prod(pred(A),product_prod(code_natural,code_natural))) ) ).

tff(sy_c_Random__Pred_Ounion,type,
    random_union: 
      !>[A: $tType] : ( ( fun(product_prod(code_natural,code_natural),product_prod(pred(A),product_prod(code_natural,code_natural))) * fun(product_prod(code_natural,code_natural),product_prod(pred(A),product_prod(code_natural,code_natural))) * product_prod(code_natural,code_natural) ) > product_prod(pred(A),product_prod(code_natural,code_natural)) ) ).

tff(sy_c_Rat_OAbs__Rat,type,
    abs_Rat: fun(product_prod(int,int),rat) ).

tff(sy_c_Rat_OFract,type,
    fract: fun(int,fun(int,rat)) ).

tff(sy_c_Rat_OFrct,type,
    frct: product_prod(int,int) > rat ).

tff(sy_c_Rat_ORep__Rat,type,
    rep_Rat: fun(rat,product_prod(int,int)) ).

tff(sy_c_Rat_Ofield__char__0__class_Oof__rat,type,
    field_char_0_of_rat: 
      !>[A: $tType] : ( rat > A ) ).

tff(sy_c_Rat_Onormalize,type,
    normalize: product_prod(int,int) > product_prod(int,int) ).

tff(sy_c_Rat_Oof__int,type,
    of_int: int > rat ).

tff(sy_c_Rat_Opcr__rat,type,
    pcr_rat: fun(product_prod(int,int),fun(rat,$o)) ).

tff(sy_c_Rat_Opositive,type,
    positive: rat > $o ).

tff(sy_c_Rat_Oquotient__of,type,
    quotient_of: rat > product_prod(int,int) ).

tff(sy_c_Rat_Oratrel,type,
    ratrel: fun(product_prod(int,int),fun(product_prod(int,int),$o)) ).

tff(sy_c_Ref__Time_Oalloc,type,
    ref_alloc: 
      !>[A: $tType] : ( ( A * heap_ext(product_unit) ) > product_prod(ref(A),heap_ext(product_unit)) ) ).

tff(sy_c_Ref__Time_Ochange,type,
    ref_change: 
      !>[A: $tType] : ( ( fun(A,A) * ref(A) ) > heap_Time_Heap(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_Opresent,type,
    ref_present: 
      !>[A: $tType] : ( ( heap_ext(product_unit) * ref(A) ) > $o ) ).

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_Refine__Imp__Hol_Oassert_H,type,
    refine_Imp_assert: $o > heap_Time_Heap(product_unit) ).

tff(sy_c_Refine__Imp__Hol_Orefines,type,
    refine_Imp_refines: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_Time_Heap(A) ) > $o ) ).

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,
    range2: 
      !>[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_Oantisymp,type,
    antisymp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $o ) ).

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

tff(sy_c_Relation_Oasymp,type,
    asymp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $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_Oconversep,type,
    conversep: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > fun(B,fun(A,$o)) ) ).

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_Oirreflp,type,
    irreflp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $o ) ).

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

tff(sy_c_Relation_Oreflp,type,
    reflp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > $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_Orelcompp,type,
    relcompp: 
      !>[A: $tType,B: $tType,C: $tType] : ( ( fun(A,fun(B,$o)) * fun(B,fun(C,$o)) ) > fun(A,fun(C,$o)) ) ).

tff(sy_c_Relation_Osingle__valued,type,
    single_valued: 
      !>[A: $tType,B: $tType] : ( set(product_prod(A,B)) > $o ) ).

tff(sy_c_Relation_Osingle__valuedp,type,
    single_valuedp: 
      !>[A: $tType,B: $tType] : ( fun(A,fun(B,$o)) > $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] : fun(A,fun(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] : fun(A,fun(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(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,
    bind3: 
      !>[A: $tType,B: $tType] : ( ( set(A) * fun(A,set(B)) ) > set(B) ) ).

tff(sy_c_Set_Odisjnt,type,
    disjnt: 
      !>[A: $tType] : ( ( set(A) * set(A) ) > $o ) ).

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] : ( A > fun(set(A),set(A)) ) ).

tff(sy_c_Set_Ois__singleton,type,
    is_singleton: 
      !>[A: $tType] : ( set(A) > $o ) ).

tff(sy_c_Set_Ovimage,type,
    vimage: 
      !>[A: $tType,B: $tType] : ( 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_Ofold__atLeastAtMost__nat__rel,type,
    set_fo1817059534552279752at_rel: 
      !>[A: $tType] : fun(product_prod(fun(nat,fun(A,A)),product_prod(nat,product_prod(nat,A))),fun(product_prod(fun(nat,fun(A,A)),product_prod(nat,product_prod(nat,A))),$o)) ).

tff(sy_c_Set__Interval_Oord__class_OatLeast,type,
    set_ord_atLeast: 
      !>[A: $tType] : fun(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] : fun(A,set(A)) ).

tff(sy_c_Set__Interval_Oord__class_OgreaterThan,type,
    set_ord_greaterThan: 
      !>[A: $tType] : fun(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] : fun(A,set(A)) ).

tff(sy_c_String_Ochar_OChar,type,
    char2: ( $o * $o * $o * $o * $o * $o * $o * $o ) > char ).

tff(sy_c_String_Ointeger__of__char,type,
    integer_of_char: char > code_integer ).

tff(sy_c_String_Ounique__euclidean__semiring__with__bit__operations__class_Ochar__of,type,
    unique5772411509450598832har_of: 
      !>[A: $tType] : ( A > char ) ).

tff(sy_c_Sum__Type_OInl,type,
    sum_Inl: 
      !>[A: $tType,B: $tType] : fun(A,sum_sum(A,B)) ).

tff(sy_c_Sum__Type_OInr,type,
    sum_Inr: 
      !>[B: $tType,A: $tType] : fun(B,sum_sum(A,B)) ).

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_Sum__Type_Omap__sum,type,
    sum_map_sum: 
      !>[A: $tType,C: $tType,B: $tType,D: $tType] : ( ( fun(A,C) * fun(B,D) ) > fun(sum_sum(A,B),sum_sum(C,D)) ) ).

tff(sy_c_Sum__Type_Osum_Ocase__sum,type,
    sum_case_sum: 
      !>[A: $tType,C: $tType,B: $tType] : ( ( fun(A,C) * fun(B,C) ) > fun(sum_sum(A,B),C) ) ).

tff(sy_c_Syntax__Match_Osyntax__fo__nomatch,type,
    syntax7388354845996824322omatch: 
      !>[A: $tType,B: $tType] : ( ( A * B ) > $o ) ).

tff(sy_c_Time__Reasoning_Ofails,type,
    time_fails: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_ext(product_unit) ) > $o ) ).

tff(sy_c_Time__Reasoning_Othe__heap,type,
    time_the_heap: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_ext(product_unit) ) > heap_ext(product_unit) ) ).

tff(sy_c_Time__Reasoning_Othe__res,type,
    time_the_res: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_ext(product_unit) ) > A ) ).

tff(sy_c_Time__Reasoning_Otime,type,
    time_time: 
      !>[A: $tType] : ( ( heap_Time_Heap(A) * heap_ext(product_unit) ) > nat ) ).

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] : ( set(product_prod(A,A)) > set(product_prod(A,A)) ) ).

tff(sy_c_Transitive__Closure_Ortranclp,type,
    transitive_rtranclp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(A,fun(A,$o)) ) ).

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

tff(sy_c_Transitive__Closure_Otranclp,type,
    transitive_tranclp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(A,fun(A,$o)) ) ).

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_Typerep_Otyperep__class_Otyperep,type,
    typerep_typerep: 
      !>[A: $tType] : ( itself(A) > typerep ) ).

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

tff(sy_c_Wellfounded_Oaccp,type,
    accp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(A,$o) ) ).

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

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_Omax__extp,type,
    max_extp: 
      !>[A: $tType] : ( fun(A,fun(A,$o)) > fun(set(A),fun(set(A),$o)) ) ).

tff(sy_c_Wellfounded_Omeasure,type,
    measure: 
      !>[A: $tType] : ( fun(A,nat) > set(product_prod(A,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_Omlex__prod,type,
    mlex_prod: 
      !>[A: $tType] : ( ( fun(A,nat) * set(product_prod(A,A)) ) > set(product_prod(A,A)) ) ).

tff(sy_c_Wellfounded_Opred__nat,type,
    pred_nat: set(product_prod(nat,nat)) ).

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_Oadm__wf,type,
    adm_wf: 
      !>[A: $tType,B: $tType] : ( ( set(product_prod(A,A)) * fun(fun(A,B),fun(A,B)) ) > $o ) ).

tff(sy_c_Wfrec_Ocut,type,
    cut: 
      !>[A: $tType,B: $tType] : ( ( fun(A,B) * set(product_prod(A,A)) * A ) > fun(A,B) ) ).

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_OChains,type,
    chains: 
      !>[A: $tType] : ( set(product_prod(A,A)) > set(set(A)) ) ).

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

tff(sy_c_Zorn_Opred__on_Ochain,type,
    pred_chain: 
      !>[A: $tType] : ( ( set(A) * fun(A,fun(A,$o)) ) > fun(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,
    member: 
      !>[A: $tType] : ( ( A * set(A) ) > $o ) ).

tff(sy_v_h,type,
    h: heap_ext(product_unit) ).

tff(sy_v_xs,type,
    xs: list(a) ).

% Relevant facts (6626)
tff(fact_0_fails__def,axiom,
    ! [B: $tType,M: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( time_fails(B,M,Ha)
    <=> ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),M),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ).

% fails_def
tff(fact_1_Heap__eqI,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),G: heap_Time_Heap(B)] :
      ( ! [H: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),H) = aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),G),H)
     => ( F = G ) ) ).

% Heap_eqI
tff(fact_2_execute__raise,axiom,
    ! [B: $tType,S: list(char),X: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_raise(B,S)),X) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ).

% execute_raise
tff(fact_3_execute__guard_I1_J,axiom,
    ! [B: $tType,P: fun(heap_ext(product_unit),$o),Ha: heap_ext(product_unit),F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))] :
      ( ~ aa(heap_ext(product_unit),$o,P,Ha)
     => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_guard(B,P,F)),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ).

% execute_guard(1)
tff(fact_4_execute__assert_I2_J,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Ha: heap_ext(product_unit)] :
      ( ~ aa(B,$o,P,X2)
     => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_assert(B,P,X2)),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ).

% execute_assert(2)
tff(fact_5_successI,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) != none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
     => heap_Time_success(B,F,Ha) ) ).

% successI
tff(fact_6_success__def,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( heap_Time_success(B,F,Ha)
    <=> ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) != none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ).

% success_def
tff(fact_7_Heap__ordE,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B),Y: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),Y)
     => ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),X2),Ha) != none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
       => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),X2),Ha) = aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),Y),Ha) ) ) ) ).

% Heap_ordE
tff(fact_8_Heap__ordI,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B),Y: heap_Time_Heap(B)] :
      ( ! [H: heap_ext(product_unit)] :
          ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),X2),H) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
          | ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),X2),H) = aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),Y),H) ) )
     => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),Y) ) ).

% Heap_ordI
tff(fact_9_execute__bind_I2_J,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),G: fun(B,heap_Time_Heap(C))] :
      ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
     => ( aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),heap_Time_bind(B,C,F,G)),Ha) = none(product_prod(C,product_prod(heap_ext(product_unit),nat))) ) ) ).

% execute_bind(2)
tff(fact_10_the__default_Osimps_I2_J,axiom,
    ! [B: $tType,X2: B] : the_default(B,X2,none(B)) = X2 ).

% the_default.simps(2)
tff(fact_11_raise__bind,axiom,
    ! [C: $tType,B: $tType,E2: list(char),F: fun(C,heap_Time_Heap(B))] : heap_Time_bind(C,B,heap_Time_raise(C,E2),F) = heap_Time_raise(B,E2) ).

% raise_bind
tff(fact_12_heap_Oleq__refl,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B)] : aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),X2) ).

% heap.leq_refl
tff(fact_13_heap_Oleq__trans,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B),Y: heap_Time_Heap(B),Z2: heap_Time_Heap(B)] :
      ( aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),Y)
     => ( aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),Y),Z2)
       => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),Z2) ) ) ).

% heap.leq_trans
tff(fact_14_heap_Oleq__antisym,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B),Y: heap_Time_Heap(B)] :
      ( aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),Y)
     => ( aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),Y),X2)
       => ( X2 = Y ) ) ) ).

% heap.leq_antisym
tff(fact_15_assert__cong,axiom,
    ! [C: $tType,B: $tType,P: fun(B,$o),P2: fun(B,$o),F: fun(B,heap_Time_Heap(C)),F2: fun(B,heap_Time_Heap(C)),X2: B] :
      ( ( P = P2 )
     => ( ! [X3: B] :
            ( aa(B,$o,P2,X3)
           => ( aa(B,heap_Time_Heap(C),F,X3) = aa(B,heap_Time_Heap(C),F2,X3) ) )
       => ( heap_Time_bind(B,C,heap_Time_assert(B,P,X2),F) = heap_Time_bind(B,C,heap_Time_assert(B,P2,X2),F2) ) ) ) ).

% assert_cong
tff(fact_16_success__ifI,axiom,
    ! [B: $tType,C2: $o,T2: heap_Time_Heap(B),Ha: heap_ext(product_unit),E2: heap_Time_Heap(B)] :
      ( ( (C2)
       => heap_Time_success(B,T2,Ha) )
     => ( ( ~ (C2)
         => heap_Time_success(B,E2,Ha) )
       => heap_Time_success(B,
            $ite((C2),T2,E2),
            Ha) ) ) ).

% success_ifI
tff(fact_17_success__guardI,axiom,
    ! [B: $tType,P: fun(heap_ext(product_unit),$o),Ha: heap_ext(product_unit),F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))] :
      ( aa(heap_ext(product_unit),$o,P,Ha)
     => heap_Time_success(B,heap_Time_guard(B,P,F),Ha) ) ).

% success_guardI
tff(fact_18_success__assertI,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Ha: heap_ext(product_unit)] :
      ( aa(B,$o,P,X2)
     => heap_Time_success(B,heap_Time_assert(B,P,X2),Ha) ) ).

% success_assertI
tff(fact_19_fails__bind,axiom,
    ! [B: $tType,C: $tType,M: heap_Time_Heap(C),F: fun(C,heap_Time_Heap(B)),Ha: heap_ext(product_unit)] :
      ( time_fails(B,heap_Time_bind(C,B,M,F),Ha)
    <=> ( ~ time_fails(C,M,Ha)
       => time_fails(B,aa(C,heap_Time_Heap(B),F,time_the_res(C,M,Ha)),time_the_heap(C,M,Ha)) ) ) ).

% fails_bind
tff(fact_20_success__of__listI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit)] : heap_Time_success(array(B),array_of_list(B,Xsa),Ha) ) ).

% success_of_listI
tff(fact_21_success__tapI,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),B),Ha: heap_ext(product_unit)] : heap_Time_success(B,heap_Time_tap(B,F),Ha) ).

% success_tapI
tff(fact_22_success__heapI,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Ha: heap_ext(product_unit)] : heap_Time_success(B,heap_Time_heap(B,F),Ha) ).

% success_heapI
tff(fact_23_success__ureturnI,axiom,
    ! [B: $tType,X2: B,Ha: heap_ext(product_unit)] : heap_Time_success(B,aa(B,heap_Time_Heap(B),heap_Time_ureturn(B),X2),Ha) ).

% success_ureturnI
tff(fact_24_bind__ureturn,axiom,
    ! [B: $tType,F: heap_Time_Heap(B)] : heap_Time_bind(B,B,F,heap_Time_ureturn(B)) = F ).

% bind_ureturn
tff(fact_25_ureturn__bind,axiom,
    ! [B: $tType,C: $tType,X2: C,F: fun(C,heap_Time_Heap(B))] : heap_Time_bind(C,B,aa(C,heap_Time_Heap(C),heap_Time_ureturn(C),X2),F) = aa(C,heap_Time_Heap(B),F,X2) ).

% ureturn_bind
tff(fact_26_option_Osimps_I6_J,axiom,
    ! [C: $tType,B: $tType,F1: B,F22: fun(C,B)] : aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),rec_option(B,C),F1),F22),none(C)) = F1 ).

% option.simps(6)
tff(fact_27_success__bind__effectI,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),X2: B,N: nat,G: fun(B,heap_Time_Heap(C))] :
      ( heap_Time_effect(B,F,Ha,H2,X2,N)
     => ( heap_Time_success(C,aa(B,heap_Time_Heap(C),G,X2),H2)
       => heap_Time_success(C,heap_Time_bind(B,C,F,G),Ha) ) ) ).

% success_bind_effectI
tff(fact_28_execute__guard_I2_J,axiom,
    ! [B: $tType,P: fun(heap_ext(product_unit),$o),Ha: heap_ext(product_unit),F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))] :
      ( aa(heap_ext(product_unit),$o,P,Ha)
     => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_guard(B,P,F)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha)) ) ) ).

% execute_guard(2)
tff(fact_29_combine__options__simps_I1_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Y: option(B)] : combine_options(B,F,none(B),Y) = Y ).

% combine_options_simps(1)
tff(fact_30_combine__options__simps_I2_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),X2: option(B)] : combine_options(B,F,X2,none(B)) = X2 ).

% combine_options_simps(2)
tff(fact_31_option_Oinject,axiom,
    ! [B: $tType,X22: B,Y2: B] :
      ( ( aa(B,option(B),some(B),X22) = aa(B,option(B),some(B),Y2) )
    <=> ( X22 = Y2 ) ) ).

% option.inject
tff(fact_32_not__None__eq,axiom,
    ! [B: $tType,X2: option(B)] :
      ( ( X2 != none(B) )
    <=> ? [Y3: B] : X2 = aa(B,option(B),some(B),Y3) ) ).

% not_None_eq
tff(fact_33_not__Some__eq,axiom,
    ! [B: $tType,X2: option(B)] :
      ( ! [Y3: B] : X2 != aa(B,option(B),some(B),Y3)
    <=> ( X2 = none(B) ) ) ).

% not_Some_eq
tff(fact_34_combine__options__simps_I3_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),A3: B,B2: B] : combine_options(B,F,aa(B,option(B),some(B),A3),aa(B,option(B),some(B),B2)) = aa(B,option(B),some(B),aa(B,B,aa(B,fun(B,B),F,A3),B2)) ).

% combine_options_simps(3)
tff(fact_35_option_Osimps_I7_J,axiom,
    ! [B: $tType,C: $tType,F1: B,F22: fun(C,B),X22: C] : aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),rec_option(B,C),F1),F22),aa(C,option(C),some(C),X22)) = aa(C,B,F22,X22) ).

% option.simps(7)
tff(fact_36_effect__deterministic_I3_J,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),A3: B,N: nat,H3: heap_ext(product_unit),B2: B,N2: nat] :
      ( heap_Time_effect(B,F,Ha,H2,A3,N)
     => ( heap_Time_effect(B,F,Ha,H3,B2,N2)
       => ( N = N2 ) ) ) ).

% effect_deterministic(3)
tff(fact_37_effect__deterministic_I2_J,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),A3: B,N: nat,H3: heap_ext(product_unit),B2: B,N2: nat] :
      ( heap_Time_effect(B,F,Ha,H2,A3,N)
     => ( heap_Time_effect(B,F,Ha,H3,B2,N2)
       => ( H2 = H3 ) ) ) ).

% effect_deterministic(2)
tff(fact_38_effect__deterministic_I1_J,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),A3: B,N: nat,H3: heap_ext(product_unit),B2: B,N2: nat] :
      ( heap_Time_effect(B,F,Ha,H2,A3,N)
     => ( heap_Time_effect(B,F,Ha,H3,B2,N2)
       => ( A3 = B2 ) ) ) ).

% effect_deterministic(1)
tff(fact_39_effect__ifE,axiom,
    ! [B: $tType,C2: $o,T2: heap_Time_Heap(B),E2: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,
          $ite((C2),T2,E2),
          Ha,H2,R,N)
     => ( ( (C2)
         => ~ heap_Time_effect(B,T2,Ha,H2,R,N) )
       => ~ ( ~ (C2)
           => ~ heap_Time_effect(B,E2,Ha,H2,R,N) ) ) ) ).

% effect_ifE
tff(fact_40_effect__ifI,axiom,
    ! [B: $tType,C2: $o,T2: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat,E2: heap_Time_Heap(B)] :
      ( ( (C2)
       => heap_Time_effect(B,T2,Ha,H2,R,N) )
     => ( ( ~ (C2)
         => heap_Time_effect(B,E2,Ha,H2,R,N) )
       => heap_Time_effect(B,
            $ite((C2),T2,E2),
            Ha,H2,R,N) ) ) ).

% effect_ifI
tff(fact_41_combine__options__assoc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),X2: option(B),Y: option(B),Z2: option(B)] :
      ( ! [X3: B,Y4: B,Z3: B] : aa(B,B,aa(B,fun(B,B),F,aa(B,B,aa(B,fun(B,B),F,X3),Y4)),Z3) = aa(B,B,aa(B,fun(B,B),F,X3),aa(B,B,aa(B,fun(B,B),F,Y4),Z3))
     => ( combine_options(B,F,combine_options(B,F,X2,Y),Z2) = combine_options(B,F,X2,combine_options(B,F,Y,Z2)) ) ) ).

% combine_options_assoc
tff(fact_42_combine__options__commute,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),X2: option(B),Y: option(B)] :
      ( ! [X3: B,Y4: B] : aa(B,B,aa(B,fun(B,B),F,X3),Y4) = aa(B,B,aa(B,fun(B,B),F,Y4),X3)
     => ( combine_options(B,F,X2,Y) = combine_options(B,F,Y,X2) ) ) ).

% combine_options_commute
tff(fact_43_combine__options__left__commute,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Y: option(B),X2: option(B),Z2: option(B)] :
      ( ! [X3: B,Y4: B] : aa(B,B,aa(B,fun(B,B),F,X3),Y4) = aa(B,B,aa(B,fun(B,B),F,Y4),X3)
     => ( ! [X3: B,Y4: B,Z3: B] : aa(B,B,aa(B,fun(B,B),F,aa(B,B,aa(B,fun(B,B),F,X3),Y4)),Z3) = aa(B,B,aa(B,fun(B,B),F,X3),aa(B,B,aa(B,fun(B,B),F,Y4),Z3))
       => ( combine_options(B,F,Y,combine_options(B,F,X2,Z2)) = combine_options(B,F,X2,combine_options(B,F,Y,Z2)) ) ) ) ).

% combine_options_left_commute
tff(fact_44_mem__Collect__eq,axiom,
    ! [B: $tType,A3: B,P: fun(B,$o)] :
      ( member(B,A3,aa(fun(B,$o),set(B),collect(B),P))
    <=> aa(B,$o,P,A3) ) ).

% mem_Collect_eq
tff(fact_45_Collect__mem__eq,axiom,
    ! [B: $tType,A4: set(B)] : aa(fun(B,$o),set(B),collect(B),aTP_Lamp_a(set(B),fun(B,$o),A4)) = A4 ).

% Collect_mem_eq
tff(fact_46_Collect__cong,axiom,
    ! [B: $tType,P: fun(B,$o),Q: fun(B,$o)] :
      ( ! [X3: B] :
          ( aa(B,$o,P,X3)
        <=> aa(B,$o,Q,X3) )
     => ( aa(fun(B,$o),set(B),collect(B),P) = aa(fun(B,$o),set(B),collect(B),Q) ) ) ).

% Collect_cong
tff(fact_47_ext,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),G: fun(B,C)] :
      ( ! [X3: B] : aa(B,C,F,X3) = aa(B,C,G,X3)
     => ( F = G ) ) ).

% ext
tff(fact_48_option_Odistinct_I1_J,axiom,
    ! [B: $tType,X22: B] : none(B) != aa(B,option(B),some(B),X22) ).

% option.distinct(1)
tff(fact_49_option_OdiscI,axiom,
    ! [B: $tType,Option: option(B),X22: B] :
      ( ( Option = aa(B,option(B),some(B),X22) )
     => ( Option != none(B) ) ) ).

% option.discI
tff(fact_50_option_Oexhaust,axiom,
    ! [B: $tType,Y: option(B)] :
      ( ( Y != none(B) )
     => ~ ! [X23: B] : Y != aa(B,option(B),some(B),X23) ) ).

% option.exhaust
tff(fact_51_split__option__ex,axiom,
    ! [B: $tType,P: fun(option(B),$o)] :
      ( ? [X_1: option(B)] : aa(option(B),$o,P,X_1)
    <=> ( aa(option(B),$o,P,none(B))
        | ? [X4: B] : aa(option(B),$o,P,aa(B,option(B),some(B),X4)) ) ) ).

% split_option_ex
tff(fact_52_split__option__all,axiom,
    ! [B: $tType,P: fun(option(B),$o)] :
      ( ! [X_1: option(B)] : aa(option(B),$o,P,X_1)
    <=> ( aa(option(B),$o,P,none(B))
        & ! [X4: B] : aa(option(B),$o,P,aa(B,option(B),some(B),X4)) ) ) ).

% split_option_all
tff(fact_53_combine__options__cases,axiom,
    ! [B: $tType,C: $tType,X2: option(B),P: fun(option(B),fun(option(C),$o)),Y: option(C)] :
      ( ( ( X2 = none(B) )
       => aa(option(C),$o,aa(option(B),fun(option(C),$o),P,X2),Y) )
     => ( ( ( Y = none(C) )
         => aa(option(C),$o,aa(option(B),fun(option(C),$o),P,X2),Y) )
       => ( ! [A5: B,B3: C] :
              ( ( X2 = aa(B,option(B),some(B),A5) )
             => ( ( Y = aa(C,option(C),some(C),B3) )
               => aa(option(C),$o,aa(option(B),fun(option(C),$o),P,X2),Y) ) )
         => aa(option(C),$o,aa(option(B),fun(option(C),$o),P,X2),Y) ) ) ) ).

% combine_options_cases
tff(fact_54_success__effectE,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( heap_Time_success(B,C2,Ha)
     => ~ ! [R2: B,H4: heap_ext(product_unit),N3: nat] : ~ heap_Time_effect(B,C2,Ha,H4,R2,N3) ) ).

% success_effectE
tff(fact_55_effect__success,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,C2,Ha,H2,R,N)
     => heap_Time_success(B,C2,Ha) ) ).

% effect_success
tff(fact_56_effect__raiseE,axiom,
    ! [B: $tType,X2: list(char),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] : ~ heap_Time_effect(B,heap_Time_raise(B,X2),Ha,H2,R,N) ).

% effect_raiseE
tff(fact_57_the__default_Osimps_I1_J,axiom,
    ! [B: $tType,Uu: B,X2: B] : the_default(B,Uu,aa(B,option(B),some(B),X2)) = X2 ).

% the_default.simps(1)
tff(fact_58_Heap__cases,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( ! [X3: B,H4: product_prod(heap_ext(product_unit),nat)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) != aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),X3),H4))
     => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ).

% Heap_cases
tff(fact_59_successE,axiom,
    ! [B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( heap_Time_success(B,F,Ha)
     => ~ ! [R2: B,H4: product_prod(heap_ext(product_unit),nat)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) != aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),H4)) ) ).

% successE
tff(fact_60_execute__heap,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))] : aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_heap(B,F)) = aa(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),comp(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),some(product_prod(B,product_prod(heap_ext(product_unit),nat)))),F) ).

% execute_heap
tff(fact_61_some__opt__sym__eq__trivial,axiom,
    ! [B: $tType,X2: B] : eps_Opt(B,aa(B,fun(B,$o),fequal(B),X2)) = aa(B,option(B),some(B),X2) ).

% some_opt_sym_eq_trivial
tff(fact_62_success__newI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B,Ha: heap_ext(product_unit)] : heap_Time_success(array(B),aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2),Ha) ) ).

% success_newI
tff(fact_63_success__makeI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,F: fun(nat,B),Ha: heap_ext(product_unit)] : heap_Time_success(array(B),array_make(B,N,F),Ha) ) ).

% success_makeI
tff(fact_64_mmupd__in__upd,axiom,
    ! [B: $tType,C: $tType,K: B,K2: set(B),M: fun(B,option(C)),V: C] :
      ( member(B,K,K2)
     => ( aa(B,option(C),map_mmupd(B,C,M,K2,V),K) = aa(C,option(C),some(C),V) ) ) ).

% mmupd_in_upd
tff(fact_65_option_Ocollapse,axiom,
    ! [B: $tType,Option: option(B)] :
      ( ( Option != none(B) )
     => ( aa(B,option(B),some(B),aa(option(B),B,the2(B),Option)) = Option ) ) ).

% option.collapse
tff(fact_66_not__Some__eq2,axiom,
    ! [C: $tType,B: $tType,V: option(product_prod(B,C))] :
      ( ! [X4: B,Y3: C] : V != aa(product_prod(B,C),option(product_prod(B,C)),some(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Y3))
    <=> ( V = none(product_prod(B,C)) ) ) ).

% not_Some_eq2
tff(fact_67_effect__tapE,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,heap_Time_tap(B,F),Ha,H2,R,N)
     => ~ ( ( H2 = Ha )
         => ( ( R = aa(heap_ext(product_unit),B,F,Ha) )
           => ( N != one_one(nat) ) ) ) ) ).

% effect_tapE
tff(fact_68_effect__tapI,axiom,
    ! [B: $tType,H2: heap_ext(product_unit),Ha: heap_ext(product_unit),R: B,F: fun(heap_ext(product_unit),B)] :
      ( ( H2 = Ha )
     => ( ( R = aa(heap_ext(product_unit),B,F,Ha) )
       => heap_Time_effect(B,heap_Time_tap(B,F),Ha,H2,R,one_one(nat)) ) ) ).

% effect_tapI
tff(fact_69_effect__assertI,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,H2: heap_ext(product_unit),Ha: heap_ext(product_unit),R: B,N: nat] :
      ( aa(B,$o,P,X2)
     => ( ( H2 = Ha )
       => ( ( R = X2 )
         => ( ( N = one_one(nat) )
           => heap_Time_effect(B,heap_Time_assert(B,P,X2),Ha,H2,R,N) ) ) ) ) ).

% effect_assertI
tff(fact_70_mmupd__notin__upd,axiom,
    ! [C: $tType,B: $tType,K: B,K2: set(B),M: fun(B,option(C)),V: C] :
      ( ~ member(B,K,K2)
     => ( aa(B,option(C),map_mmupd(B,C,M,K2,V),K) = aa(B,option(C),M,K) ) ) ).

% mmupd_notin_upd
tff(fact_71_fun__comp__eq__conv,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(D,C),G: fun(B,D),Fg: fun(B,C)] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G) = Fg )
    <=> ! [X4: B] : aa(D,C,F,aa(B,D,G,X4)) = aa(B,C,Fg,X4) ) ).

% fun_comp_eq_conv
tff(fact_72_comp__cong__right,axiom,
    ! [D: $tType,C: $tType,B: $tType,X2: fun(B,C),Y: fun(B,C),F: fun(C,D)] :
      ( ( X2 = Y )
     => ( aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F),X2) = aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F),Y) ) ) ).

% comp_cong_right
tff(fact_73_comp__cong__left,axiom,
    ! [C: $tType,B: $tType,D: $tType,X2: fun(B,C),Y: fun(B,C),F: fun(D,B)] :
      ( ( X2 = Y )
     => ( aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),X2),F) = aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),Y),F) ) ) ).

% comp_cong_left
tff(fact_74_bex2I,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,S2: set(product_prod(B,C)),P: fun(B,fun(C,$o))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),S2)
     => ( ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),S2)
         => aa(C,$o,aa(B,fun(C,$o),P,A3),B2) )
       => ? [A5: B,B3: C] :
            ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3),S2)
            & aa(C,$o,aa(B,fun(C,$o),P,A5),B3) ) ) ) ).

% bex2I
tff(fact_75_pairself_Ocases,axiom,
    ! [C: $tType,B: $tType,X2: product_prod(fun(B,C),product_prod(B,B))] :
      ~ ! [F3: fun(B,C),A5: B,B3: B] : X2 != aa(product_prod(B,B),product_prod(fun(B,C),product_prod(B,B)),aa(fun(B,C),fun(product_prod(B,B),product_prod(fun(B,C),product_prod(B,B))),product_Pair(fun(B,C),product_prod(B,B)),F3),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),B3)) ).

% pairself.cases
tff(fact_76_fails__array__new,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B,Ha: heap_ext(product_unit)] : ~ time_fails(array(B),aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2),Ha) ) ).

% fails_array_new
tff(fact_77_timeFrame_Ocases,axiom,
    ! [B: $tType,X2: product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] :
      ( ! [N3: nat,R2: B,H: heap_ext(product_unit),N4: nat] : X2 != aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(nat,fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),product_Pair(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),N3),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H),N4))))
     => ~ ! [N3: nat] : X2 != aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(nat,fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),product_Pair(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),N3),none(product_prod(B,product_prod(heap_ext(product_unit),nat)))) ) ).

% timeFrame.cases
tff(fact_78_execute__assert_I1_J,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Ha: heap_ext(product_unit)] :
      ( aa(B,$o,P,X2)
     => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_assert(B,P,X2)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),X2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),one_one(nat)))) ) ) ).

% execute_assert(1)
tff(fact_79_execute__tap,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_tap(B,F)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),B,F,Ha)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),one_one(nat)))) ).

% execute_tap
tff(fact_80_option_Osel,axiom,
    ! [B: $tType,X22: B] : aa(option(B),B,the2(B),aa(B,option(B),some(B),X22)) = X22 ).

% option.sel
tff(fact_81_option_Oexpand,axiom,
    ! [B: $tType,Option: option(B),Option2: option(B)] :
      ( ( ( Option = none(B) )
      <=> ( Option2 = none(B) ) )
     => ( ( ( Option != none(B) )
         => ( ( Option2 != none(B) )
           => ( aa(option(B),B,the2(B),Option) = aa(option(B),B,the2(B),Option2) ) ) )
       => ( Option = Option2 ) ) ) ).

% option.expand
tff(fact_82_effect__def,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,C2,Ha,H2,R,N)
    <=> ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H2),N))) ) ) ).

% effect_def
tff(fact_83_effectI,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),Ha: heap_ext(product_unit),R: B,H2: heap_ext(product_unit),N: nat] :
      ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H2),N))) )
     => heap_Time_effect(B,C2,Ha,H2,R,N) ) ).

% effectI
tff(fact_84_map__mmupd__def,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),K2: set(C),V: B,K: C] :
      aa(C,option(B),map_mmupd(C,B,M,K2,V),K) = $ite(member(C,K,K2),aa(B,option(B),some(B),V),aa(C,option(B),M,K)) ).

% map_mmupd_def
tff(fact_85_map__mmupdE,axiom,
    ! [C: $tType,B: $tType,M: fun(C,option(B)),K2: set(C),V: B,K: C,X2: B] :
      ( ( aa(C,option(B),map_mmupd(C,B,M,K2,V),K) = aa(B,option(B),some(B),X2) )
     => ( ( ~ member(C,K,K2)
         => ( aa(C,option(B),M,K) != aa(B,option(B),some(B),X2) ) )
       => ~ ( member(C,K,K2)
           => ( X2 != V ) ) ) ) ).

% map_mmupdE
tff(fact_86_success__bind__executeI,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),X2: B,H2: heap_ext(product_unit),N: nat,G: fun(B,heap_Time_Heap(C))] :
      ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),X2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H2),N))) )
     => ( heap_Time_success(C,aa(B,heap_Time_Heap(C),G,X2),H2)
       => heap_Time_success(C,heap_Time_bind(B,C,F,G),Ha) ) ) ).

% success_bind_executeI
tff(fact_87_Eps__Opt__eq__Some__implies,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B] :
      ( ( eps_Opt(B,P) = aa(B,option(B),some(B),X2) )
     => aa(B,$o,P,X2) ) ).

% Eps_Opt_eq_Some_implies
tff(fact_88_Eps__Opt__eq__Some,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B] :
      ( ! [X5: B] :
          ( aa(B,$o,P,X2)
         => ( aa(B,$o,P,X5)
           => ( X5 = X2 ) ) )
     => ( ( eps_Opt(B,P) = aa(B,option(B),some(B),X2) )
      <=> aa(B,$o,P,X2) ) ) ).

% Eps_Opt_eq_Some
tff(fact_89_option_Oexhaust__sel,axiom,
    ! [B: $tType,Option: option(B)] :
      ( ( Option != none(B) )
     => ( Option = aa(B,option(B),some(B),aa(option(B),B,the2(B),Option)) ) ) ).

% option.exhaust_sel
tff(fact_90_effect__assertE,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,heap_Time_assert(B,P,X2),Ha,H2,R,N)
     => ~ ( aa(B,$o,P,X2)
         => ( ( R = X2 )
           => ( ( H2 = Ha )
             => ( N != one_one(nat) ) ) ) ) ) ).

% effect_assertE
tff(fact_91_comp__apply,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(C,B),G: fun(D,C),X2: D] : aa(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G),X2) = aa(C,B,F,aa(D,C,G,X2)) ).

% comp_apply
tff(fact_92_prod_Oinject,axiom,
    ! [B: $tType,C: $tType,X1: B,X22: C,Y1: B,Y2: C] :
      ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X1),X22) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y1),Y2) )
    <=> ( ( X1 = Y1 )
        & ( X22 = Y2 ) ) ) ).

% prod.inject
tff(fact_93_old_Oprod_Oinject,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,A6: B,B4: C] :
      ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A6),B4) )
    <=> ( ( A3 = A6 )
        & ( B2 = B4 ) ) ) ).

% old.prod.inject
tff(fact_94_execute__bind_I1_J,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),X2: B,H2: heap_ext(product_unit),N: nat,G: fun(B,heap_Time_Heap(C))] :
      ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),X2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H2),N))) )
     => ( aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),heap_Time_bind(B,C,F,G)),Ha) = heap_Time_timeFrame(C,N,aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),aa(B,heap_Time_Heap(C),G,X2)),H2)) ) ) ).

% execute_bind(1)
tff(fact_95_prod__cases3,axiom,
    ! [B: $tType,C: $tType,D: $tType,Y: product_prod(B,product_prod(C,D))] :
      ~ ! [A5: B,B3: C,C3: D] : Y != aa(product_prod(C,D),product_prod(B,product_prod(C,D)),aa(B,fun(product_prod(C,D),product_prod(B,product_prod(C,D))),product_Pair(B,product_prod(C,D)),A5),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),B3),C3)) ).

% prod_cases3
tff(fact_96_prod__cases4,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,Y: product_prod(B,product_prod(C,product_prod(D,E)))] :
      ~ ! [A5: B,B3: C,C3: D,D2: E] : Y != aa(product_prod(C,product_prod(D,E)),product_prod(B,product_prod(C,product_prod(D,E))),aa(B,fun(product_prod(C,product_prod(D,E)),product_prod(B,product_prod(C,product_prod(D,E)))),product_Pair(B,product_prod(C,product_prod(D,E))),A5),aa(product_prod(D,E),product_prod(C,product_prod(D,E)),aa(C,fun(product_prod(D,E),product_prod(C,product_prod(D,E))),product_Pair(C,product_prod(D,E)),B3),aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),C3),D2))) ).

% prod_cases4
tff(fact_97_prod__cases5,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,F4: $tType,Y: product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4))))] :
      ~ ! [A5: B,B3: C,C3: D,D2: E,E3: F4] : Y != aa(product_prod(C,product_prod(D,product_prod(E,F4))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4)))),aa(B,fun(product_prod(C,product_prod(D,product_prod(E,F4))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4))))),product_Pair(B,product_prod(C,product_prod(D,product_prod(E,F4)))),A5),aa(product_prod(D,product_prod(E,F4)),product_prod(C,product_prod(D,product_prod(E,F4))),aa(C,fun(product_prod(D,product_prod(E,F4)),product_prod(C,product_prod(D,product_prod(E,F4)))),product_Pair(C,product_prod(D,product_prod(E,F4))),B3),aa(product_prod(E,F4),product_prod(D,product_prod(E,F4)),aa(D,fun(product_prod(E,F4),product_prod(D,product_prod(E,F4))),product_Pair(D,product_prod(E,F4)),C3),aa(F4,product_prod(E,F4),aa(E,fun(F4,product_prod(E,F4)),product_Pair(E,F4),D2),E3)))) ).

% prod_cases5
tff(fact_98_prod__cases6,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,F4: $tType,G2: $tType,Y: product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))))] :
      ~ ! [A5: B,B3: C,C3: D,D2: E,E3: F4,F3: G2] : Y != aa(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),aa(B,fun(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))))),product_Pair(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),A5),aa(product_prod(D,product_prod(E,product_prod(F4,G2))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),aa(C,fun(product_prod(D,product_prod(E,product_prod(F4,G2))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),product_Pair(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),B3),aa(product_prod(E,product_prod(F4,G2)),product_prod(D,product_prod(E,product_prod(F4,G2))),aa(D,fun(product_prod(E,product_prod(F4,G2)),product_prod(D,product_prod(E,product_prod(F4,G2)))),product_Pair(D,product_prod(E,product_prod(F4,G2))),C3),aa(product_prod(F4,G2),product_prod(E,product_prod(F4,G2)),aa(E,fun(product_prod(F4,G2),product_prod(E,product_prod(F4,G2))),product_Pair(E,product_prod(F4,G2)),D2),aa(G2,product_prod(F4,G2),aa(F4,fun(G2,product_prod(F4,G2)),product_Pair(F4,G2),E3),F3))))) ).

% prod_cases6
tff(fact_99_prod__cases7,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,F4: $tType,G2: $tType,H5: $tType,Y: product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))))] :
      ~ ! [A5: B,B3: C,C3: D,D2: E,E3: F4,F3: G2,G3: H5] : Y != aa(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),aa(B,fun(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))))),product_Pair(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),A5),aa(product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),aa(C,fun(product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),product_Pair(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),B3),aa(product_prod(E,product_prod(F4,product_prod(G2,H5))),product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),aa(D,fun(product_prod(E,product_prod(F4,product_prod(G2,H5))),product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),product_Pair(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),C3),aa(product_prod(F4,product_prod(G2,H5)),product_prod(E,product_prod(F4,product_prod(G2,H5))),aa(E,fun(product_prod(F4,product_prod(G2,H5)),product_prod(E,product_prod(F4,product_prod(G2,H5)))),product_Pair(E,product_prod(F4,product_prod(G2,H5))),D2),aa(product_prod(G2,H5),product_prod(F4,product_prod(G2,H5)),aa(F4,fun(product_prod(G2,H5),product_prod(F4,product_prod(G2,H5))),product_Pair(F4,product_prod(G2,H5)),E3),aa(H5,product_prod(G2,H5),aa(G2,fun(H5,product_prod(G2,H5)),product_Pair(G2,H5),F3),G3)))))) ).

% prod_cases7
tff(fact_100_prod__induct3,axiom,
    ! [D: $tType,C: $tType,B: $tType,P: fun(product_prod(B,product_prod(C,D)),$o),X2: product_prod(B,product_prod(C,D))] :
      ( ! [A5: B,B3: C,C3: D] : aa(product_prod(B,product_prod(C,D)),$o,P,aa(product_prod(C,D),product_prod(B,product_prod(C,D)),aa(B,fun(product_prod(C,D),product_prod(B,product_prod(C,D))),product_Pair(B,product_prod(C,D)),A5),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),B3),C3)))
     => aa(product_prod(B,product_prod(C,D)),$o,P,X2) ) ).

% prod_induct3
tff(fact_101_prod__induct4,axiom,
    ! [E: $tType,D: $tType,C: $tType,B: $tType,P: fun(product_prod(B,product_prod(C,product_prod(D,E))),$o),X2: product_prod(B,product_prod(C,product_prod(D,E)))] :
      ( ! [A5: B,B3: C,C3: D,D2: E] : aa(product_prod(B,product_prod(C,product_prod(D,E))),$o,P,aa(product_prod(C,product_prod(D,E)),product_prod(B,product_prod(C,product_prod(D,E))),aa(B,fun(product_prod(C,product_prod(D,E)),product_prod(B,product_prod(C,product_prod(D,E)))),product_Pair(B,product_prod(C,product_prod(D,E))),A5),aa(product_prod(D,E),product_prod(C,product_prod(D,E)),aa(C,fun(product_prod(D,E),product_prod(C,product_prod(D,E))),product_Pair(C,product_prod(D,E)),B3),aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),C3),D2))))
     => aa(product_prod(B,product_prod(C,product_prod(D,E))),$o,P,X2) ) ).

% prod_induct4
tff(fact_102_timeFrame_Osimps_I2_J,axiom,
    ! [B: $tType,N: nat] : heap_Time_timeFrame(B,N,none(product_prod(B,product_prod(heap_ext(product_unit),nat)))) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ).

% timeFrame.simps(2)
tff(fact_103_Pair__inject,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,A6: B,B4: C] :
      ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A6),B4) )
     => ~ ( ( A3 = A6 )
         => ( B2 != B4 ) ) ) ).

% Pair_inject
tff(fact_104_prod__cases,axiom,
    ! [C: $tType,B: $tType,P: fun(product_prod(B,C),$o),P3: product_prod(B,C)] :
      ( ! [A5: B,B3: C] : aa(product_prod(B,C),$o,P,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3))
     => aa(product_prod(B,C),$o,P,P3) ) ).

% prod_cases
tff(fact_105_surj__pair,axiom,
    ! [B: $tType,C: $tType,P3: product_prod(B,C)] :
    ? [X3: B,Y4: C] : P3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4) ).

% surj_pair
tff(fact_106_old_Oprod_Oexhaust,axiom,
    ! [B: $tType,C: $tType,Y: product_prod(B,C)] :
      ~ ! [A5: B,B3: C] : Y != aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3) ).

% old.prod.exhaust
tff(fact_107_one__reorient,axiom,
    ! [B: $tType] :
      ( one(B)
     => ! [X2: B] :
          ( ( one_one(B) = X2 )
        <=> ( X2 = one_one(B) ) ) ) ).

% one_reorient
tff(fact_108_comp__eq__dest__lhs,axiom,
    ! [D: $tType,C: $tType,B: $tType,A3: fun(D,C),B2: fun(B,D),C2: fun(B,C),V: B] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),A3),B2) = C2 )
     => ( aa(D,C,A3,aa(B,D,B2,V)) = aa(B,C,C2,V) ) ) ).

% comp_eq_dest_lhs
tff(fact_109_comp__eq__elim,axiom,
    ! [D: $tType,C: $tType,E: $tType,B: $tType,A3: fun(D,C),B2: fun(B,D),C2: fun(E,C),D3: fun(B,E)] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),A3),B2) = aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),C2),D3) )
     => ! [V2: B] : aa(D,C,A3,aa(B,D,B2,V2)) = aa(E,C,C2,aa(B,E,D3,V2)) ) ).

% comp_eq_elim
tff(fact_110_comp__eq__dest,axiom,
    ! [D: $tType,C: $tType,E: $tType,B: $tType,A3: fun(D,C),B2: fun(B,D),C2: fun(E,C),D3: fun(B,E),V: B] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),A3),B2) = aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),C2),D3) )
     => ( aa(D,C,A3,aa(B,D,B2,V)) = aa(E,C,C2,aa(B,E,D3,V)) ) ) ).

% comp_eq_dest
tff(fact_111_comp__assoc,axiom,
    ! [C: $tType,E: $tType,D: $tType,B: $tType,F: fun(E,C),G: fun(D,E),Ha: fun(B,D)] : aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),aa(fun(D,E),fun(D,C),aa(fun(E,C),fun(fun(D,E),fun(D,C)),comp(E,C,D),F),G)),Ha) = aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),F),aa(fun(B,D),fun(B,E),aa(fun(D,E),fun(fun(B,D),fun(B,E)),comp(D,E,B),G),Ha)) ).

% comp_assoc
tff(fact_112_comp__def,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),G: fun(B,D),X: B] : aa(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G),X) = aa(D,C,F,aa(B,D,G,X)) ).

% comp_def
tff(fact_113_prod__induct7,axiom,
    ! [H5: $tType,G2: $tType,F4: $tType,E: $tType,D: $tType,C: $tType,B: $tType,P: fun(product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),$o),X2: product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))))] :
      ( ! [A5: B,B3: C,C3: D,D2: E,E3: F4,F3: G2,G3: H5] : aa(product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),$o,P,aa(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),aa(B,fun(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))))),product_Pair(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),A5),aa(product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),aa(C,fun(product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),product_Pair(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),B3),aa(product_prod(E,product_prod(F4,product_prod(G2,H5))),product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),aa(D,fun(product_prod(E,product_prod(F4,product_prod(G2,H5))),product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5))))),product_Pair(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))),C3),aa(product_prod(F4,product_prod(G2,H5)),product_prod(E,product_prod(F4,product_prod(G2,H5))),aa(E,fun(product_prod(F4,product_prod(G2,H5)),product_prod(E,product_prod(F4,product_prod(G2,H5)))),product_Pair(E,product_prod(F4,product_prod(G2,H5))),D2),aa(product_prod(G2,H5),product_prod(F4,product_prod(G2,H5)),aa(F4,fun(product_prod(G2,H5),product_prod(F4,product_prod(G2,H5))),product_Pair(F4,product_prod(G2,H5)),E3),aa(H5,product_prod(G2,H5),aa(G2,fun(H5,product_prod(G2,H5)),product_Pair(G2,H5),F3),G3)))))))
     => aa(product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,product_prod(G2,H5)))))),$o,P,X2) ) ).

% prod_induct7
tff(fact_114_prod__induct6,axiom,
    ! [G2: $tType,F4: $tType,E: $tType,D: $tType,C: $tType,B: $tType,P: fun(product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),$o),X2: product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))))] :
      ( ! [A5: B,B3: C,C3: D,D2: E,E3: F4,F3: G2] : aa(product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),$o,P,aa(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),aa(B,fun(product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))))),product_Pair(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),A5),aa(product_prod(D,product_prod(E,product_prod(F4,G2))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),aa(C,fun(product_prod(D,product_prod(E,product_prod(F4,G2))),product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),product_Pair(C,product_prod(D,product_prod(E,product_prod(F4,G2)))),B3),aa(product_prod(E,product_prod(F4,G2)),product_prod(D,product_prod(E,product_prod(F4,G2))),aa(D,fun(product_prod(E,product_prod(F4,G2)),product_prod(D,product_prod(E,product_prod(F4,G2)))),product_Pair(D,product_prod(E,product_prod(F4,G2))),C3),aa(product_prod(F4,G2),product_prod(E,product_prod(F4,G2)),aa(E,fun(product_prod(F4,G2),product_prod(E,product_prod(F4,G2))),product_Pair(E,product_prod(F4,G2)),D2),aa(G2,product_prod(F4,G2),aa(F4,fun(G2,product_prod(F4,G2)),product_Pair(F4,G2),E3),F3))))))
     => aa(product_prod(B,product_prod(C,product_prod(D,product_prod(E,product_prod(F4,G2))))),$o,P,X2) ) ).

% prod_induct6
tff(fact_115_prod__induct5,axiom,
    ! [F4: $tType,E: $tType,D: $tType,C: $tType,B: $tType,P: fun(product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4)))),$o),X2: product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4))))] :
      ( ! [A5: B,B3: C,C3: D,D2: E,E3: F4] : aa(product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4)))),$o,P,aa(product_prod(C,product_prod(D,product_prod(E,F4))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4)))),aa(B,fun(product_prod(C,product_prod(D,product_prod(E,F4))),product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4))))),product_Pair(B,product_prod(C,product_prod(D,product_prod(E,F4)))),A5),aa(product_prod(D,product_prod(E,F4)),product_prod(C,product_prod(D,product_prod(E,F4))),aa(C,fun(product_prod(D,product_prod(E,F4)),product_prod(C,product_prod(D,product_prod(E,F4)))),product_Pair(C,product_prod(D,product_prod(E,F4))),B3),aa(product_prod(E,F4),product_prod(D,product_prod(E,F4)),aa(D,fun(product_prod(E,F4),product_prod(D,product_prod(E,F4))),product_Pair(D,product_prod(E,F4)),C3),aa(F4,product_prod(E,F4),aa(E,fun(F4,product_prod(E,F4)),product_Pair(E,F4),D2),E3)))))
     => aa(product_prod(B,product_prod(C,product_prod(D,product_prod(E,F4)))),$o,P,X2) ) ).

% prod_induct5
tff(fact_116_old_Oprod_Orec,axiom,
    ! [C: $tType,B: $tType,D: $tType,F1: fun(C,fun(D,B)),A3: C,B2: D] : product_rec_prod(C,D,B,F1,aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2)) = aa(D,B,aa(C,fun(D,B),F1,A3),B2) ).

% old.prod.rec
tff(fact_117_timeFrame_Oelims,axiom,
    ! [B: $tType,X2: nat,Xa: option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Y: option(product_prod(B,product_prod(heap_ext(product_unit),nat)))] :
      ( ( heap_Time_timeFrame(B,X2,Xa) = Y )
     => ( ! [R2: B,H: heap_ext(product_unit),N4: nat] :
            ( ( Xa = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H),N4))) )
           => ( Y != aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X2),N4)))) ) )
       => ~ ( ( Xa = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
           => ( Y != none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ) ) ).

% timeFrame.elims
tff(fact_118_execute__bind__eq__SomeI,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),X2: B,H2: heap_ext(product_unit),N: nat,G: fun(B,heap_Time_Heap(C)),Y: C,H3: heap_ext(product_unit),N2: nat] :
      ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),X2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H2),N))) )
     => ( ( aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),aa(B,heap_Time_Heap(C),G,X2)),H2) = aa(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),some(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(C,product_prod(heap_ext(product_unit),nat)),aa(C,fun(product_prod(heap_ext(product_unit),nat),product_prod(C,product_prod(heap_ext(product_unit),nat))),product_Pair(C,product_prod(heap_ext(product_unit),nat)),Y),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H3),N2))) )
       => ( aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),heap_Time_bind(B,C,F,G)),Ha) = aa(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),some(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(C,product_prod(heap_ext(product_unit),nat)),aa(C,fun(product_prod(heap_ext(product_unit),nat),product_prod(C,product_prod(heap_ext(product_unit),nat))),product_Pair(C,product_prod(heap_ext(product_unit),nat)),Y),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H3),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),N2)))) ) ) ) ).

% execute_bind_eq_SomeI
tff(fact_119_uncurry__apply,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,fun(D,B)),A3: C,B2: D] : aa(product_prod(C,D),B,uncurry(C,D,B,F),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2)) = aa(D,B,aa(C,fun(D,B),F,A3),B2) ).

% uncurry_apply
tff(fact_120_timeFrame_Osimps_I1_J,axiom,
    ! [B: $tType,N: nat,R: B,Ha: heap_ext(product_unit),N2: nat] : heap_Time_timeFrame(B,N,aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),N2)))) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),N2)))) ).

% timeFrame.simps(1)
tff(fact_121_heap__def,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))] : heap_Time_heap(B,F) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aa(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),comp(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),some(product_prod(B,product_prod(heap_ext(product_unit),nat)))),F)) ).

% heap_def
tff(fact_122_internal__case__prod__conv,axiom,
    ! [C: $tType,B: $tType,D: $tType,C2: fun(C,fun(D,B)),A3: C,B2: D] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),produc5280177257484947105e_prod(C,D,B),C2),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2)) = aa(D,B,aa(C,fun(D,B),C2,A3),B2) ).

% internal_case_prod_conv
tff(fact_123_option_Osplit__sel,axiom,
    ! [B: $tType,C: $tType,P: fun(B,$o),F1: B,F22: fun(C,B),Option: option(C)] :
      ( aa(B,$o,P,aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),case_option(B,C),F1),F22),Option))
    <=> ( ( ( Option = none(C) )
         => aa(B,$o,P,F1) )
        & ( ( Option = aa(C,option(C),some(C),aa(option(C),C,the2(C),Option)) )
         => aa(B,$o,P,aa(C,B,F22,aa(option(C),C,the2(C),Option))) ) ) ) ).

% option.split_sel
tff(fact_124_option_Osplit__sel__asm,axiom,
    ! [B: $tType,C: $tType,P: fun(B,$o),F1: B,F22: fun(C,B),Option: option(C)] :
      ( aa(B,$o,P,aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),case_option(B,C),F1),F22),Option))
    <=> ~ ( ( ( Option = none(C) )
            & ~ aa(B,$o,P,F1) )
          | ( ( Option = aa(C,option(C),some(C),aa(option(C),C,the2(C),Option)) )
            & ~ aa(B,$o,P,aa(C,B,F22,aa(option(C),C,the2(C),Option))) ) ) ) ).

% option.split_sel_asm
tff(fact_125_fold__atLeastAtMost__nat_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))] :
      ~ ! [F3: fun(nat,fun(B,B)),A5: nat,B3: nat,Acc: B] : X2 != aa(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),aa(fun(nat,fun(B,B)),fun(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))),product_Pair(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),F3),aa(product_prod(nat,B),product_prod(nat,product_prod(nat,B)),aa(nat,fun(product_prod(nat,B),product_prod(nat,product_prod(nat,B))),product_Pair(nat,product_prod(nat,B)),A5),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),B3),Acc))) ).

% fold_atLeastAtMost_nat.cases
tff(fact_126_one__natural_Orsp,axiom,
    one_one(nat) = one_one(nat) ).

% one_natural.rsp
tff(fact_127_timeFrame_Opelims,axiom,
    ! [B: $tType,X2: nat,Xa: option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Y: option(product_prod(B,product_prod(heap_ext(product_unit),nat)))] :
      ( ( heap_Time_timeFrame(B,X2,Xa) = Y )
     => ( aa(product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),$o,accp(product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_T5500966940807335491me_rel(B)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(nat,fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),product_Pair(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),X2),Xa))
       => ( ! [R2: B,H: heap_ext(product_unit),N4: nat] :
              ( ( Xa = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H),N4))) )
             => ( ( Y = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X2),N4)))) )
               => ~ aa(product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),$o,accp(product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_T5500966940807335491me_rel(B)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(nat,fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),product_Pair(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),X2),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H),N4))))) ) )
         => ~ ( ( Xa = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
             => ( ( Y = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) )
               => ~ aa(product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),$o,accp(product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_T5500966940807335491me_rel(B)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(nat,fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),product_Pair(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),X2),none(product_prod(B,product_prod(heap_ext(product_unit),nat))))) ) ) ) ) ) ).

% timeFrame.pelims
tff(fact_128_add__right__cancel,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [B2: B,A3: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3) )
        <=> ( B2 = C2 ) ) ) ).

% add_right_cancel
tff(fact_129_add__left__cancel,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2) )
        <=> ( B2 = C2 ) ) ) ).

% add_left_cancel
tff(fact_130_Heap_Oinject,axiom,
    ! [B: $tType,X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),Ya: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] :
      ( ( aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),Ya) )
    <=> ( X2 = Ya ) ) ).

% Heap.inject
tff(fact_131_Heap__execute,axiom,
    ! [B: $tType,F: heap_Time_Heap(B)] : aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F)) = F ).

% Heap_execute
tff(fact_132_timeFrame__assoc,axiom,
    ! [B: $tType,N: nat,N2: nat,F: option(product_prod(B,product_prod(heap_ext(product_unit),nat)))] : heap_Time_timeFrame(B,N,heap_Time_timeFrame(B,N2,F)) = heap_Time_timeFrame(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),N2),F) ).

% timeFrame_assoc
tff(fact_133_add__right__imp__eq,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [B2: B,A3: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3) )
         => ( B2 = C2 ) ) ) ).

% add_right_imp_eq
tff(fact_134_add__left__imp__eq,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2) )
         => ( B2 = C2 ) ) ) ).

% add_left_imp_eq
tff(fact_135_ab__semigroup__add__class_Oadd_Oleft__commute,axiom,
    ! [B: $tType] :
      ( ab_semigroup_add(B)
     => ! [B2: B,A3: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ).

% ab_semigroup_add_class.add.left_commute
tff(fact_136_ab__semigroup__add__class_Oadd_Ocommute,axiom,
    ! [B: $tType] :
      ( ab_semigroup_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) ) ).

% ab_semigroup_add_class.add.commute
tff(fact_137_add_Oright__cancel,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [B2: B,A3: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3) )
        <=> ( B2 = C2 ) ) ) ).

% add.right_cancel
tff(fact_138_add_Oleft__cancel,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2) )
        <=> ( B2 = C2 ) ) ) ).

% add.left_cancel
tff(fact_139_add_Oassoc,axiom,
    ! [B: $tType] :
      ( semigroup_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ).

% add.assoc
tff(fact_140_group__cancel_Oadd2,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [B5: B,K: B,B2: B,A3: B] :
          ( ( B5 = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),B2) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B5) = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% group_cancel.add2
tff(fact_141_group__cancel_Oadd1,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [A4: B,K: B,A3: B,B2: B] :
          ( ( A4 = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),A3) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A4),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% group_cancel.add1
tff(fact_142_add__mono__thms__linordered__semiring_I4_J,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( ( I = J )
            & ( K = L ) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K) = aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L) ) ) ) ).

% add_mono_thms_linordered_semiring(4)
tff(fact_143_Heap_Oexhaust,axiom,
    ! [B: $tType,Y: heap_Time_Heap(B)] :
      ~ ! [X3: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] : Y != aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X3) ).

% Heap.exhaust
tff(fact_144_execute_Osimps,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] : aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),F)) = F ).

% execute.simps
tff(fact_145_option_Osimps_I5_J,axiom,
    ! [B: $tType,C: $tType,F1: B,F22: fun(C,B),X22: C] : aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),case_option(B,C),F1),F22),aa(C,option(C),some(C),X22)) = aa(C,B,F22,X22) ).

% option.simps(5)
tff(fact_146_option_Osimps_I4_J,axiom,
    ! [C: $tType,B: $tType,F1: B,F22: fun(C,B)] : aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),case_option(B,C),F1),F22),none(C)) = F1 ).

% option.simps(4)
tff(fact_147_effect__bindE,axiom,
    ! [C: $tType,B: $tType,F: heap_Time_Heap(C),G: fun(C,heap_Time_Heap(B)),Ha: heap_ext(product_unit),H3: heap_ext(product_unit),R3: B,N: nat] :
      ( heap_Time_effect(B,heap_Time_bind(C,B,F,G),Ha,H3,R3,N)
     => ~ ! [H4: heap_ext(product_unit),R2: C,N1: nat] :
            ( heap_Time_effect(C,F,Ha,H4,R2,N1)
           => ! [N22: nat] :
                ( heap_Time_effect(B,aa(C,heap_Time_Heap(B),G,R2),H4,H3,R3,N22)
               => ( N != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N1),N22) ) ) ) ) ).

% effect_bindE
tff(fact_148_effect__bindI,axiom,
    ! [C: $tType,B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat,G: fun(B,heap_Time_Heap(C)),H3: heap_ext(product_unit),R3: C,N2: nat] :
      ( heap_Time_effect(B,F,Ha,H2,R,N)
     => ( heap_Time_effect(C,aa(B,heap_Time_Heap(C),G,R),H2,H3,R3,N2)
       => heap_Time_effect(C,heap_Time_bind(B,C,F,G),Ha,H3,R3,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),N2)) ) ) ).

% effect_bindI
tff(fact_149_option_Ocase__eq__if,axiom,
    ! [B: $tType,C: $tType,F1: B,F22: fun(C,B),Option: option(C)] :
      aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),case_option(B,C),F1),F22),Option) = $ite(Option = none(C),F1,aa(C,B,F22,aa(option(C),C,the2(C),Option))) ).

% option.case_eq_if
tff(fact_150_uncurry__curry__id,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(product_prod(B,C),D)] : uncurry(B,C,D,product_curry(B,C,D,F)) = F ).

% uncurry_curry_id
tff(fact_151_curry__uncurry__id,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,fun(C,D))] : product_curry(B,C,D,uncurry(B,C,D,F)) = F ).

% curry_uncurry_id
tff(fact_152_accp_Ocases,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),A3: B] :
      ( aa(B,$o,accp(B,R),A3)
     => ! [Y5: B] :
          ( aa(B,$o,aa(B,fun(B,$o),R,Y5),A3)
         => aa(B,$o,accp(B,R),Y5) ) ) ).

% accp.cases
tff(fact_153_accp_Osimps,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),A3: B] :
      ( aa(B,$o,accp(B,R),A3)
    <=> ? [X4: B] :
          ( ( A3 = X4 )
          & ! [Xa2: B] :
              ( aa(B,$o,aa(B,fun(B,$o),R,Xa2),X4)
             => aa(B,$o,accp(B,R),Xa2) ) ) ) ).

% accp.simps
tff(fact_154_accpI,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),X2: B] :
      ( ! [Y4: B] :
          ( aa(B,$o,aa(B,fun(B,$o),R,Y4),X2)
         => aa(B,$o,accp(B,R),Y4) )
     => aa(B,$o,accp(B,R),X2) ) ).

% accpI
tff(fact_155_accp__induct,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),A3: B,P: fun(B,$o)] :
      ( aa(B,$o,accp(B,R),A3)
     => ( ! [X3: B] :
            ( aa(B,$o,accp(B,R),X3)
           => ( ! [Y5: B] :
                  ( aa(B,$o,aa(B,fun(B,$o),R,Y5),X3)
                 => aa(B,$o,P,Y5) )
             => aa(B,$o,P,X3) ) )
       => aa(B,$o,P,A3) ) ) ).

% accp_induct
tff(fact_156_accp__downward,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),B2: B,A3: B] :
      ( aa(B,$o,accp(B,R),B2)
     => ( aa(B,$o,aa(B,fun(B,$o),R,A3),B2)
       => aa(B,$o,accp(B,R),A3) ) ) ).

% accp_downward
tff(fact_157_not__accp__down,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),X2: B] :
      ( ~ aa(B,$o,accp(B,R4),X2)
     => ~ ! [Z3: B] :
            ( aa(B,$o,aa(B,fun(B,$o),R4,Z3),X2)
           => aa(B,$o,accp(B,R4),Z3) ) ) ).

% not_accp_down
tff(fact_158_accp__induct__rule,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),A3: B,P: fun(B,$o)] :
      ( aa(B,$o,accp(B,R),A3)
     => ( ! [X3: B] :
            ( aa(B,$o,accp(B,R),X3)
           => ( ! [Y5: B] :
                  ( aa(B,$o,aa(B,fun(B,$o),R,Y5),X3)
                 => aa(B,$o,P,Y5) )
             => aa(B,$o,P,X3) ) )
       => aa(B,$o,P,A3) ) ) ).

% accp_induct_rule
tff(fact_159_fun_Omap__comp,axiom,
    ! [D: $tType,C: $tType,E: $tType,B: $tType,G: fun(D,C),F: fun(E,D),V: fun(B,E)] : aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),G),aa(fun(B,E),fun(B,D),aa(fun(E,D),fun(fun(B,E),fun(B,D)),comp(E,D,B),F),V)) = aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),aa(fun(E,D),fun(E,C),aa(fun(D,C),fun(fun(E,D),fun(E,C)),comp(D,C,E),G),F)),V) ).

% fun.map_comp
tff(fact_160_comp__cong,axiom,
    ! [D: $tType,C: $tType,E: $tType,B: $tType,F4: $tType,F: fun(C,B),G: fun(D,C),X2: D,F2: fun(E,B),G4: fun(F4,E),X6: F4] :
      ( ( aa(C,B,F,aa(D,C,G,X2)) = aa(E,B,F2,aa(F4,E,G4,X6)) )
     => ( aa(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G),X2) = aa(F4,B,aa(fun(F4,E),fun(F4,B),aa(fun(E,B),fun(fun(F4,E),fun(F4,B)),comp(E,B,F4),F2),G4),X6) ) ) ).

% comp_cong
tff(fact_161_curryI,axiom,
    ! [B: $tType,C: $tType,F: fun(product_prod(B,C),$o),A3: B,B2: C] :
      ( aa(product_prod(B,C),$o,F,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2))
     => aa(C,$o,aa(B,fun(C,$o),product_curry(B,C,$o,F),A3),B2) ) ).

% curryI
tff(fact_162_curry__conv,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(product_prod(C,D),B),A3: C,B2: D] : aa(D,B,aa(C,fun(D,B),product_curry(C,D,B,F),A3),B2) = aa(product_prod(C,D),B,F,aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2)) ).

% curry_conv
tff(fact_163_curryE,axiom,
    ! [B: $tType,C: $tType,F: fun(product_prod(B,C),$o),A3: B,B2: C] :
      ( aa(C,$o,aa(B,fun(C,$o),product_curry(B,C,$o,F),A3),B2)
     => aa(product_prod(B,C),$o,F,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)) ) ).

% curryE
tff(fact_164_curryD,axiom,
    ! [B: $tType,C: $tType,F: fun(product_prod(B,C),$o),A3: B,B2: C] :
      ( aa(C,$o,aa(B,fun(C,$o),product_curry(B,C,$o,F),A3),B2)
     => aa(product_prod(B,C),$o,F,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)) ) ).

% curryD
tff(fact_165_fold__atLeastAtMost__nat_Opinduct,axiom,
    ! [B: $tType,A0: fun(nat,fun(B,B)),A1: nat,A22: nat,A32: B,P: fun(fun(nat,fun(B,B)),fun(nat,fun(nat,fun(B,$o))))] :
      ( aa(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),$o,accp(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),set_fo1817059534552279752at_rel(B)),aa(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),aa(fun(nat,fun(B,B)),fun(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))),product_Pair(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),A0),aa(product_prod(nat,B),product_prod(nat,product_prod(nat,B)),aa(nat,fun(product_prod(nat,B),product_prod(nat,product_prod(nat,B))),product_Pair(nat,product_prod(nat,B)),A1),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),A22),A32))))
     => ( ! [F3: fun(nat,fun(B,B)),A5: nat,B3: nat,Acc: B] :
            ( aa(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),$o,accp(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),set_fo1817059534552279752at_rel(B)),aa(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),aa(fun(nat,fun(B,B)),fun(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))),product_Pair(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),F3),aa(product_prod(nat,B),product_prod(nat,product_prod(nat,B)),aa(nat,fun(product_prod(nat,B),product_prod(nat,product_prod(nat,B))),product_Pair(nat,product_prod(nat,B)),A5),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),B3),Acc))))
           => ( ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B3),A5)
               => aa(B,$o,aa(nat,fun(B,$o),aa(nat,fun(nat,fun(B,$o)),aa(fun(nat,fun(B,B)),fun(nat,fun(nat,fun(B,$o))),P,F3),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A5),one_one(nat))),B3),aa(B,B,aa(nat,fun(B,B),F3,A5),Acc)) )
             => aa(B,$o,aa(nat,fun(B,$o),aa(nat,fun(nat,fun(B,$o)),aa(fun(nat,fun(B,B)),fun(nat,fun(nat,fun(B,$o))),P,F3),A5),B3),Acc) ) )
       => aa(B,$o,aa(nat,fun(B,$o),aa(nat,fun(nat,fun(B,$o)),aa(fun(nat,fun(B,B)),fun(nat,fun(nat,fun(B,$o))),P,A0),A1),A22),A32) ) ) ).

% fold_atLeastAtMost_nat.pinduct
tff(fact_166_in__lex__prod,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,A6: B,B4: C,R: set(product_prod(B,B)),S: set(product_prod(C,C))] :
      ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A6),B4)),lex_prod(B,C,R,S))
    <=> ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A6),R)
        | ( ( A3 = A6 )
          & member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),B2),B4),S) ) ) ) ).

% in_lex_prod
tff(fact_167_rewriteR__comp__comp2,axiom,
    ! [D: $tType,C: $tType,F4: $tType,E: $tType,B: $tType,G: fun(D,C),Ha: fun(B,D),R1: fun(E,C),R22: fun(B,E),F: fun(C,F4),L: fun(E,F4)] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),G),Ha) = aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),R1),R22) )
     => ( ( aa(fun(E,C),fun(E,F4),aa(fun(C,F4),fun(fun(E,C),fun(E,F4)),comp(C,F4,E),F),R1) = L )
       => ( aa(fun(B,D),fun(B,F4),aa(fun(D,F4),fun(fun(B,D),fun(B,F4)),comp(D,F4,B),aa(fun(D,C),fun(D,F4),aa(fun(C,F4),fun(fun(D,C),fun(D,F4)),comp(C,F4,D),F),G)),Ha) = aa(fun(B,E),fun(B,F4),aa(fun(E,F4),fun(fun(B,E),fun(B,F4)),comp(E,F4,B),L),R22) ) ) ) ).

% rewriteR_comp_comp2
tff(fact_168_rewriteL__comp__comp2,axiom,
    ! [B: $tType,D: $tType,C: $tType,E: $tType,F4: $tType,F: fun(D,C),G: fun(B,D),L1: fun(E,C),L2: fun(B,E),Ha: fun(F4,B),R: fun(F4,E)] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G) = aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),L1),L2) )
     => ( ( aa(fun(F4,B),fun(F4,E),aa(fun(B,E),fun(fun(F4,B),fun(F4,E)),comp(B,E,F4),L2),Ha) = R )
       => ( aa(fun(F4,D),fun(F4,C),aa(fun(D,C),fun(fun(F4,D),fun(F4,C)),comp(D,C,F4),F),aa(fun(F4,B),fun(F4,D),aa(fun(B,D),fun(fun(F4,B),fun(F4,D)),comp(B,D,F4),G),Ha)) = aa(fun(F4,E),fun(F4,C),aa(fun(E,C),fun(fun(F4,E),fun(F4,C)),comp(E,C,F4),L1),R) ) ) ) ).

% rewriteL_comp_comp2
tff(fact_169_rewriteR__comp__comp,axiom,
    ! [D: $tType,E: $tType,C: $tType,B: $tType,G: fun(D,C),Ha: fun(B,D),R: fun(B,C),F: fun(C,E)] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),G),Ha) = R )
     => ( aa(fun(B,D),fun(B,E),aa(fun(D,E),fun(fun(B,D),fun(B,E)),comp(D,E,B),aa(fun(D,C),fun(D,E),aa(fun(C,E),fun(fun(D,C),fun(D,E)),comp(C,E,D),F),G)),Ha) = aa(fun(B,C),fun(B,E),aa(fun(C,E),fun(fun(B,C),fun(B,E)),comp(C,E,B),F),R) ) ) ).

% rewriteR_comp_comp
tff(fact_170_rewriteL__comp__comp,axiom,
    ! [D: $tType,C: $tType,B: $tType,E: $tType,F: fun(D,C),G: fun(B,D),L: fun(B,C),Ha: fun(E,B)] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G) = L )
     => ( aa(fun(E,D),fun(E,C),aa(fun(D,C),fun(fun(E,D),fun(E,C)),comp(D,C,E),F),aa(fun(E,B),fun(E,D),aa(fun(B,D),fun(fun(E,B),fun(E,D)),comp(B,D,E),G),Ha)) = aa(fun(E,B),fun(E,C),aa(fun(B,C),fun(fun(E,B),fun(E,C)),comp(B,C,E),L),Ha) ) ) ).

% rewriteL_comp_comp
tff(fact_171_type__copy__map__cong0,axiom,
    ! [C: $tType,E: $tType,F4: $tType,B: $tType,D: $tType,M2: fun(C,B),G: fun(D,C),X2: D,N5: fun(E,B),Ha: fun(D,E),F: fun(B,F4)] :
      ( ( aa(C,B,M2,aa(D,C,G,X2)) = aa(E,B,N5,aa(D,E,Ha,X2)) )
     => ( aa(D,F4,aa(fun(D,C),fun(D,F4),aa(fun(C,F4),fun(fun(D,C),fun(D,F4)),comp(C,F4,D),aa(fun(C,B),fun(C,F4),aa(fun(B,F4),fun(fun(C,B),fun(C,F4)),comp(B,F4,C),F),M2)),G),X2) = aa(D,F4,aa(fun(D,E),fun(D,F4),aa(fun(E,F4),fun(fun(D,E),fun(D,F4)),comp(E,F4,D),aa(fun(E,B),fun(E,F4),aa(fun(B,F4),fun(fun(E,B),fun(E,F4)),comp(B,F4,E),F),N5)),Ha),X2) ) ) ).

% type_copy_map_cong0
tff(fact_172_comp__apply__eq,axiom,
    ! [C: $tType,E: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(D,C),X2: D,Ha: fun(E,B),K: fun(D,E)] :
      ( ( aa(C,B,F,aa(D,C,G,X2)) = aa(E,B,Ha,aa(D,E,K,X2)) )
     => ( aa(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G),X2) = aa(D,B,aa(fun(D,E),fun(D,B),aa(fun(E,B),fun(fun(D,E),fun(D,B)),comp(E,B,D),Ha),K),X2) ) ) ).

% comp_apply_eq
tff(fact_173_effect__returnE,axiom,
    ! [B: $tType,X2: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,aa(B,heap_Time_Heap(B),heap_Time_return(B),X2),Ha,H2,R,N)
     => ~ ( ( R = X2 )
         => ( ( H2 = Ha )
           => ( N != one_one(nat) ) ) ) ) ).

% effect_returnE
tff(fact_174_effect__returnI,axiom,
    ! [B: $tType,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),X2: B] :
      ( ( Ha = H2 )
     => heap_Time_effect(B,aa(B,heap_Time_Heap(B),heap_Time_return(B),X2),Ha,H2,X2,one_one(nat)) ) ).

% effect_returnI
tff(fact_175_add_Oright__commute,axiom,
    ! [B: $tType] :
      ( ab_semigroup_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),B2) ) ).

% add.right_commute
tff(fact_176_add__less__cancel__right,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% add_less_cancel_right
tff(fact_177_add__less__cancel__left,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [C2: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% add_less_cancel_left
tff(fact_178_fold__if__return,axiom,
    ! [B: $tType,B2: $o,C2: B,D3: B] :
      $ite((B2),aa(B,heap_Time_Heap(B),heap_Time_return(B),C2),aa(B,heap_Time_Heap(B),heap_Time_return(B),D3)) = aa(B,heap_Time_Heap(B),heap_Time_return(B),
        $ite((B2),C2,D3)) ).

% fold_if_return
tff(fact_179_add__less__imp__less__right,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2))
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% add_less_imp_less_right
tff(fact_180_add__less__imp__less__left,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [C2: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2))
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% add_less_imp_less_left
tff(fact_181_add__strict__right__mono,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ) ).

% add_strict_right_mono
tff(fact_182_add__strict__left__mono,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)) ) ) ).

% add_strict_left_mono
tff(fact_183_add__strict__mono,axiom,
    ! [B: $tType] :
      ( strict9044650504122735259up_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),D3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),D3)) ) ) ) ).

% add_strict_mono
tff(fact_184_add__mono__thms__linordered__field_I1_J,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),I),J)
            & ( K = L ) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_field(1)
tff(fact_185_add__mono__thms__linordered__field_I2_J,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( ( I = J )
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),K),L) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_field(2)
tff(fact_186_add__mono__thms__linordered__field_I5_J,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),I),J)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),K),L) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_field(5)
tff(fact_187_success__returnI,axiom,
    ! [B: $tType,X2: B,Ha: heap_ext(product_unit)] : heap_Time_success(B,aa(B,heap_Time_Heap(B),heap_Time_return(B),X2),Ha) ).

% success_returnI
tff(fact_188_fails__return,axiom,
    ! [B: $tType,X2: B,Ha: heap_ext(product_unit)] : ~ time_fails(B,aa(B,heap_Time_Heap(B),heap_Time_return(B),X2),Ha) ).

% fails_return
tff(fact_189_add_Oright__assoc,axiom,
    ! [B: $tType] :
      ( ab_semigroup_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ).

% add.right_assoc
tff(fact_190_nat__add__left__cancel__less,axiom,
    ! [K: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N) ) ).

% nat_add_left_cancel_less
tff(fact_191_less__option__Some,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B,Y: B] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less(option(B)),aa(B,option(B),some(B),X2)),aa(B,option(B),some(B),Y))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y) ) ) ).

% less_option_Some
tff(fact_192_fold__atLeastAtMost__nat_Opelims,axiom,
    ! [B: $tType,X2: fun(nat,fun(B,B)),Xa: nat,Xb: nat,Xc: B,Y: B] :
      ( ( set_fo6178422350223883121st_nat(B,X2,Xa,Xb,Xc) = Y )
     => ( aa(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),$o,accp(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),set_fo1817059534552279752at_rel(B)),aa(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),aa(fun(nat,fun(B,B)),fun(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))),product_Pair(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),X2),aa(product_prod(nat,B),product_prod(nat,product_prod(nat,B)),aa(nat,fun(product_prod(nat,B),product_prod(nat,product_prod(nat,B))),product_Pair(nat,product_prod(nat,B)),Xa),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),Xb),Xc))))
       => ~ ( ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Xb),Xa),Xc,set_fo6178422350223883121st_nat(B,X2,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Xa),one_one(nat)),Xb,aa(B,B,aa(nat,fun(B,B),X2,Xa),Xc))) )
           => ~ aa(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),$o,accp(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),set_fo1817059534552279752at_rel(B)),aa(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),aa(fun(nat,fun(B,B)),fun(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))),product_Pair(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),X2),aa(product_prod(nat,B),product_prod(nat,product_prod(nat,B)),aa(nat,fun(product_prod(nat,B),product_prod(nat,product_prod(nat,B))),product_Pair(nat,product_prod(nat,B)),Xa),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),Xb),Xc)))) ) ) ) ).

% fold_atLeastAtMost_nat.pelims
tff(fact_193_fold__atLeastAtMost__nat_Opsimps,axiom,
    ! [B: $tType,F: fun(nat,fun(B,B)),A3: nat,B2: nat,Acc2: B] :
      ( aa(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),$o,accp(product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),set_fo1817059534552279752at_rel(B)),aa(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),aa(fun(nat,fun(B,B)),fun(product_prod(nat,product_prod(nat,B)),product_prod(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B)))),product_Pair(fun(nat,fun(B,B)),product_prod(nat,product_prod(nat,B))),F),aa(product_prod(nat,B),product_prod(nat,product_prod(nat,B)),aa(nat,fun(product_prod(nat,B),product_prod(nat,product_prod(nat,B))),product_Pair(nat,product_prod(nat,B)),A3),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),B2),Acc2))))
     => ( set_fo6178422350223883121st_nat(B,F,A3,B2,Acc2) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),A3),Acc2,set_fo6178422350223883121st_nat(B,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),one_one(nat)),B2,aa(B,B,aa(nat,fun(B,B),F,A3),Acc2))) ) ) ).

% fold_atLeastAtMost_nat.psimps
tff(fact_194_in__measure,axiom,
    ! [B: $tType,X2: B,Y: B,F: fun(B,nat)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measure(B,F))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y)) ) ).

% in_measure
tff(fact_195_less__add__one,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B] : aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))) ) ).

% less_add_one
tff(fact_196_add__mono1,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),one_one(B))) ) ) ).

% add_mono1
tff(fact_197_lift__collapse,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: C] : aa(C,heap_Time_Heap(B),heap_Time_lift(C,B,F),X2) = aa(B,heap_Time_Heap(B),heap_Time_return(B),aa(C,B,F,X2)) ).

% lift_collapse
tff(fact_198_add__lessD1,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J)),K)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),K) ) ).

% add_lessD1
tff(fact_199_add__less__mono,axiom,
    ! [I: nat,J: nat,K: nat,L: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),L)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),L)) ) ) ).

% add_less_mono
tff(fact_200_not__add__less1,axiom,
    ! [I: 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),J)),I) ).

% not_add_less1
tff(fact_201_less__option__None,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B)] : ~ aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less(option(B)),X2),none(B)) ) ).

% less_option_None
tff(fact_202_less__option__None__Some__code,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B] : aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less(option(B)),none(B)),aa(B,option(B),some(B),X2)) ) ).

% less_option_None_Some_code
tff(fact_203_less__option__None__Some,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B] : aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less(option(B)),none(B)),aa(B,option(B),some(B),X2)) ) ).

% less_option_None_Some
tff(fact_204_less__option__None__is__Some,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B)] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less(option(B)),none(B)),X2)
         => ? [Z3: B] : X2 = aa(B,option(B),some(B),Z3) ) ) ).

% less_option_None_is_Some
tff(fact_205_lift__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] : heap_Time_lift(B,C,F) = aa(fun(B,C),fun(B,heap_Time_Heap(C)),aa(fun(C,heap_Time_Heap(C)),fun(fun(B,C),fun(B,heap_Time_Heap(C))),comp(C,heap_Time_Heap(C),B),heap_Time_return(C)),F) ).

% lift_def
tff(fact_206_fold__atLeastAtMost__nat_Osimps,axiom,
    ! [B: $tType,F: fun(nat,fun(B,B)),A3: nat,B2: nat,Acc2: B] :
      set_fo6178422350223883121st_nat(B,F,A3,B2,Acc2) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),A3),Acc2,set_fo6178422350223883121st_nat(B,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),one_one(nat)),B2,aa(B,B,aa(nat,fun(B,B),F,A3),Acc2))) ).

% fold_atLeastAtMost_nat.simps
tff(fact_207_fold__atLeastAtMost__nat_Oelims,axiom,
    ! [B: $tType,X2: fun(nat,fun(B,B)),Xa: nat,Xb: nat,Xc: B,Y: B] :
      ( ( set_fo6178422350223883121st_nat(B,X2,Xa,Xb,Xc) = Y )
     => ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Xb),Xa),Xc,set_fo6178422350223883121st_nat(B,X2,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Xa),one_one(nat)),Xb,aa(B,B,aa(nat,fun(B,B),X2,Xa),Xc))) ) ) ).

% fold_atLeastAtMost_nat.elims
tff(fact_208_less__add__eq__less,axiom,
    ! [K: nat,L: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),L)
     => ( ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),L) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N) )
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N) ) ) ).

% less_add_eq_less
tff(fact_209_trans__less__add2,axiom,
    ! [I: nat,J: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),J)) ) ).

% trans_less_add2
tff(fact_210_trans__less__add1,axiom,
    ! [I: nat,J: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),M)) ) ).

% trans_less_add1
tff(fact_211_add__less__mono1,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K)) ) ).

% add_less_mono1
tff(fact_212_not__add__less2,axiom,
    ! [J: nat,I: nat] : ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),I)),I) ).

% not_add_less2
tff(fact_213_less__numeral__extra_I4_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),one_one(B)) ) ).

% less_numeral_extra(4)
tff(fact_214_mlex__iff,axiom,
    ! [B: $tType,X2: B,Y: B,F: fun(B,nat),R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),mlex_prod(B,F,R4))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y))
        | ( ( aa(B,nat,F,X2) = aa(B,nat,F,Y) )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R4) ) ) ) ).

% mlex_iff
tff(fact_215_mlex__less,axiom,
    ! [B: $tType,F: fun(B,nat),X2: B,Y: B,R4: set(product_prod(B,B))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),mlex_prod(B,F,R4)) ) ).

% mlex_less
tff(fact_216_pairself_Opelims,axiom,
    ! [B: $tType,C: $tType,X2: fun(C,B),Xa: product_prod(C,C),Y: product_prod(B,B)] :
      ( ( aa(product_prod(C,C),product_prod(B,B),pairself(C,B,X2),Xa) = Y )
     => ( aa(product_prod(fun(C,B),product_prod(C,C)),$o,accp(product_prod(fun(C,B),product_prod(C,C)),pairself_rel(C,B)),aa(product_prod(C,C),product_prod(fun(C,B),product_prod(C,C)),aa(fun(C,B),fun(product_prod(C,C),product_prod(fun(C,B),product_prod(C,C))),product_Pair(fun(C,B),product_prod(C,C)),X2),Xa))
       => ~ ! [A5: C,B3: C] :
              ( ( Xa = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A5),B3) )
             => ( ( Y = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(C,B,X2,A5)),aa(C,B,X2,B3)) )
               => ~ aa(product_prod(fun(C,B),product_prod(C,C)),$o,accp(product_prod(fun(C,B),product_prod(C,C)),pairself_rel(C,B)),aa(product_prod(C,C),product_prod(fun(C,B),product_prod(C,C)),aa(fun(C,B),fun(product_prod(C,C),product_prod(fun(C,B),product_prod(C,C))),product_Pair(fun(C,B),product_prod(C,C)),X2),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A5),B3))) ) ) ) ) ).

% pairself.pelims
tff(fact_217_execute__return,axiom,
    ! [B: $tType,X2: B] : aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),aa(B,heap_Time_Heap(B),heap_Time_return(B),X2)) = aa(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),comp(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),some(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_aa(B,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),X2)) ).

% execute_return
tff(fact_218_same__fstI,axiom,
    ! [C: $tType,B: $tType,P: fun(B,$o),X2: B,Y6: C,Y: C,R4: fun(B,set(product_prod(C,C)))] :
      ( aa(B,$o,P,X2)
     => ( member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y6),Y),aa(B,set(product_prod(C,C)),R4,X2))
       => member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y6)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),same_fst(B,C,P,R4)) ) ) ).

% same_fstI
tff(fact_219_zero__less__two,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),one_one(B))) ) ).

% zero_less_two
tff(fact_220_is__num__normalize_I1_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ).

% is_num_normalize(1)
tff(fact_221_add_Osafe__commute,axiom,
    ! [B: $tType] :
      ( ab_semigroup_add(B)
     => ! [X2: B,Y: B,A3: B,B2: B] :
          ( syntax7388354845996824322omatch(B,B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y),A3)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) ) ) ) ).

% add.safe_commute
tff(fact_222_bijective__def,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C))] :
      ( bijective(B,C,R4)
    <=> ( ! [X4: B,Y3: C,Z4: C] :
            ( ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Y3),R4)
              & member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Z4),R4) )
           => ( Y3 = Z4 ) )
        & ! [X4: B,Y3: B,Z4: C] :
            ( ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Z4),R4)
              & member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y3),Z4),R4) )
           => ( X4 = Y3 ) ) ) ) ).

% bijective_def
tff(fact_223_ssubst__Pair__rhs,axiom,
    ! [C: $tType,B: $tType,R: B,S: C,R4: set(product_prod(B,C)),S3: C] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),R),S),R4)
     => ( ( S3 = S )
       => member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),R),S3),R4) ) ) ).

% ssubst_Pair_rhs
tff(fact_224_add__is__0,axiom,
    ! [M: nat,N: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N) = zero_zero(nat) )
    <=> ( ( M = zero_zero(nat) )
        & ( N = zero_zero(nat) ) ) ) ).

% add_is_0
tff(fact_225_Nat_Oadd__0__right,axiom,
    ! [M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),zero_zero(nat)) = M ).

% Nat.add_0_right
tff(fact_226_timeFrame__zero,axiom,
    ! [B: $tType,Ha: option(product_prod(B,product_prod(heap_ext(product_unit),nat)))] : heap_Time_timeFrame(B,zero_zero(nat),Ha) = Ha ).

% timeFrame_zero
tff(fact_227_Heap__Time__Monad_Obind__bind,axiom,
    ! [D: $tType,B: $tType,C: $tType,F: heap_Time_Heap(D),G: fun(D,heap_Time_Heap(C)),K: fun(C,heap_Time_Heap(B))] : heap_Time_bind(C,B,heap_Time_bind(D,C,F,G),K) = heap_Time_bind(D,B,F,aa(fun(C,heap_Time_Heap(B)),fun(D,heap_Time_Heap(B)),aTP_Lamp_ab(fun(D,heap_Time_Heap(C)),fun(fun(C,heap_Time_Heap(B)),fun(D,heap_Time_Heap(B))),G),K)) ).

% Heap_Time_Monad.bind_bind
tff(fact_228_not__gr__zero,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [N: B] :
          ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),N)
        <=> ( N = zero_zero(B) ) ) ) ).

% not_gr_zero
tff(fact_229_add__0,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),zero_zero(B)),A3) = A3 ) ).

% add_0
tff(fact_230_zero__eq__add__iff__both__eq__0,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [X2: B,Y: B] :
          ( ( zero_zero(B) = aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y) )
        <=> ( ( X2 = zero_zero(B) )
            & ( Y = zero_zero(B) ) ) ) ) ).

% zero_eq_add_iff_both_eq_0
tff(fact_231_add__eq__0__iff__both__eq__0,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y) = zero_zero(B) )
        <=> ( ( X2 = zero_zero(B) )
            & ( Y = zero_zero(B) ) ) ) ) ).

% add_eq_0_iff_both_eq_0
tff(fact_232_add__cancel__right__right,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [A3: B,B2: B] :
          ( ( A3 = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) )
        <=> ( B2 = zero_zero(B) ) ) ) ).

% add_cancel_right_right
tff(fact_233_add__cancel__right__left,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [A3: B,B2: B] :
          ( ( A3 = aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) )
        <=> ( B2 = zero_zero(B) ) ) ) ).

% add_cancel_right_left
tff(fact_234_add__cancel__left__right,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = A3 )
        <=> ( B2 = zero_zero(B) ) ) ) ).

% add_cancel_left_right
tff(fact_235_add__cancel__left__left,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [B2: B,A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) = A3 )
        <=> ( B2 = zero_zero(B) ) ) ) ).

% add_cancel_left_left
tff(fact_236_double__zero__sym,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( ( zero_zero(B) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% double_zero_sym
tff(fact_237_add_Oright__neutral,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),zero_zero(B)) = A3 ) ).

% add.right_neutral
tff(fact_238_add__gr__0,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M)
        | aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N) ) ) ).

% add_gr_0
tff(fact_239_less__one,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),one_one(nat))
    <=> ( N = zero_zero(nat) ) ) ).

% less_one
tff(fact_240_some__opt__eq__trivial,axiom,
    ! [B: $tType,X2: B] : eps_Opt(B,aTP_Lamp_ac(B,fun(B,$o),X2)) = aa(B,option(B),some(B),X2) ).

% some_opt_eq_trivial
tff(fact_241_zero__less__double__add__iff__zero__less__single__add,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3) ) ) ).

% zero_less_double_add_iff_zero_less_single_add
tff(fact_242_double__add__less__zero__iff__single__add__less__zero,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3)),zero_zero(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% double_add_less_zero_iff_single_add_less_zero
tff(fact_243_less__add__same__cancel2,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2) ) ) ).

% less_add_same_cancel2
tff(fact_244_less__add__same__cancel1,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2) ) ) ).

% less_add_same_cancel1
tff(fact_245_add__less__same__cancel2,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% add_less_same_cancel2
tff(fact_246_add__less__same__cancel1,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% add_less_same_cancel1
tff(fact_247_some__opt__false__trivial,axiom,
    ! [B: $tType] : eps_Opt(B,aTP_Lamp_ad(B,$o)) = none(B) ).

% some_opt_false_trivial
tff(fact_248_zero__reorient,axiom,
    ! [B: $tType] :
      ( zero(B)
     => ! [X2: B] :
          ( ( zero_zero(B) = X2 )
        <=> ( X2 = zero_zero(B) ) ) ) ).

% zero_reorient
tff(fact_249_fun_Omap__ident,axiom,
    ! [C: $tType,B: $tType,T2: fun(B,C)] : aa(fun(B,C),fun(B,C),aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),aTP_Lamp_ae(C,C)),T2) = T2 ).

% fun.map_ident
tff(fact_250_option_Odisc__eq__case_I2_J,axiom,
    ! [B: $tType,Option: option(B)] :
      ( ( Option != none(B) )
    <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),$false),aTP_Lamp_af(B,$o)),Option) ) ).

% option.disc_eq_case(2)
tff(fact_251_option_Odisc__eq__case_I1_J,axiom,
    ! [B: $tType,Option: option(B)] :
      ( ( Option = none(B) )
    <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),$true),aTP_Lamp_ad(B,$o)),Option) ) ).

% option.disc_eq_case(1)
tff(fact_252_option_Ocase__distrib,axiom,
    ! [C: $tType,B: $tType,D: $tType,Ha: fun(C,B),F1: C,F22: fun(D,C),Option: option(D)] : aa(C,B,Ha,aa(option(D),C,aa(fun(D,C),fun(option(D),C),aa(C,fun(fun(D,C),fun(option(D),C)),case_option(C,D),F1),F22),Option)) = aa(option(D),B,aa(fun(D,B),fun(option(D),B),aa(B,fun(fun(D,B),fun(option(D),B)),case_option(B,D),aa(C,B,Ha,F1)),aa(fun(D,C),fun(D,B),aTP_Lamp_ag(fun(C,B),fun(fun(D,C),fun(D,B)),Ha),F22)),Option) ).

% option.case_distrib
tff(fact_253_effect__LetI,axiom,
    ! [C: $tType,B: $tType,X2: B,T2: B,F: fun(B,heap_Time_Heap(C)),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: C,N: nat] :
      ( ( X2 = T2 )
     => ( heap_Time_effect(C,aa(B,heap_Time_Heap(C),F,X2),Ha,H2,R,N)
       => heap_Time_effect(C,aa(B,heap_Time_Heap(C),F,T2),Ha,H2,R,N) ) ) ).

% effect_LetI
tff(fact_254_distrib__if__bind,axiom,
    ! [B: $tType,C: $tType,B2: $o,C2: heap_Time_Heap(C),D3: heap_Time_Heap(C),F: fun(C,heap_Time_Heap(B))] :
      heap_Time_bind(C,B,
        $ite((B2),C2,D3),
        F) = $ite((B2),heap_Time_bind(C,B,C2,F),heap_Time_bind(C,B,D3,F)) ).

% distrib_if_bind
tff(fact_255_success__LetI,axiom,
    ! [B: $tType,C: $tType,X2: B,T2: B,F: fun(B,heap_Time_Heap(C)),Ha: heap_ext(product_unit)] :
      ( ( X2 = T2 )
     => ( heap_Time_success(C,aa(B,heap_Time_Heap(C),F,X2),Ha)
       => heap_Time_success(C,aa(B,heap_Time_Heap(C),F,T2),Ha) ) ) ).

% success_LetI
tff(fact_256_curry__K,axiom,
    ! [C: $tType,B: $tType,D: $tType,C2: D,X: B,Xa3: C] : aa(C,D,aa(B,fun(C,D),product_curry(B,C,D,aTP_Lamp_ah(D,fun(product_prod(B,C),D),C2)),X),Xa3) = C2 ).

% curry_K
tff(fact_257_case__optionE,axiom,
    ! [B: $tType,P: $o,Q: fun(B,$o),X2: option(B)] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),(P)),Q),X2)
     => ( ( ( X2 = none(B) )
         => ~ (P) )
       => ~ ! [Y4: B] :
              ( ( X2 = aa(B,option(B),some(B),Y4) )
             => ~ aa(B,$o,Q,Y4) ) ) ) ).

% case_optionE
tff(fact_258_curry__def,axiom,
    ! [D: $tType,B: $tType,C: $tType,X: fun(product_prod(B,C),D),Xa3: B,Xb2: C] : aa(C,D,aa(B,fun(C,D),product_curry(B,C,D,X),Xa3),Xb2) = aa(product_prod(B,C),D,X,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa3),Xb2)) ).

% curry_def
tff(fact_259_combine__options__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),X2: option(B),Y: option(B)] : combine_options(B,F,X2,Y) = aa(option(B),option(B),aa(fun(B,option(B)),fun(option(B),option(B)),aa(option(B),fun(fun(B,option(B)),fun(option(B),option(B))),case_option(option(B),B),Y),aa(option(B),fun(B,option(B)),aTP_Lamp_aj(fun(B,fun(B,B)),fun(option(B),fun(B,option(B))),F),Y)),X2) ).

% combine_options_def
tff(fact_260_less__option__def,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B),Y: option(B)] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less(option(B)),X2),Y)
        <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),$false),aTP_Lamp_al(option(B),fun(B,$o),X2)),Y) ) ) ).

% less_option_def
tff(fact_261_zero__less__iff__neq__zero,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [N: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),N)
        <=> ( N != zero_zero(B) ) ) ) ).

% zero_less_iff_neq_zero
tff(fact_262_gr__implies__not__zero,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [M: B,N: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),N)
         => ( N != zero_zero(B) ) ) ) ).

% gr_implies_not_zero
tff(fact_263_not__less__zero,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [N: B] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),N),zero_zero(B)) ) ).

% not_less_zero
tff(fact_264_gr__zeroI,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [N: B] :
          ( ( N != zero_zero(B) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),N) ) ) ).

% gr_zeroI
tff(fact_265_add_Ogroup__left__neutral,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),zero_zero(B)),A3) = A3 ) ).

% add.group_left_neutral
tff(fact_266_add_Ocomm__neutral,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),zero_zero(B)) = A3 ) ).

% add.comm_neutral
tff(fact_267_comm__monoid__add__class_Oadd__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),zero_zero(B)),A3) = A3 ) ).

% comm_monoid_add_class.add_0
tff(fact_268_zero__neq__one,axiom,
    ! [B: $tType] :
      ( zero_neq_one(B)
     => ( zero_zero(B) != one_one(B) ) ) ).

% zero_neq_one
tff(fact_269_array__make,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B] : aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2) = array_make(B,N,aTP_Lamp_am(B,fun(nat,B),X2)) ) ).

% array_make
tff(fact_270_plus__nat_Oadd__0,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),zero_zero(nat)),N) = N ).

% plus_nat.add_0
tff(fact_271_add__eq__self__zero,axiom,
    ! [M: nat,N: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N) = M )
     => ( N = zero_zero(nat) ) ) ).

% add_eq_self_zero
tff(fact_272_less__numeral__extra_I1_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),one_one(B)) ) ).

% less_numeral_extra(1)
tff(fact_273_ureturn__def,axiom,
    ! [B: $tType,X2: B] : aa(B,heap_Time_Heap(B),heap_Time_ureturn(B),X2) = heap_Time_heap(B,aTP_Lamp_an(B,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),X2)) ).

% ureturn_def
tff(fact_274_raise__def,axiom,
    ! [B: $tType,S: list(char)] : heap_Time_raise(B,S) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aTP_Lamp_ao(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))) ).

% raise_def
tff(fact_275_bind__lift,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(C),G: fun(C,B)] : heap_Time_bind(C,B,F,heap_Time_lift(C,B,G)) = heap_Time_bind(C,B,F,aTP_Lamp_ap(fun(C,B),fun(C,heap_Time_Heap(B)),G)) ).

% bind_lift
tff(fact_276_guard__def,axiom,
    ! [B: $tType,P: fun(heap_ext(product_unit),$o),F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))] : heap_Time_guard(B,P,F) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aa(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_aq(fun(heap_ext(product_unit),$o),fun(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),P),F)) ).

% guard_def
tff(fact_277_pos__add__strict,axiom,
    ! [B: $tType] :
      ( strict7427464778891057005id_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),C2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)) ) ) ) ).

% pos_add_strict
tff(fact_278_canonically__ordered__monoid__add__class_OlessE,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ~ ! [C3: B] :
                ( ( B2 = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C3) )
               => ( C3 = zero_zero(B) ) ) ) ) ).

% canonically_ordered_monoid_add_class.lessE
tff(fact_279_add__pos__pos,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% add_pos_pos
tff(fact_280_add__neg__neg,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),zero_zero(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),zero_zero(B)) ) ) ) ).

% add_neg_neg
tff(fact_281_add__less__zeroD,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),zero_zero(B))
            | aa(B,$o,aa(B,fun(B,$o),ord_less(B),Y),zero_zero(B)) ) ) ) ).

% add_less_zeroD
tff(fact_282_zero__less__one,axiom,
    ! [B: $tType] :
      ( zero_less_one(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),one_one(B)) ) ).

% zero_less_one
tff(fact_283_not__one__less__zero,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),zero_zero(B)) ) ).

% not_one_less_zero
tff(fact_284_execute__ureturn,axiom,
    ! [B: $tType,X2: B] : aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),aa(B,heap_Time_Heap(B),heap_Time_ureturn(B),X2)) = aa(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),comp(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),some(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_an(B,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),X2)) ).

% execute_ureturn
tff(fact_285_less__imp__add__positive,axiom,
    ! [I: nat,J: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
     => ? [K3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K3)
          & ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K3) = J ) ) ) ).

% less_imp_add_positive
tff(fact_286_pairself_Osimps,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),A3: C,B2: C] : aa(product_prod(C,C),product_prod(B,B),pairself(C,B,F),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A3),B2)) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(C,B,F,A3)),aa(C,B,F,B2)) ).

% pairself.simps
tff(fact_287_pairself_Oelims,axiom,
    ! [B: $tType,C: $tType,X2: fun(C,B),Xa: product_prod(C,C),Y: product_prod(B,B)] :
      ( ( aa(product_prod(C,C),product_prod(B,B),pairself(C,B,X2),Xa) = Y )
     => ~ ! [A5: C,B3: C] :
            ( ( Xa = aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A5),B3) )
           => ( Y != aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(C,B,X2,A5)),aa(C,B,X2,B3)) ) ) ) ).

% pairself.elims
tff(fact_288_return__def,axiom,
    ! [B: $tType,X2: B] : aa(B,heap_Time_Heap(B),heap_Time_return(B),X2) = heap_Time_heap(B,aTP_Lamp_aa(B,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),X2)) ).

% return_def
tff(fact_289_effect__ureturnI,axiom,
    ! [B: $tType,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),X2: B] :
      ( ( Ha = H2 )
     => heap_Time_effect(B,aa(B,heap_Time_Heap(B),heap_Time_ureturn(B),X2),Ha,H2,X2,zero_zero(nat)) ) ).

% effect_ureturnI
tff(fact_290_effect__ureturnE,axiom,
    ! [B: $tType,X2: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,aa(B,heap_Time_Heap(B),heap_Time_ureturn(B),X2),Ha,H2,R,N)
     => ~ ( ( R = X2 )
         => ( ( H2 = Ha )
           => ( N != zero_zero(nat) ) ) ) ) ).

% effect_ureturnE
tff(fact_291_tap__def,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),B)] : heap_Time_tap(B,F) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aTP_Lamp_ar(fun(heap_ext(product_unit),B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),F)) ).

% tap_def
tff(fact_292_double__eq__0__iff,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3) = zero_zero(B) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% double_eq_0_iff
tff(fact_293_return__bind,axiom,
    ! [B: $tType,C: $tType,X2: C,F: fun(C,heap_Time_Heap(B))] : heap_Time_bind(C,B,aa(C,heap_Time_Heap(C),heap_Time_return(C),X2),F) = heap_Time_bind(product_unit,B,heap_Time_wait(one_one(nat)),aa(fun(C,heap_Time_Heap(B)),fun(product_unit,heap_Time_Heap(B)),aTP_Lamp_as(C,fun(fun(C,heap_Time_Heap(B)),fun(product_unit,heap_Time_Heap(B))),X2),F)) ).

% return_bind
tff(fact_294_bind__return,axiom,
    ! [B: $tType,F: heap_Time_Heap(B)] : heap_Time_bind(B,B,F,heap_Time_return(B)) = heap_Time_bind(product_unit,B,heap_Time_wait(one_one(nat)),aTP_Lamp_at(heap_Time_Heap(B),fun(product_unit,heap_Time_Heap(B)),F)) ).

% bind_return
tff(fact_295_add__0__iff,axiom,
    ! [B: $tType] :
      ( semiri1453513574482234551roduct(B)
     => ! [B2: B,A3: B] :
          ( ( B2 = aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% add_0_iff
tff(fact_296_verit__sum__simplify,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),zero_zero(B)) = A3 ) ).

% verit_sum_simplify
tff(fact_297_dbl__inc__simps_I2_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl_inc(B,zero_zero(B)) = one_one(B) ) ) ).

% dbl_inc_simps(2)
tff(fact_298_disjE__realizer2,axiom,
    ! [C: $tType,B: $tType,P: $o,Q: fun(B,$o),X2: option(B),R4: fun(C,$o),F: C,G: fun(B,C)] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),(P)),Q),X2)
     => ( ( (P)
         => aa(C,$o,R4,F) )
       => ( ! [Q2: B] :
              ( aa(B,$o,Q,Q2)
             => aa(C,$o,R4,aa(B,C,G,Q2)) )
         => aa(C,$o,R4,aa(option(B),C,aa(fun(B,C),fun(option(B),C),aa(C,fun(fun(B,C),fun(option(B),C)),case_option(C,B),F),G),X2)) ) ) ) ).

% disjE_realizer2
tff(fact_299_set__to__map__def,axiom,
    ! [B: $tType,C: $tType,S2: set(product_prod(C,B)),K: C] : aa(C,option(B),set_to_map(C,B,S2),K) = eps_Opt(B,aa(C,fun(B,$o),aTP_Lamp_au(set(product_prod(C,B)),fun(C,fun(B,$o)),S2),K)) ).

% set_to_map_def
tff(fact_300_K__record__comp,axiom,
    ! [B: $tType,D: $tType,C: $tType,C2: C,F: fun(B,D),X: B] : aa(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),aTP_Lamp_av(C,fun(D,C),C2)),F),X) = C2 ).

% K_record_comp
tff(fact_301_pred__equals__eq2,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(B,C))] :
      ( ! [X4: B,Xa2: C] :
          ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Xa2),R4)
        <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Xa2),S2) )
    <=> ( R4 = S2 ) ) ).

% pred_equals_eq2
tff(fact_302_dbl__inc__def,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [X2: B] : neg_numeral_dbl_inc(B,X2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),X2)),one_one(B)) ) ).

% dbl_inc_def
tff(fact_303_zero__natural_Orsp,axiom,
    zero_zero(nat) = zero_zero(nat) ).

% zero_natural.rsp
tff(fact_304_fails__wait,axiom,
    ! [X2: nat,Ha: heap_ext(product_unit)] : ~ time_fails(product_unit,heap_Time_wait(X2),Ha) ).

% fails_wait
tff(fact_305_Euclid__induct,axiom,
    ! [P: fun(nat,fun(nat,$o)),A3: nat,B2: nat] :
      ( ! [A5: nat,B3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),P,A5),B3)
        <=> aa(nat,$o,aa(nat,fun(nat,$o),P,B3),A5) )
     => ( ! [A5: nat] : aa(nat,$o,aa(nat,fun(nat,$o),P,A5),zero_zero(nat))
       => ( ! [A5: nat,B3: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),P,A5),B3)
             => aa(nat,$o,aa(nat,fun(nat,$o),P,A5),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A5),B3)) )
         => aa(nat,$o,aa(nat,fun(nat,$o),P,A3),B2) ) ) ) ).

% Euclid_induct
tff(fact_306_lookup__chain,axiom,
    ! [C: $tType,B: $tType] :
      ( heap(C)
     => ! [R: ref(C),F: heap_Time_Heap(B)] : heap_Time_bind(C,B,ref_lookup(C,R),aTP_Lamp_aw(heap_Time_Heap(B),fun(C,heap_Time_Heap(B)),F)) = heap_Time_bind(product_unit,B,heap_Time_wait(one_one(nat)),aTP_Lamp_at(heap_Time_Heap(B),fun(product_unit,heap_Time_Heap(B)),F)) ) ).

% lookup_chain
tff(fact_307_Ints__odd__less__0,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          ( member(B,A3,ring_1_Ints(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),A3)),A3)),zero_zero(B))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ) ).

% Ints_odd_less_0
tff(fact_308_num__of__nat__plus__distrib,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
       => ( aa(nat,num,num_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) = aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(nat,num,num_of_nat,M)),aa(nat,num,num_of_nat,N)) ) ) ) ).

% num_of_nat_plus_distrib
tff(fact_309_divides__aux__eq,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [Q3: B,R: B] :
          ( unique5940410009612947441es_aux(B,aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),R))
        <=> ( R = zero_zero(B) ) ) ) ).

% divides_aux_eq
tff(fact_310_sgn__pos,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,B,sgn_sgn(B),A3) = one_one(B) ) ) ) ).

% sgn_pos
tff(fact_311_abs__add__one__gt__zero,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,abs_abs(B),X2))) ) ).

% abs_add_one_gt_zero
tff(fact_312_map__option__case,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),Y: option(C)] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),Y) = aa(option(C),option(B),aa(fun(C,option(B)),fun(option(C),option(B)),aa(option(B),fun(fun(C,option(B)),fun(option(C),option(B))),case_option(option(B),C),none(B)),aTP_Lamp_ax(fun(C,B),fun(C,option(B)),F)),Y) ).

% map_option_case
tff(fact_313_add__neg__numeral__special_I7_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,uminus_uminus(B),one_one(B))) = zero_zero(B) ) ) ).

% add_neg_numeral_special(7)
tff(fact_314_add__neg__numeral__special_I8_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),one_one(B))),one_one(B)) = zero_zero(B) ) ) ).

% add_neg_numeral_special(8)
tff(fact_315_dbl__dec__simps_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl_dec(B,one_one(B)) = one_one(B) ) ) ).

% dbl_dec_simps(3)
tff(fact_316_neg__equal__iff__equal,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,uminus_uminus(B),A3) = aa(B,B,uminus_uminus(B),B2) )
        <=> ( A3 = B2 ) ) ) ).

% neg_equal_iff_equal
tff(fact_317_add_Oinverse__inverse,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,uminus_uminus(B),aa(B,B,uminus_uminus(B),A3)) = A3 ) ).

% add.inverse_inverse
tff(fact_318_abs__idempotent,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : aa(B,B,abs_abs(B),aa(B,B,abs_abs(B),A3)) = aa(B,B,abs_abs(B),A3) ) ).

% abs_idempotent
tff(fact_319_neg__equal__zero,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( ( aa(B,B,uminus_uminus(B),A3) = A3 )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% neg_equal_zero
tff(fact_320_equal__neg__zero,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( ( A3 = aa(B,B,uminus_uminus(B),A3) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% equal_neg_zero
tff(fact_321_neg__equal__0__iff__equal,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] :
          ( ( aa(B,B,uminus_uminus(B),A3) = zero_zero(B) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% neg_equal_0_iff_equal
tff(fact_322_neg__0__equal__iff__equal,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] :
          ( ( zero_zero(B) = aa(B,B,uminus_uminus(B),A3) )
        <=> ( zero_zero(B) = A3 ) ) ) ).

% neg_0_equal_iff_equal
tff(fact_323_add_Oinverse__neutral,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ( aa(B,B,uminus_uminus(B),zero_zero(B)) = zero_zero(B) ) ) ).

% add.inverse_neutral
tff(fact_324_neg__less__iff__less,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),B2)),aa(B,B,uminus_uminus(B),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% neg_less_iff_less
tff(fact_325_minus__add__distrib,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),aa(B,B,uminus_uminus(B),B2)) ) ).

% minus_add_distrib
tff(fact_326_minus__add__cancel,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = B2 ) ).

% minus_add_cancel
tff(fact_327_add__minus__cancel,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),B2)) = B2 ) ).

% add_minus_cancel
tff(fact_328_abs__zero,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ( aa(B,B,abs_abs(B),zero_zero(B)) = zero_zero(B) ) ) ).

% abs_zero
tff(fact_329_abs__eq__0,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( ( aa(B,B,abs_abs(B),A3) = zero_zero(B) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% abs_eq_0
tff(fact_330_abs__0__eq,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( ( zero_zero(B) = aa(B,B,abs_abs(B),A3) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% abs_0_eq
tff(fact_331_abs__add__abs,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2)) ) ).

% abs_add_abs
tff(fact_332_abs__1,axiom,
    ! [B: $tType] :
      ( idom_abs_sgn(B)
     => ( aa(B,B,abs_abs(B),one_one(B)) = one_one(B) ) ) ).

% abs_1
tff(fact_333_abs__minus__cancel,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : aa(B,B,abs_abs(B),aa(B,B,uminus_uminus(B),A3)) = aa(B,B,abs_abs(B),A3) ) ).

% abs_minus_cancel
tff(fact_334_sgn__1,axiom,
    ! [B: $tType] :
      ( idom_abs_sgn(B)
     => ( aa(B,B,sgn_sgn(B),one_one(B)) = one_one(B) ) ) ).

% sgn_1
tff(fact_335_map__option__eq__Some,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),Xo: option(C),Y: B] :
      ( ( aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),Xo) = aa(B,option(B),some(B),Y) )
    <=> ? [Z4: C] :
          ( ( Xo = aa(C,option(C),some(C),Z4) )
          & ( aa(C,B,F,Z4) = Y ) ) ) ).

% map_option_eq_Some
tff(fact_336_None__eq__map__option__iff,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: option(C)] :
      ( ( none(B) = aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),X2) )
    <=> ( X2 = none(C) ) ) ).

% None_eq_map_option_iff
tff(fact_337_map__option__is__None,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),Opt: option(C)] :
      ( ( aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),Opt) = none(B) )
    <=> ( Opt = none(C) ) ) ).

% map_option_is_None
tff(fact_338_option_Omap__disc__iff,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),A3: option(C)] :
      ( ( aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),A3) = none(B) )
    <=> ( A3 = none(C) ) ) ).

% option.map_disc_iff
tff(fact_339_neg__less__0__iff__less,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),A3)),zero_zero(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3) ) ) ).

% neg_less_0_iff_less
tff(fact_340_neg__0__less__iff__less,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,uminus_uminus(B),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% neg_0_less_iff_less
tff(fact_341_neg__less__pos,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),A3)),A3)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3) ) ) ).

% neg_less_pos
tff(fact_342_less__neg__neg,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,uminus_uminus(B),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% less_neg_neg
tff(fact_343_ab__left__minus,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),A3) = zero_zero(B) ) ).

% ab_left_minus
tff(fact_344_add_Oright__inverse,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,uminus_uminus(B),A3)) = zero_zero(B) ) ).

% add.right_inverse
tff(fact_345_zero__less__abs__iff,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,abs_abs(B),A3))
        <=> ( A3 != zero_zero(B) ) ) ) ).

% zero_less_abs_iff
tff(fact_346_abs__neg__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ( aa(B,B,abs_abs(B),aa(B,B,uminus_uminus(B),one_one(B))) = one_one(B) ) ) ).

% abs_neg_one
tff(fact_347_case__map__option,axiom,
    ! [C: $tType,B: $tType,D: $tType,G: B,Ha: fun(C,B),F: fun(D,C),X2: option(D)] : aa(option(C),B,aa(fun(C,B),fun(option(C),B),aa(B,fun(fun(C,B),fun(option(C),B)),case_option(B,C),G),Ha),aa(option(D),option(C),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F),X2)) = aa(option(D),B,aa(fun(D,B),fun(option(D),B),aa(B,fun(fun(D,B),fun(option(D),B)),case_option(B,D),G),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Ha),F)),X2) ).

% case_map_option
tff(fact_348_dbl__inc__simps_I4_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl_inc(B,aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% dbl_inc_simps(4)
tff(fact_349_abs__sgn__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,abs_abs(B),aa(B,B,sgn_sgn(B),A3)) = one_one(B) ) ) ) ).

% abs_sgn_eq_1
tff(fact_350_dbl__dec__simps_I2_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl_dec(B,zero_zero(B)) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% dbl_dec_simps(2)
tff(fact_351_sgn__neg,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,B,sgn_sgn(B),A3) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ) ).

% sgn_neg
tff(fact_352_minus__equation__iff,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,uminus_uminus(B),A3) = B2 )
        <=> ( aa(B,B,uminus_uminus(B),B2) = A3 ) ) ) ).

% minus_equation_iff
tff(fact_353_equation__minus__iff,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( A3 = aa(B,B,uminus_uminus(B),B2) )
        <=> ( B2 = aa(B,B,uminus_uminus(B),A3) ) ) ) ).

% equation_minus_iff
tff(fact_354_same__sgn__abs__add,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [B2: B,A3: B] :
          ( ( aa(B,B,sgn_sgn(B),B2) = aa(B,B,sgn_sgn(B),A3) )
         => ( aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2)) ) ) ) ).

% same_sgn_abs_add
tff(fact_355_sgn__minus__1,axiom,
    ! [B: $tType] :
      ( idom_abs_sgn(B)
     => ( aa(B,B,sgn_sgn(B),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% sgn_minus_1
tff(fact_356_option_Omap__ident,axiom,
    ! [B: $tType,T2: option(B)] : aa(option(B),option(B),aa(fun(B,B),fun(option(B),option(B)),map_option(B,B),aTP_Lamp_ay(B,B)),T2) = T2 ).

% option.map_ident
tff(fact_357_abs__of__neg,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,B,abs_abs(B),A3) = aa(B,B,uminus_uminus(B),A3) ) ) ) ).

% abs_of_neg
tff(fact_358_abs__sgn__eq,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          aa(B,B,abs_abs(B),aa(B,B,sgn_sgn(B),A3)) = $ite(A3 = zero_zero(B),zero_zero(B),one_one(B)) ) ).

% abs_sgn_eq
tff(fact_359_abs__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ( aa(B,B,abs_abs(B),one_one(B)) = one_one(B) ) ) ).

% abs_one
tff(fact_360_map__option_Ocompositionality,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(D,C),Option: option(D)] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),aa(option(D),option(C),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),G),Option)) = aa(option(D),option(B),aa(fun(D,B),fun(option(D),option(B)),map_option(D,B),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G)),Option) ).

% map_option.compositionality
tff(fact_361_option_Omap__comp,axiom,
    ! [C: $tType,B: $tType,D: $tType,G: fun(C,B),F: fun(D,C),V: option(D)] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),G),aa(option(D),option(C),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F),V)) = aa(option(D),option(B),aa(fun(D,B),fun(option(D),option(B)),map_option(D,B),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),V) ).

% option.map_comp
tff(fact_362_map__option_Ocomp,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),G: fun(B,D)] : aa(fun(option(B),option(D)),fun(option(B),option(C)),aa(fun(option(D),option(C)),fun(fun(option(B),option(D)),fun(option(B),option(C))),comp(option(D),option(C),option(B)),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F)),aa(fun(B,D),fun(option(B),option(D)),map_option(B,D),G)) = aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G)) ).

% map_option.comp
tff(fact_363_minus__less__iff,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),A3)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),B2)),A3) ) ) ).

% minus_less_iff
tff(fact_364_less__minus__iff,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,uminus_uminus(B),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),aa(B,B,uminus_uminus(B),A3)) ) ) ).

% less_minus_iff
tff(fact_365_is__num__normalize_I8_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [A3: B,B2: B] : aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),B2)),aa(B,B,uminus_uminus(B),A3)) ) ).

% is_num_normalize(8)
tff(fact_366_add_Oinverse__distrib__swap,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),B2)),aa(B,B,uminus_uminus(B),A3)) ) ).

% add.inverse_distrib_swap
tff(fact_367_group__cancel_Oneg1,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A4: B,K: B,A3: B] :
          ( ( A4 = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),A3) )
         => ( aa(B,B,uminus_uminus(B),A4) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),K)),aa(B,B,uminus_uminus(B),A3)) ) ) ) ).

% group_cancel.neg1
tff(fact_368_one__neq__neg__one,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ( one_one(B) != aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% one_neq_neg_one
tff(fact_369_map__option__cong,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Y: option(B),F: fun(B,C),G: fun(B,C)] :
      ( ( X2 = Y )
     => ( ! [A5: B] :
            ( ( Y = aa(B,option(B),some(B),A5) )
           => ( aa(B,C,F,A5) = aa(B,C,G,A5) ) )
       => ( aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),X2) = aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),G),Y) ) ) ) ).

% map_option_cong
tff(fact_370_option_Osimps_I9_J,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X22: C] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),aa(C,option(C),some(C),X22)) = aa(B,option(B),some(B),aa(C,B,F,X22)) ).

% option.simps(9)
tff(fact_371_option_Osimps_I8_J,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B)] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),none(C)) = none(B) ).

% option.simps(8)
tff(fact_372_same__sgn__sgn__add,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [B2: B,A3: B] :
          ( ( aa(B,B,sgn_sgn(B),B2) = aa(B,B,sgn_sgn(B),A3) )
         => ( aa(B,B,sgn_sgn(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,sgn_sgn(B),A3) ) ) ) ).

% same_sgn_sgn_add
tff(fact_373_Ints__add,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [A3: B,B2: B] :
          ( member(B,A3,ring_1_Ints(B))
         => ( member(B,B2,ring_1_Ints(B))
           => member(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2),ring_1_Ints(B)) ) ) ) ).

% Ints_add
tff(fact_374_success__lookupI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),Ha: heap_ext(product_unit)] : heap_Time_success(B,ref_lookup(B,R),Ha) ) ).

% success_lookupI
tff(fact_375_Ints__1,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => member(B,one_one(B),ring_1_Ints(B)) ) ).

% Ints_1
tff(fact_376_Ints__nonzero__abs__less1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          ( member(B,X2,ring_1_Ints(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),X2)),one_one(B))
           => ( X2 = zero_zero(B) ) ) ) ) ).

% Ints_nonzero_abs_less1
tff(fact_377_sgn__if,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          aa(B,B,sgn_sgn(B),X2) = $ite(
            X2 = zero_zero(B),
            zero_zero(B),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),X2),one_one(B),aa(B,B,uminus_uminus(B),one_one(B))) ) ) ).

% sgn_if
tff(fact_378_sgn__1__neg,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          ( ( aa(B,B,sgn_sgn(B),A3) = aa(B,B,uminus_uminus(B),one_one(B)) )
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% sgn_1_neg
tff(fact_379_abs__not__less__zero,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),A3)),zero_zero(B)) ) ).

% abs_not_less_zero
tff(fact_380_abs__of__pos,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,B,abs_abs(B),A3) = A3 ) ) ) ).

% abs_of_pos
tff(fact_381_option_Orec__o__map,axiom,
    ! [C: $tType,D: $tType,B: $tType,G: C,Ga: fun(D,C),F: fun(B,D)] : aa(fun(option(B),option(D)),fun(option(B),C),aa(fun(option(D),C),fun(fun(option(B),option(D)),fun(option(B),C)),comp(option(D),C,option(B)),aa(fun(D,C),fun(option(D),C),aa(C,fun(fun(D,C),fun(option(D),C)),rec_option(C,D),G),Ga)),aa(fun(B,D),fun(option(B),option(D)),map_option(B,D),F)) = aa(fun(B,C),fun(option(B),C),aa(C,fun(fun(B,C),fun(option(B),C)),rec_option(C,B),G),aa(fun(B,D),fun(B,C),aTP_Lamp_az(fun(D,C),fun(fun(B,D),fun(B,C)),Ga),F)) ).

% option.rec_o_map
tff(fact_382_neg__eq__iff__add__eq__0,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,uminus_uminus(B),A3) = B2 )
        <=> ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = zero_zero(B) ) ) ) ).

% neg_eq_iff_add_eq_0
tff(fact_383_eq__neg__iff__add__eq__0,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( A3 = aa(B,B,uminus_uminus(B),B2) )
        <=> ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = zero_zero(B) ) ) ) ).

% eq_neg_iff_add_eq_0
tff(fact_384_add_Oinverse__unique,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = zero_zero(B) )
         => ( aa(B,B,uminus_uminus(B),A3) = B2 ) ) ) ).

% add.inverse_unique
tff(fact_385_ab__group__add__class_Oab__left__minus,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),A3) = zero_zero(B) ) ).

% ab_group_add_class.ab_left_minus
tff(fact_386_add__eq__0__iff,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = zero_zero(B) )
        <=> ( B2 = aa(B,B,uminus_uminus(B),A3) ) ) ) ).

% add_eq_0_iff
tff(fact_387_zero__neq__neg__one,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ( zero_zero(B) != aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% zero_neq_neg_one
tff(fact_388_less__minus__one__simps_I4_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% less_minus_one_simps(4)
tff(fact_389_less__minus__one__simps_I2_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),one_one(B))),one_one(B)) ) ).

% less_minus_one_simps(2)
tff(fact_390_option_Omap__sel,axiom,
    ! [C: $tType,B: $tType,A3: option(B),F: fun(B,C)] :
      ( ( A3 != none(B) )
     => ( aa(option(C),C,the2(C),aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),A3)) = aa(B,C,F,aa(option(B),B,the2(B),A3)) ) ) ).

% option.map_sel
tff(fact_391_Ints__double__eq__0__iff,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [A3: B] :
          ( member(B,A3,ring_1_Ints(B))
         => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3) = zero_zero(B) )
          <=> ( A3 = zero_zero(B) ) ) ) ) ).

% Ints_double_eq_0_iff
tff(fact_392_less__minus__one__simps_I3_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% less_minus_one_simps(3)
tff(fact_393_less__minus__one__simps_I1_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),one_one(B))),zero_zero(B)) ) ).

% less_minus_one_simps(1)
tff(fact_394_sgn__1__pos,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B] :
          ( ( aa(B,B,sgn_sgn(B),A3) = one_one(B) )
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3) ) ) ).

% sgn_1_pos
tff(fact_395_Ints__odd__nonzero,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [A3: B] :
          ( member(B,A3,ring_1_Ints(B))
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),A3)),A3) != zero_zero(B) ) ) ) ).

% Ints_odd_nonzero
tff(fact_396_map__option__o__empty,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(D,C),X: B] : aa(B,option(C),aa(fun(B,option(D)),fun(B,option(C)),aa(fun(option(D),option(C)),fun(fun(B,option(D)),fun(B,option(C))),comp(option(D),option(C),B),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F)),aTP_Lamp_ba(B,option(D))),X) = none(C) ).

% map_option_o_empty
tff(fact_397_execute__lookup,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),ref_lookup(B,R)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),ref_get(B,Ha,R)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),one_one(nat)))) ) ).

% execute_lookup
tff(fact_398_change__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [F: fun(B,B),R: ref(B)] : ref_change(B,F,R) = heap_Time_bind(B,B,ref_lookup(B,R),aa(ref(B),fun(B,heap_Time_Heap(B)),aTP_Lamp_bc(fun(B,B),fun(ref(B),fun(B,heap_Time_Heap(B))),F),R)) ) ).

% change_def
tff(fact_399_fails__assert_H,axiom,
    ! [P: $o,Ha: heap_ext(product_unit)] :
      ( time_fails(product_unit,refine_Imp_assert((P)),Ha)
    <=> ~ (P) ) ).

% fails_assert'
tff(fact_400_effect__lookupI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [H2: heap_ext(product_unit),Ha: heap_ext(product_unit),X2: B,R: ref(B),N: nat] :
          ( ( H2 = Ha )
         => ( ( X2 = ref_get(B,Ha,R) )
           => ( ( N = one_one(nat) )
             => heap_Time_effect(B,ref_lookup(B,R),Ha,H2,X2,N) ) ) ) ) ).

% effect_lookupI
tff(fact_401_effect__lookupE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),X2: B,N: nat] :
          ( heap_Time_effect(B,ref_lookup(B,R),Ha,H2,X2,N)
         => ~ ( ( H2 = Ha )
             => ( ( X2 = ref_get(B,Ha,R) )
               => ( N != one_one(nat) ) ) ) ) ) ).

% effect_lookupE
tff(fact_402_add_Ogroup__axioms,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => group(B,plus_plus(B),zero_zero(B),uminus_uminus(B)) ) ).

% add.group_axioms
tff(fact_403_num__of__nat__double,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,num,num_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),N)) = aa(num,num,bit0,aa(nat,num,num_of_nat,N)) ) ) ).

% num_of_nat_double
tff(fact_404_Ints__nonzero__abs__ge1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          ( member(B,X2,ring_1_Ints(B))
         => ( ( X2 != zero_zero(B) )
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,abs_abs(B),X2)) ) ) ) ).

% Ints_nonzero_abs_ge1
tff(fact_405_lookup__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B)] : ref_lookup(B,R) = heap_Time_tap(B,aTP_Lamp_bd(ref(B),fun(heap_ext(product_unit),B),R)) ) ).

% lookup_def
tff(fact_406_map__conv__bind__option,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: option(C)] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),X2) = aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),X2),aa(fun(C,B),fun(C,option(B)),aa(fun(B,option(B)),fun(fun(C,B),fun(C,option(B))),comp(B,option(B),C),some(B)),F)) ).

% map_conv_bind_option
tff(fact_407_nat__add__left__cancel__le,axiom,
    ! [K: nat,M: 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),K),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ).

% nat_add_left_cancel_le
tff(fact_408_less__eq__option__None__code,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B)] : aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),none(B)),X2) ) ).

% less_eq_option_None_code
tff(fact_409_bind__assoc,axiom,
    ! [D: $tType,B: $tType,C: $tType,X2: option(D),F: fun(D,option(C)),G: fun(C,option(B))] : aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),aa(fun(D,option(C)),option(C),aa(option(D),fun(fun(D,option(C)),option(C)),bind(D,C),X2),F)),G) = aa(fun(D,option(B)),option(B),aa(option(D),fun(fun(D,option(B)),option(B)),bind(D,B),X2),aa(fun(C,option(B)),fun(D,option(B)),aTP_Lamp_be(fun(D,option(C)),fun(fun(C,option(B)),fun(D,option(B))),F),G)) ).

% bind_assoc
tff(fact_410_le__zero__eq,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [N: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),N),zero_zero(B))
        <=> ( N = zero_zero(B) ) ) ) ).

% le_zero_eq
tff(fact_411_add__le__cancel__left,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [C2: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% add_le_cancel_left
tff(fact_412_add__le__cancel__right,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% add_le_cancel_right
tff(fact_413_neg__le__iff__le,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),B2)),aa(B,B,uminus_uminus(B),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% neg_le_iff_le
tff(fact_414_less__eq__option__Some,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B,Y: B] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),aa(B,option(B),some(B),X2)),aa(B,option(B),some(B),Y))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y) ) ) ).

% less_eq_option_Some
tff(fact_415_less__eq__option__Some__None,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B] : ~ aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),aa(B,option(B),some(B),X2)),none(B)) ) ).

% less_eq_option_Some_None
tff(fact_416_bind__runit,axiom,
    ! [B: $tType,X2: option(B)] : aa(fun(B,option(B)),option(B),aa(option(B),fun(fun(B,option(B)),option(B)),bind(B,B),X2),some(B)) = X2 ).

% bind_runit
tff(fact_417_bind__rzero,axiom,
    ! [C: $tType,B: $tType,X2: option(C)] : aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),X2),aTP_Lamp_bf(C,option(B))) = none(B) ).

% bind_rzero
tff(fact_418_add__le__same__cancel1,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B)) ) ) ).

% add_le_same_cancel1
tff(fact_419_add__le__same__cancel2,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B)) ) ) ).

% add_le_same_cancel2
tff(fact_420_le__add__same__cancel1,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),B2) ) ) ).

% le_add_same_cancel1
tff(fact_421_le__add__same__cancel2,axiom,
    ! [B: $tType] :
      ( ordere1937475149494474687imp_le(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),B2) ) ) ).

% le_add_same_cancel2
tff(fact_422_double__add__le__zero__iff__single__add__le__zero,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3)),zero_zero(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B)) ) ) ).

% double_add_le_zero_iff_single_add_le_zero
tff(fact_423_zero__le__double__add__iff__zero__le__single__add,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3) ) ) ).

% zero_le_double_add_iff_zero_le_single_add
tff(fact_424_neg__0__le__iff__le,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,uminus_uminus(B),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B)) ) ) ).

% neg_0_le_iff_le
tff(fact_425_neg__le__0__iff__le,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),zero_zero(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3) ) ) ).

% neg_le_0_iff_le
tff(fact_426_less__eq__neg__nonpos,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,uminus_uminus(B),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B)) ) ) ).

% less_eq_neg_nonpos
tff(fact_427_neg__less__eq__nonneg,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),A3)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3) ) ) ).

% neg_less_eq_nonneg
tff(fact_428_abs__of__nonneg,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,B,abs_abs(B),A3) = A3 ) ) ) ).

% abs_of_nonneg
tff(fact_429_abs__le__self__iff,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),A3)),A3)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3) ) ) ).

% abs_le_self_iff
tff(fact_430_abs__le__zero__iff,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),A3)),zero_zero(B))
        <=> ( A3 = zero_zero(B) ) ) ) ).

% abs_le_zero_iff
tff(fact_431_abs__of__nonpos,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B))
         => ( aa(B,B,abs_abs(B),A3) = aa(B,B,uminus_uminus(B),A3) ) ) ) ).

% abs_of_nonpos
tff(fact_432_ord__eq__le__eq__trans,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( A3 = B2 )
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),C2)
           => ( ( C2 = D3 )
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),D3) ) ) ) ) ).

% ord_eq_le_eq_trans
tff(fact_433_bind__option__cong__code,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Y: option(B),F: fun(B,option(C))] :
      ( ( X2 = Y )
     => ( aa(fun(B,option(C)),option(C),aa(option(B),fun(fun(B,option(C)),option(C)),bind(B,C),X2),F) = aa(fun(B,option(C)),option(C),aa(option(B),fun(fun(B,option(C)),option(C)),bind(B,C),Y),F) ) ) ).

% bind_option_cong_code
tff(fact_434_group_Oleft__cancel,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B,B2: B,C2: B] :
      ( group(B,F,Z2,Inverse)
     => ( ( aa(B,B,aa(B,fun(B,B),F,A3),B2) = aa(B,B,aa(B,fun(B,B),F,A3),C2) )
      <=> ( B2 = C2 ) ) ) ).

% group.left_cancel
tff(fact_435_group_Oleft__inverse,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B] :
      ( group(B,F,Z2,Inverse)
     => ( aa(B,B,aa(B,fun(B,B),F,aa(B,B,Inverse,A3)),A3) = Z2 ) ) ).

% group.left_inverse
tff(fact_436_group_Oright__cancel,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),B2: B,A3: B,C2: B] :
      ( group(B,F,Z2,Inverse)
     => ( ( aa(B,B,aa(B,fun(B,B),F,B2),A3) = aa(B,B,aa(B,fun(B,B),F,C2),A3) )
      <=> ( B2 = C2 ) ) ) ).

% group.right_cancel
tff(fact_437_group_Oright__inverse,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B] :
      ( group(B,F,Z2,Inverse)
     => ( aa(B,B,aa(B,fun(B,B),F,A3),aa(B,B,Inverse,A3)) = Z2 ) ) ).

% group.right_inverse
tff(fact_438_group_Oinverse__unique,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B,B2: B] :
      ( group(B,F,Z2,Inverse)
     => ( ( aa(B,B,aa(B,fun(B,B),F,A3),B2) = Z2 )
       => ( aa(B,B,Inverse,A3) = B2 ) ) ) ).

% group.inverse_unique
tff(fact_439_group_Oinverse__inverse,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B] :
      ( group(B,F,Z2,Inverse)
     => ( aa(B,B,Inverse,aa(B,B,Inverse,A3)) = A3 ) ) ).

% group.inverse_inverse
tff(fact_440_group_Oinverse__neutral,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( group(B,F,Z2,Inverse)
     => ( aa(B,B,Inverse,Z2) = Z2 ) ) ).

% group.inverse_neutral
tff(fact_441_group_Ogroup__left__neutral,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B] :
      ( group(B,F,Z2,Inverse)
     => ( aa(B,B,aa(B,fun(B,B),F,Z2),A3) = A3 ) ) ).

% group.group_left_neutral
tff(fact_442_group_Oinverse__distrib__swap,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B),A3: B,B2: B] :
      ( group(B,F,Z2,Inverse)
     => ( aa(B,B,Inverse,aa(B,B,aa(B,fun(B,B),F,A3),B2)) = aa(B,B,aa(B,fun(B,B),F,aa(B,B,Inverse,B2)),aa(B,B,Inverse,A3)) ) ) ).

% group.inverse_distrib_swap
tff(fact_443_accp__subset,axiom,
    ! [B: $tType,R12: fun(B,fun(B,$o)),R23: fun(B,fun(B,$o))] :
      ( aa(fun(B,fun(B,$o)),$o,aa(fun(B,fun(B,$o)),fun(fun(B,fun(B,$o)),$o),ord_less_eq(fun(B,fun(B,$o))),R12),R23)
     => aa(fun(B,$o),$o,aa(fun(B,$o),fun(fun(B,$o),$o),ord_less_eq(fun(B,$o)),accp(B,R23)),accp(B,R12)) ) ).

% accp_subset
tff(fact_444_le__some__optE,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [M: B,X2: option(B)] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),aa(B,option(B),some(B),M)),X2)
         => ~ ! [M3: B] :
                ( ( X2 = aa(B,option(B),some(B),M3) )
               => ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),M3) ) ) ) ).

% le_some_optE
tff(fact_445_pred__subset__eq2,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(B,C))] :
      ( aa(fun(B,fun(C,$o)),$o,aa(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),$o),ord_less_eq(fun(B,fun(C,$o))),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R4)),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),S2))
    <=> aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),R4),S2) ) ).

% pred_subset_eq2
tff(fact_446_less__eq__option__def,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B),Y: option(B)] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),X2),Y)
        <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),$true),aTP_Lamp_bh(option(B),fun(B,$o),Y)),X2) ) ) ).

% less_eq_option_def
tff(fact_447_zero__le,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2) ) ).

% zero_le
tff(fact_448_add__mono__thms__linordered__semiring_I3_J,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),J)
            & ( K = L ) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_semiring(3)
tff(fact_449_add__mono__thms__linordered__semiring_I2_J,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( ( I = J )
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),K),L) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_semiring(2)
tff(fact_450_add__mono__thms__linordered__semiring_I1_J,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),J)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),K),L) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_semiring(1)
tff(fact_451_add__mono,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),D3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),D3)) ) ) ) ).

% add_mono
tff(fact_452_add__left__mono,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)) ) ) ).

% add_left_mono
tff(fact_453_less__eqE,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ~ ! [C3: B] : B2 != aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C3) ) ) ).

% less_eqE
tff(fact_454_add__right__mono,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ) ).

% add_right_mono
tff(fact_455_le__iff__add,axiom,
    ! [B: $tType] :
      ( canoni5634975068530333245id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
        <=> ? [C4: B] : B2 = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C4) ) ) ).

% le_iff_add
tff(fact_456_add__le__imp__le__left,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [C2: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2))
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% add_le_imp_le_left
tff(fact_457_add__le__imp__le__right,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2))
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% add_le_imp_le_right
tff(fact_458_accp__subset__induct,axiom,
    ! [B: $tType,D4: fun(B,$o),R4: fun(B,fun(B,$o)),X2: B,P: fun(B,$o)] :
      ( aa(fun(B,$o),$o,aa(fun(B,$o),fun(fun(B,$o),$o),ord_less_eq(fun(B,$o)),D4),accp(B,R4))
     => ( ! [X3: B,Z3: B] :
            ( aa(B,$o,D4,X3)
           => ( aa(B,$o,aa(B,fun(B,$o),R4,Z3),X3)
             => aa(B,$o,D4,Z3) ) )
       => ( aa(B,$o,D4,X2)
         => ( ! [X3: B] :
                ( aa(B,$o,D4,X3)
               => ( ! [Z5: B] :
                      ( aa(B,$o,aa(B,fun(B,$o),R4,Z5),X3)
                     => aa(B,$o,P,Z5) )
                 => aa(B,$o,P,X3) ) )
           => aa(B,$o,P,X2) ) ) ) ) ).

% accp_subset_induct
tff(fact_459_le__numeral__extra_I4_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),one_one(B)) ) ).

% le_numeral_extra(4)
tff(fact_460_subrelI,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C)),S: set(product_prod(B,C))] :
      ( ! [X3: B,Y4: C] :
          ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4),R)
         => member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4),S) )
     => aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),R),S) ) ).

% subrelI
tff(fact_461_le__minus__iff,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,uminus_uminus(B),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),aa(B,B,uminus_uminus(B),A3)) ) ) ).

% le_minus_iff
tff(fact_462_minus__le__iff,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),B2)),A3) ) ) ).

% minus_le_iff
tff(fact_463_le__imp__neg__le,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),B2)),aa(B,B,uminus_uminus(B),A3)) ) ) ).

% le_imp_neg_le
tff(fact_464_exists__leI,axiom,
    ! [N: nat,P: fun(nat,$o)] :
      ( ( ! [N6: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N6),N)
           => ~ aa(nat,$o,P,N6) )
       => aa(nat,$o,P,N) )
     => ? [N4: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N4),N)
          & aa(nat,$o,P,N4) ) ) ).

% exists_leI
tff(fact_465_nat__le__iff__add,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
    <=> ? [K4: nat] : N = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K4) ) ).

% nat_le_iff_add
tff(fact_466_trans__le__add2,axiom,
    ! [I: nat,J: nat,M: 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),I),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),J)) ) ).

% trans_le_add2
tff(fact_467_trans__le__add1,axiom,
    ! [I: nat,J: nat,M: 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),I),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),M)) ) ).

% trans_le_add1
tff(fact_468_add__le__mono1,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),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K)) ) ).

% add_le_mono1
tff(fact_469_add__le__mono,axiom,
    ! [I: nat,J: nat,K: nat,L: 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),K),L)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),L)) ) ) ).

% add_le_mono
tff(fact_470_le__Suc__ex,axiom,
    ! [K: nat,L: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),L)
     => ? [N3: nat] : L = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N3) ) ).

% le_Suc_ex
tff(fact_471_add__leD2,axiom,
    ! [M: nat,K: 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),M),K)),N)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N) ) ).

% add_leD2
tff(fact_472_add__leD1,axiom,
    ! [M: nat,K: 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),M),K)),N)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ).

% add_leD1
tff(fact_473_le__add2,axiom,
    ! [N: nat,M: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) ).

% le_add2
tff(fact_474_le__add1,axiom,
    ! [N: nat,M: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)) ).

% le_add1
tff(fact_475_add__leE,axiom,
    ! [M: nat,K: 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),M),K)),N)
     => ~ ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N) ) ) ).

% add_leE
tff(fact_476_abs__le__D1,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),A3)),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% abs_le_D1
tff(fact_477_abs__ge__self,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,abs_abs(B),A3)) ) ).

% abs_ge_self
tff(fact_478_less__eq__option__None,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B)] : aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),none(B)),X2) ) ).

% less_eq_option_None
tff(fact_479_less__eq__option__None__is__None,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: option(B)] :
          ( aa(option(B),$o,aa(option(B),fun(option(B),$o),ord_less_eq(option(B)),X2),none(B))
         => ( X2 = none(B) ) ) ) ).

% less_eq_option_None_is_None
tff(fact_480_bind_Obind__lunit,axiom,
    ! [B: $tType,C: $tType,X2: C,F: fun(C,option(B))] : aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),aa(C,option(C),some(C),X2)),F) = aa(C,option(B),F,X2) ).

% bind.bind_lunit
tff(fact_481_Option_Obind__cong,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Y: option(B),F: fun(B,option(C)),G: fun(B,option(C))] :
      ( ( X2 = Y )
     => ( ! [A5: B] :
            ( ( Y = aa(B,option(B),some(B),A5) )
           => ( aa(B,option(C),F,A5) = aa(B,option(C),G,A5) ) )
       => ( aa(fun(B,option(C)),option(C),aa(option(B),fun(fun(B,option(C)),option(C)),bind(B,C),X2),F) = aa(fun(B,option(C)),option(C),aa(option(B),fun(fun(B,option(C)),option(C)),bind(B,C),Y),G) ) ) ) ).

% Option.bind_cong
tff(fact_482_bind__eq__Some__conv,axiom,
    ! [C: $tType,B: $tType,F: option(C),G: fun(C,option(B)),X2: B] :
      ( ( aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),F),G) = aa(B,option(B),some(B),X2) )
    <=> ? [Y3: C] :
          ( ( F = aa(C,option(C),some(C),Y3) )
          & ( aa(C,option(B),G,Y3) = aa(B,option(B),some(B),X2) ) ) ) ).

% bind_eq_Some_conv
tff(fact_483_bind_Obind__lzero,axiom,
    ! [C: $tType,B: $tType,F: fun(C,option(B))] : aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),none(C)),F) = none(B) ).

% bind.bind_lzero
tff(fact_484_map__option__bind,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(C,B),X2: option(D),G: fun(D,option(C))] : aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),aa(fun(D,option(C)),option(C),aa(option(D),fun(fun(D,option(C)),option(C)),bind(D,C),X2),G)) = aa(fun(D,option(B)),option(B),aa(option(D),fun(fun(D,option(B)),option(B)),bind(D,B),X2),aa(fun(D,option(C)),fun(D,option(B)),aa(fun(option(C),option(B)),fun(fun(D,option(C)),fun(D,option(B))),comp(option(C),option(B),D),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F)),G)) ).

% map_option_bind
tff(fact_485_add__decreasing,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),B2) ) ) ) ).

% add_decreasing
tff(fact_486_add__increasing,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),C2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)) ) ) ) ).

% add_increasing
tff(fact_487_add__decreasing2,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [C2: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),B2) ) ) ) ).

% add_decreasing2
tff(fact_488_add__increasing2,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [C2: B,B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),C2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)) ) ) ) ).

% add_increasing2
tff(fact_489_add__nonneg__nonneg,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% add_nonneg_nonneg
tff(fact_490_add__nonpos__nonpos,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),zero_zero(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),zero_zero(B)) ) ) ) ).

% add_nonpos_nonpos
tff(fact_491_add__nonneg__eq__0__iff,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),Y)
           => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y) = zero_zero(B) )
            <=> ( ( X2 = zero_zero(B) )
                & ( Y = zero_zero(B) ) ) ) ) ) ) ).

% add_nonneg_eq_0_iff
tff(fact_492_add__nonpos__eq__0__iff,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y),zero_zero(B))
           => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y) = zero_zero(B) )
            <=> ( ( X2 = zero_zero(B) )
                & ( Y = zero_zero(B) ) ) ) ) ) ) ).

% add_nonpos_eq_0_iff
tff(fact_493_not__one__le__zero,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),zero_zero(B)) ) ).

% not_one_le_zero
tff(fact_494_linordered__nonzero__semiring__class_Ozero__le__one,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),one_one(B)) ) ).

% linordered_nonzero_semiring_class.zero_le_one
tff(fact_495_zero__less__one__class_Ozero__le__one,axiom,
    ! [B: $tType] :
      ( zero_less_one(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),one_one(B)) ) ).

% zero_less_one_class.zero_le_one
tff(fact_496_add__mono__thms__linordered__field_I4_J,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),J)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),K),L) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_field(4)
tff(fact_497_add__mono__thms__linordered__field_I3_J,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [I: B,J: B,K: B,L: B] :
          ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),I),J)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),K),L) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),L)) ) ) ).

% add_mono_thms_linordered_field(3)
tff(fact_498_add__le__less__mono,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),D3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),D3)) ) ) ) ).

% add_le_less_mono
tff(fact_499_add__less__le__mono,axiom,
    ! [B: $tType] :
      ( ordere580206878836729694up_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),D3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),D3)) ) ) ) ).

% add_less_le_mono
tff(fact_500_le__minus__one__simps_I2_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),one_one(B))),one_one(B)) ) ).

% le_minus_one_simps(2)
tff(fact_501_le__minus__one__simps_I4_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% le_minus_one_simps(4)
tff(fact_502_abs__ge__zero,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,abs_abs(B),A3)) ) ).

% abs_ge_zero
tff(fact_503_abs__triangle__ineq,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2))) ) ).

% abs_triangle_ineq
tff(fact_504_abs__leI,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),A3)),B2) ) ) ) ).

% abs_leI
tff(fact_505_abs__le__D2,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),A3)),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),B2) ) ) ).

% abs_le_D2
tff(fact_506_abs__le__iff,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),A3)),B2)
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),B2) ) ) ) ).

% abs_le_iff
tff(fact_507_abs__ge__minus__self,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),A3)),aa(B,B,abs_abs(B),A3)) ) ).

% abs_ge_minus_self
tff(fact_508_mono__nat__linear__lb,axiom,
    ! [F: fun(nat,nat),M: nat,K: nat] :
      ( ! [M4: nat,N3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M4),N3)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,F,M4)),aa(nat,nat,F,N3)) )
     => 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,F,M)),K)),aa(nat,nat,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K))) ) ).

% mono_nat_linear_lb
tff(fact_509_nat__geq__1__eq__neqz,axiom,
    ! [X2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),X2)
    <=> ( X2 != zero_zero(nat) ) ) ).

% nat_geq_1_eq_neqz
tff(fact_510_bind__split__asm,axiom,
    ! [B: $tType,C: $tType,P: fun(option(B),$o),M: option(C),F: fun(C,option(B))] :
      ( aa(option(B),$o,P,aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),M),F))
    <=> ~ ( ( ( M = none(C) )
            & ~ aa(option(B),$o,P,none(B)) )
          | ? [X4: C] :
              ( ( M = aa(C,option(C),some(C),X4) )
              & ~ aa(option(B),$o,P,aa(C,option(B),F,X4)) ) ) ) ).

% bind_split_asm
tff(fact_511_bind__split,axiom,
    ! [B: $tType,C: $tType,P: fun(option(B),$o),M: option(C),F: fun(C,option(B))] :
      ( aa(option(B),$o,P,aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),M),F))
    <=> ( ( ( M = none(C) )
         => aa(option(B),$o,P,none(B)) )
        & ! [V3: C] :
            ( ( M = aa(C,option(C),some(C),V3) )
           => aa(option(B),$o,P,aa(C,option(B),F,V3)) ) ) ) ).

% bind_split
tff(fact_512_mlex__leq,axiom,
    ! [B: $tType,F: fun(B,nat),X2: B,Y: B,R4: set(product_prod(B,B))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R4)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),mlex_prod(B,F,R4)) ) ) ).

% mlex_leq
tff(fact_513_bind__eq__None__conv,axiom,
    ! [C: $tType,B: $tType,A3: option(C),F: fun(C,option(B))] :
      ( ( aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),A3),F) = none(B) )
    <=> ( ( A3 = none(C) )
        | ( aa(C,option(B),F,aa(option(C),C,the2(C),A3)) = none(B) ) ) ) ).

% bind_eq_None_conv
tff(fact_514_bind__map__option,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,C),X2: option(D),G: fun(C,option(B))] : aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),aa(option(D),option(C),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F),X2)),G) = aa(fun(D,option(B)),option(B),aa(option(D),fun(fun(D,option(B)),option(B)),bind(D,B),X2),aa(fun(D,C),fun(D,option(B)),aa(fun(C,option(B)),fun(fun(D,C),fun(D,option(B))),comp(C,option(B),D),G),F)) ).

% bind_map_option
tff(fact_515_add__neg__nonpos,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),zero_zero(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),zero_zero(B)) ) ) ) ).

% add_neg_nonpos
tff(fact_516_add__nonneg__pos,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% add_nonneg_pos
tff(fact_517_add__nonpos__neg,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),zero_zero(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),zero_zero(B)) ) ) ) ).

% add_nonpos_neg
tff(fact_518_add__pos__nonneg,axiom,
    ! [B: $tType] :
      ( ordere6911136660526730532id_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),B2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% add_pos_nonneg
tff(fact_519_add__strict__increasing,axiom,
    ! [B: $tType] :
      ( ordere8940638589300402666id_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),C2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)) ) ) ) ).

% add_strict_increasing
tff(fact_520_add__strict__increasing2,axiom,
    ! [B: $tType] :
      ( ordere8940638589300402666id_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),C2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)) ) ) ) ).

% add_strict_increasing2
tff(fact_521_discrete,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),B2) ) ) ).

% discrete
tff(fact_522_le__minus__one__simps_I1_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),one_one(B))),zero_zero(B)) ) ).

% le_minus_one_simps(1)
tff(fact_523_le__minus__one__simps_I3_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% le_minus_one_simps(3)
tff(fact_524_dense__eq0__I,axiom,
    ! [B: $tType] :
      ( ( ordere166539214618696060dd_abs(B)
        & dense_linorder(B) )
     => ! [X2: B] :
          ( ! [E3: B] :
              ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),E3)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),X2)),E3) )
         => ( X2 = zero_zero(B) ) ) ) ).

% dense_eq0_I
tff(fact_525_abs__minus__le__zero,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),aa(B,B,abs_abs(B),A3))),zero_zero(B)) ) ).

% abs_minus_le_zero
tff(fact_526_success__changeI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [F: fun(B,B),R: ref(B),Ha: heap_ext(product_unit)] : heap_Time_success(B,ref_change(B,F,R),Ha) ) ).

% success_changeI
tff(fact_527_semiring__norm_I6_J,axiom,
    ! [M: num,N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,bit0,M)),aa(num,num,bit0,N)) = aa(num,num,bit0,aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% semiring_norm(6)
tff(fact_528_field__le__epsilon,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B,Y: B] :
          ( ! [E3: B] :
              ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),E3)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),Y),E3)) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y) ) ) ).

% field_le_epsilon
tff(fact_529_ex__has__greatest__nat__lemma,axiom,
    ! [B: $tType,P: fun(B,$o),K: B,F: fun(B,nat),N: nat] :
      ( aa(B,$o,P,K)
     => ( ! [X3: B] :
            ( aa(B,$o,P,X3)
           => ? [Y5: B] :
                ( aa(B,$o,P,Y5)
                & ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,F,Y5)),aa(B,nat,F,X3)) ) )
       => ? [Y4: B] :
            ( aa(B,$o,P,Y4)
            & ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,Y4)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,F,K)),N)) ) ) ) ).

% ex_has_greatest_nat_lemma
tff(fact_530_map__comp__def,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,option(C)),G: fun(B,option(D)),X: B] : map_comp(D,C,B,F,G,X) = aa(option(D),option(C),aa(fun(D,option(C)),fun(option(D),option(C)),aa(option(C),fun(fun(D,option(C)),fun(option(D),option(C))),case_option(option(C),D),none(C)),F),aa(B,option(D),G,X)) ).

% map_comp_def
tff(fact_531_convex__bound__lt,axiom,
    ! [B: $tType] :
      ( linord715952674999750819strict(B)
     => ! [X2: B,A3: B,Y: B,U: B,V: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),Y),A3)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),U)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),V)
               => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),U),V) = one_one(B) )
                 => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),U),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),V),Y))),A3) ) ) ) ) ) ) ).

% convex_bound_lt
tff(fact_532_map__comp__empty_I1_J,axiom,
    ! [B: $tType,D: $tType,C: $tType,M: fun(D,option(C)),X: B] : map_comp(D,C,B,M,aTP_Lamp_ba(B,option(D)),X) = none(C) ).

% map_comp_empty(1)
tff(fact_533_map__comp__empty_I2_J,axiom,
    ! [B: $tType,D: $tType,C: $tType,M: fun(B,option(D)),X: B] : map_comp(D,C,B,aTP_Lamp_bi(D,option(C)),M,X) = none(C) ).

% map_comp_empty(2)
tff(fact_534_map__comp__None__iff,axiom,
    ! [D: $tType,C: $tType,B: $tType,M1: fun(C,option(B)),M22: fun(D,option(C)),K: D] :
      ( ( map_comp(C,B,D,M1,M22,K) = none(B) )
    <=> ( ( aa(D,option(C),M22,K) = none(C) )
        | ? [K5: C] :
            ( ( aa(D,option(C),M22,K) = aa(C,option(C),some(C),K5) )
            & ( aa(C,option(B),M1,K5) = none(B) ) ) ) ) ).

% map_comp_None_iff
tff(fact_535_Ints__eq__abs__less1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( member(B,X2,ring_1_Ints(B))
         => ( member(B,Y,ring_1_Ints(B))
           => ( ( X2 = Y )
            <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Y))),one_one(B)) ) ) ) ) ).

% Ints_eq_abs_less1
tff(fact_536_nat0__intermed__int__val,axiom,
    ! [N: nat,F: fun(nat,int),K: int] :
      ( ! [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),N)
         => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,abs_abs(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(nat,int,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I2),one_one(nat)))),aa(nat,int,F,I2)))),one_one(int)) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(nat,int,F,zero_zero(nat))),K)
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),K),aa(nat,int,F,N))
         => ? [I2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I2),N)
              & ( aa(nat,int,F,I2) = K ) ) ) ) ) ).

% nat0_intermed_int_val
tff(fact_537_diff__diff__left,axiom,
    ! [I: nat,J: nat,K: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J)),K) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K)) ).

% diff_diff_left
tff(fact_538_nat__1__eq__mult__iff,axiom,
    ! [M: nat,N: nat] :
      ( ( one_one(nat) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N) )
    <=> ( ( M = one_one(nat) )
        & ( N = one_one(nat) ) ) ) ).

% nat_1_eq_mult_iff
tff(fact_539_nat__mult__eq__1__iff,axiom,
    ! [M: nat,N: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N) = one_one(nat) )
    <=> ( ( M = one_one(nat) )
        & ( N = one_one(nat) ) ) ) ).

% nat_mult_eq_1_iff
tff(fact_540_cancel__comm__monoid__add__class_Odiff__cancel,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),A3) = zero_zero(B) ) ).

% cancel_comm_monoid_add_class.diff_cancel
tff(fact_541_diff__zero,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),zero_zero(B)) = A3 ) ).

% diff_zero
tff(fact_542_zero__diff,axiom,
    ! [B: $tType] :
      ( comm_monoid_diff(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),zero_zero(B)),A3) = zero_zero(B) ) ).

% zero_diff
tff(fact_543_diff__0__right,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),zero_zero(B)) = A3 ) ).

% diff_0_right
tff(fact_544_diff__self,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),A3) = zero_zero(B) ) ).

% diff_self
tff(fact_545_mult_Oright__neutral,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),one_one(B)) = A3 ) ).

% mult.right_neutral
tff(fact_546_mult__1,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),one_one(B)),A3) = A3 ) ).

% mult_1
tff(fact_547_add__diff__cancel__right_H,axiom,
    ! [B: $tType] :
      ( cancel2418104881723323429up_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),B2) = A3 ) ).

% add_diff_cancel_right'
tff(fact_548_add__diff__cancel__right,axiom,
    ! [B: $tType] :
      ( cancel2418104881723323429up_add(B)
     => ! [A3: B,C2: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) ) ).

% add_diff_cancel_right
tff(fact_549_add__diff__cancel__left_H,axiom,
    ! [B: $tType] :
      ( cancel2418104881723323429up_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),A3) = B2 ) ).

% add_diff_cancel_left'
tff(fact_550_add__diff__cancel__left,axiom,
    ! [B: $tType] :
      ( cancel2418104881723323429up_add(B)
     => ! [C2: B,A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) ) ).

% add_diff_cancel_left
tff(fact_551_diff__add__cancel,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),B2) = A3 ) ).

% diff_add_cancel
tff(fact_552_add__diff__cancel,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),B2) = A3 ) ).

% add_diff_cancel
tff(fact_553_minus__diff__eq,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3) ) ).

% minus_diff_eq
tff(fact_554_Nat_Oadd__diff__assoc,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J)),K) ) ) ).

% Nat.add_diff_assoc
tff(fact_555_Nat_Oadd__diff__assoc2,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)),I) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),I)),K) ) ) ).

% Nat.add_diff_assoc2
tff(fact_556_Nat_Odiff__diff__right,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),J) ) ) ).

% Nat.diff_diff_right
tff(fact_557_zle__add1__eq__le,axiom,
    ! [W: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),W),aa(int,int,aa(int,fun(int,int),plus_plus(int),Z2),one_one(int)))
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),W),Z2) ) ).

% zle_add1_eq_le
tff(fact_558_map__comp__simps_I2_J,axiom,
    ! [C: $tType,D: $tType,B: $tType,M22: fun(C,option(B)),K: C,K6: B,M1: fun(B,option(D))] :
      ( ( aa(C,option(B),M22,K) = aa(B,option(B),some(B),K6) )
     => ( map_comp(B,D,C,M1,M22,K) = aa(B,option(D),M1,K6) ) ) ).

% map_comp_simps(2)
tff(fact_559_map__comp__simps_I1_J,axiom,
    ! [C: $tType,B: $tType,D: $tType,M22: fun(C,option(B)),K: C,M1: fun(B,option(D))] :
      ( ( aa(C,option(B),M22,K) = none(B) )
     => ( map_comp(B,D,C,M1,M22,K) = none(D) ) ) ).

% map_comp_simps(1)
tff(fact_560_diff__ge__0__iff__ge,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ).

% diff_ge_0_iff_ge
tff(fact_561_zero__comp__diff__simps_I1_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ).

% zero_comp_diff_simps(1)
tff(fact_562_diff__gt__0__iff__gt,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ).

% diff_gt_0_iff_gt
tff(fact_563_zero__comp__diff__simps_I2_J,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ).

% zero_comp_diff_simps(2)
tff(fact_564_le__add__diff__inverse,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) = A3 ) ) ) ).

% le_add_diff_inverse
tff(fact_565_le__add__diff__inverse2,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),B2) = A3 ) ) ) ).

% le_add_diff_inverse2
tff(fact_566_mult__cancel__left1,axiom,
    ! [B: $tType] :
      ( ring_15535105094025558882visors(B)
     => ! [C2: B,B2: B] :
          ( ( C2 = aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2) )
        <=> ( ( C2 = zero_zero(B) )
            | ( B2 = one_one(B) ) ) ) ) ).

% mult_cancel_left1
tff(fact_567_mult__cancel__left2,axiom,
    ! [B: $tType] :
      ( ring_15535105094025558882visors(B)
     => ! [C2: B,A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3) = C2 )
        <=> ( ( C2 = zero_zero(B) )
            | ( A3 = one_one(B) ) ) ) ) ).

% mult_cancel_left2
tff(fact_568_mult__cancel__right1,axiom,
    ! [B: $tType] :
      ( ring_15535105094025558882visors(B)
     => ! [C2: B,B2: B] :
          ( ( C2 = aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2) )
        <=> ( ( C2 = zero_zero(B) )
            | ( B2 = one_one(B) ) ) ) ) ).

% mult_cancel_right1
tff(fact_569_mult__cancel__right2,axiom,
    ! [B: $tType] :
      ( ring_15535105094025558882visors(B)
     => ! [A3: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2) = C2 )
        <=> ( ( C2 = zero_zero(B) )
            | ( A3 = one_one(B) ) ) ) ) ).

% mult_cancel_right2
tff(fact_570_diff__add__zero,axiom,
    ! [B: $tType] :
      ( comm_monoid_diff(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = zero_zero(B) ) ).

% diff_add_zero
tff(fact_571_diff__numeral__special_I9_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),one_one(B)) = zero_zero(B) ) ) ).

% diff_numeral_special(9)
tff(fact_572_diff__0,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),zero_zero(B)),A3) = aa(B,B,uminus_uminus(B),A3) ) ).

% diff_0
tff(fact_573_mult__minus1,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [Z2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,uminus_uminus(B),one_one(B))),Z2) = aa(B,B,uminus_uminus(B),Z2) ) ).

% mult_minus1
tff(fact_574_mult__minus1__right,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [Z2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),Z2),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),Z2) ) ).

% mult_minus1_right
tff(fact_575_uminus__add__conv__diff,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),B2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3) ) ).

% uminus_add_conv_diff
tff(fact_576_diff__minus__eq__add,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(B,B,uminus_uminus(B),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) ) ).

% diff_minus_eq_add
tff(fact_577_diff__numeral__special_I12_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(B,B,uminus_uminus(B),one_one(B))) = zero_zero(B) ) ) ).

% diff_numeral_special(12)
tff(fact_578_le__imp__0__less,axiom,
    ! [Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),Z2)
     => aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),Z2)) ) ).

% le_imp_0_less
tff(fact_579_q__pos__lemma,axiom,
    ! [B4: int,Q4: int,R3: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B4),Q4)),R3))
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R3),B4)
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),B4)
         => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),Q4) ) ) ) ).

% q_pos_lemma
tff(fact_580_zdiv__mono2__lemma,axiom,
    ! [B2: int,Q3: int,R: int,B4: int,Q4: int,R3: int] :
      ( ( aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B4),Q4)),R3) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B4),Q4)),R3))
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R3),B4)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),R)
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),B4)
             => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),B4),B2)
               => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Q3),Q4) ) ) ) ) ) ) ).

% zdiv_mono2_lemma
tff(fact_581_zdiv__mono2__neg__lemma,axiom,
    ! [B2: int,Q3: int,R: int,B4: int,Q4: int,R3: int] :
      ( ( aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B4),Q4)),R3) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B4),Q4)),R3)),zero_zero(int))
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R),B2)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),R3)
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),B4)
             => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),B4),B2)
               => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Q4),Q3) ) ) ) ) ) ) ).

% zdiv_mono2_neg_lemma
tff(fact_582_unique__quotient__lemma,axiom,
    ! [B2: int,Q4: int,R3: int,Q3: int,R: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q4)),R3)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R))
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),R3)
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R3),B2)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R),B2)
           => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Q4),Q3) ) ) ) ) ).

% unique_quotient_lemma
tff(fact_583_unique__quotient__lemma__neg,axiom,
    ! [B2: int,Q4: int,R3: int,Q3: int,R: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q4)),R3)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R))
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),R),zero_zero(int))
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),B2),R)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),B2),R3)
           => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Q3),Q4) ) ) ) ) ).

% unique_quotient_lemma_neg
tff(fact_584_int__ge__induct,axiom,
    ! [K: int,I: int,P: fun(int,$o)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),K),I)
     => ( aa(int,$o,P,K)
       => ( ! [I2: int] :
              ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),K),I2)
             => ( aa(int,$o,P,I2)
               => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),I2),one_one(int))) ) )
         => aa(int,$o,P,I) ) ) ) ).

% int_ge_induct
tff(fact_585_int__induct,axiom,
    ! [P: fun(int,$o),K: int,I: int] :
      ( aa(int,$o,P,K)
     => ( ! [I2: int] :
            ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),K),I2)
           => ( aa(int,$o,P,I2)
             => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),I2),one_one(int))) ) )
       => ( ! [I2: int] :
              ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I2),K)
             => ( aa(int,$o,P,I2)
               => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),I2),one_one(int))) ) )
         => aa(int,$o,P,I) ) ) ) ).

% int_induct
tff(fact_586_zless__imp__add1__zle,axiom,
    ! [W: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),W),Z2)
     => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),W),one_one(int))),Z2) ) ).

% zless_imp_add1_zle
tff(fact_587_add1__zle__eq,axiom,
    ! [W: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),W),one_one(int))),Z2)
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),W),Z2) ) ).

% add1_zle_eq
tff(fact_588_nat__eq__add__iff1,axiom,
    ! [J: nat,I: nat,U: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),M) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N) )
      <=> ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J)),U)),M) = N ) ) ) ).

% nat_eq_add_iff1
tff(fact_589_nat__eq__add__iff2,axiom,
    ! [I: nat,J: nat,U: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),M) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N) )
      <=> ( M = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I)),U)),N) ) ) ) ).

% nat_eq_add_iff2
tff(fact_590_nat__le__add__iff1,axiom,
    ! [J: nat,I: nat,U: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( 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),I),U)),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N))
      <=> 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),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J)),U)),M)),N) ) ) ).

% nat_le_add_iff1
tff(fact_591_nat__le__add__iff2,axiom,
    ! [I: nat,J: nat,U: nat,M: nat,N: 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),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N))
      <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I)),U)),N)) ) ) ).

% nat_le_add_iff2
tff(fact_592_nat__diff__add__eq1,axiom,
    ! [J: nat,I: nat,U: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J)),U)),M)),N) ) ) ).

% nat_diff_add_eq1
tff(fact_593_nat__diff__add__eq2,axiom,
    ! [I: nat,J: nat,U: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I)),U)),N)) ) ) ).

% nat_diff_add_eq2
tff(fact_594_bounded__Max__nat,axiom,
    ! [P: fun(nat,$o),X2: nat,M2: nat] :
      ( aa(nat,$o,P,X2)
     => ( ! [X3: nat] :
            ( aa(nat,$o,P,X3)
           => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),X3),M2) )
       => ~ ! [M4: nat] :
              ( aa(nat,$o,P,M4)
             => ~ ! [X: nat] :
                    ( aa(nat,$o,P,X)
                   => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),X),M4) ) ) ) ) ).

% bounded_Max_nat
tff(fact_595_subset__Collect__conv,axiom,
    ! [B: $tType,S2: set(B),P: fun(B,$o)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),aa(fun(B,$o),set(B),collect(B),P))
    <=> ! [X4: B] :
          ( member(B,X4,S2)
         => aa(B,$o,P,X4) ) ) ).

% subset_Collect_conv
tff(fact_596_cancel__ab__semigroup__add__class_Odiff__right__commute,axiom,
    ! [B: $tType] :
      ( cancel2418104881723323429up_add(B)
     => ! [A3: B,C2: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2)),B2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),C2) ) ).

% cancel_ab_semigroup_add_class.diff_right_commute
tff(fact_597_ab__semigroup__mult__class_Omult_Oleft__commute,axiom,
    ! [B: $tType] :
      ( ab_semigroup_mult(B)
     => ! [B2: B,A3: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) ) ).

% ab_semigroup_mult_class.mult.left_commute
tff(fact_598_ab__semigroup__mult__class_Omult_Ocommute,axiom,
    ! [B: $tType] :
      ( ab_semigroup_mult(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2) = aa(B,B,aa(B,fun(B,B),times_times(B),B2),A3) ) ).

% ab_semigroup_mult_class.mult.commute
tff(fact_599_mult_Oassoc,axiom,
    ! [B: $tType] :
      ( semigroup_mult(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) ) ).

% mult.assoc
tff(fact_600_diff__eq__diff__eq,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),D3) )
         => ( ( A3 = B2 )
          <=> ( C2 = D3 ) ) ) ) ).

% diff_eq_diff_eq
tff(fact_601_one__integer_Orsp,axiom,
    one_one(int) = one_one(int) ).

% one_integer.rsp
tff(fact_602_int__gr__induct,axiom,
    ! [K: int,I: int,P: fun(int,$o)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),I)
     => ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),K),one_one(int)))
       => ( ! [I2: int] :
              ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),I2)
             => ( aa(int,$o,P,I2)
               => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),I2),one_one(int))) ) )
         => aa(int,$o,P,I) ) ) ) ).

% int_gr_induct
tff(fact_603_zless__add1__eq,axiom,
    ! [W: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),W),aa(int,int,aa(int,fun(int,int),plus_plus(int),Z2),one_one(int)))
    <=> ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),W),Z2)
        | ( W = Z2 ) ) ) ).

% zless_add1_eq
tff(fact_604_odd__nonzero,axiom,
    ! [Z2: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),Z2)),Z2) != zero_zero(int) ).

% odd_nonzero
tff(fact_605_odd__less__0__iff,axiom,
    ! [Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),Z2)),Z2)),zero_zero(int))
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z2),zero_zero(int)) ) ).

% odd_less_0_iff
tff(fact_606_eq__add__iff1,axiom,
    ! [B: $tType] :
      ( ring(B)
     => ! [A3: B,E2: B,C2: B,B2: B,D3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),D3) )
        <=> ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),E2)),C2) = D3 ) ) ) ).

% eq_add_iff1
tff(fact_607_eq__add__iff2,axiom,
    ! [B: $tType] :
      ( ring(B)
     => ! [A3: B,E2: B,C2: B,B2: B,D3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),D3) )
        <=> ( C2 = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)),E2)),D3) ) ) ) ).

% eq_add_iff2
tff(fact_608_square__diff__square__factored,axiom,
    ! [B: $tType] :
      ( comm_ring(B)
     => ! [X2: B,Y: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Y)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Y)) ) ).

% square_diff_square_factored
tff(fact_609_left__add__mult__distrib,axiom,
    ! [I: nat,U: nat,J: nat,K: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),K)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J)),U)),K) ).

% left_add_mult_distrib
tff(fact_610_nat__less__add__iff1,axiom,
    ! [J: nat,I: nat,U: nat,M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( 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),I),U)),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N))
      <=> 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),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J)),U)),M)),N) ) ) ).

% nat_less_add_iff1
tff(fact_611_nat__less__add__iff2,axiom,
    ! [I: nat,J: nat,U: nat,M: nat,N: 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(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),I),U)),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),J),U)),N))
      <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I)),U)),N)) ) ) ).

% nat_less_add_iff2
tff(fact_612_le__add__iff1,axiom,
    ! [B: $tType] :
      ( ordered_ring(B)
     => ! [A3: B,E2: B,C2: B,B2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),D3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),E2)),C2)),D3) ) ) ).

% le_add_iff1
tff(fact_613_le__add__iff2,axiom,
    ! [B: $tType] :
      ( ordered_ring(B)
     => ! [A3: B,E2: B,C2: B,B2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),D3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)),E2)),D3)) ) ) ).

% le_add_iff2
tff(fact_614_less__add__iff1,axiom,
    ! [B: $tType] :
      ( ordered_ring(B)
     => ! [A3: B,E2: B,C2: B,B2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),D3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),E2)),C2)),D3) ) ) ).

% less_add_iff1
tff(fact_615_less__add__iff2,axiom,
    ! [B: $tType] :
      ( ordered_ring(B)
     => ! [A3: B,E2: B,C2: B,B2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),C2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),D3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)),E2)),D3)) ) ) ).

% less_add_iff2
tff(fact_616_square__diff__one__factored,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),one_one(B)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),one_one(B))),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),one_one(B))) ) ).

% square_diff_one_factored
tff(fact_617_diff__eq__diff__less__eq,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),D3) )
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),D3) ) ) ) ).

% diff_eq_diff_less_eq
tff(fact_618_diff__right__mono,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),C2)) ) ) ).

% diff_right_mono
tff(fact_619_diff__left__mono,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [B2: B,A3: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2)) ) ) ).

% diff_left_mono
tff(fact_620_diff__mono,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,D3: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),D3),C2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),D3)) ) ) ) ).

% diff_mono
tff(fact_621_eq__iff__diff__eq__0,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] :
          ( ( A3 = B2 )
        <=> ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = zero_zero(B) ) ) ) ).

% eq_iff_diff_eq_0
tff(fact_622_diff__strict__right__mono,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),C2)) ) ) ).

% diff_strict_right_mono
tff(fact_623_diff__strict__left__mono,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [B2: B,A3: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),A3)),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2)) ) ) ).

% diff_strict_left_mono
tff(fact_624_diff__eq__diff__less,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),D3) )
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),D3) ) ) ) ).

% diff_eq_diff_less
tff(fact_625_diff__strict__mono,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,D3: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),D3),C2)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),D3)) ) ) ) ).

% diff_strict_mono
tff(fact_626_diff__diff__eq,axiom,
    ! [B: $tType] :
      ( cancel2418104881723323429up_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ).

% diff_diff_eq
tff(fact_627_add__implies__diff,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [C2: B,B2: B,A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2) = A3 )
         => ( C2 = aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) ) ) ) ).

% add_implies_diff
tff(fact_628_diff__add__eq__diff__diff__swap,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2)),B2) ) ).

% diff_add_eq_diff_diff_swap
tff(fact_629_diff__add__eq,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),B2) ) ).

% diff_add_eq
tff(fact_630_diff__diff__eq2,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2)),B2) ) ).

% diff_diff_eq2
tff(fact_631_add__diff__eq,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) ) ).

% add_diff_eq
tff(fact_632_eq__diff__eq,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,C2: B,B2: B] :
          ( ( A3 = aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2) )
        <=> ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = C2 ) ) ) ).

% eq_diff_eq
tff(fact_633_diff__eq__eq,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = C2 )
        <=> ( A3 = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2) ) ) ) ).

% diff_eq_eq
tff(fact_634_group__cancel_Osub1,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A4: B,K: B,A3: B,B2: B] :
          ( ( A4 = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),A3) )
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A4),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) ) ) ) ).

% group_cancel.sub1
tff(fact_635_minus__diff__commute,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [B2: B,A3: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),B2)),A3) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),A3)),B2) ) ).

% minus_diff_commute
tff(fact_636_ring__class_Oring__distribs_I2_J,axiom,
    ! [B: $tType] :
      ( ring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) ) ).

% ring_class.ring_distribs(2)
tff(fact_637_ring__class_Oring__distribs_I1_J,axiom,
    ! [B: $tType] :
      ( ring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)) ) ).

% ring_class.ring_distribs(1)
tff(fact_638_comm__semiring__class_Odistrib,axiom,
    ! [B: $tType] :
      ( comm_semiring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) ) ).

% comm_semiring_class.distrib
tff(fact_639_distrib__left,axiom,
    ! [B: $tType] :
      ( semiring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)) ) ).

% distrib_left
tff(fact_640_distrib__right,axiom,
    ! [B: $tType] :
      ( semiring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) ) ).

% distrib_right
tff(fact_641_combine__common__factor,axiom,
    ! [B: $tType] :
      ( semiring(B)
     => ! [A3: B,E2: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),E2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),E2)),C2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),E2)),C2) ) ).

% combine_common_factor
tff(fact_642_crossproduct__eq,axiom,
    ! [B: $tType] :
      ( semiri1453513574482234551roduct(B)
     => ! [W: B,Y: B,X2: B,Z2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),W),Y)),aa(B,B,aa(B,fun(B,B),times_times(B),X2),Z2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),W),Z2)),aa(B,B,aa(B,fun(B,B),times_times(B),X2),Y)) )
        <=> ( ( W = X2 )
            | ( Y = Z2 ) ) ) ) ).

% crossproduct_eq
tff(fact_643_crossproduct__noteq,axiom,
    ! [B: $tType] :
      ( semiri1453513574482234551roduct(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( ( A3 != B2 )
            & ( C2 != D3 ) )
        <=> ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),D3)) != aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),D3)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) ) ) ) ).

% crossproduct_noteq
tff(fact_644_comm__monoid__mult__class_Omult__1,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),one_one(B)),A3) = A3 ) ).

% comm_monoid_mult_class.mult_1
tff(fact_645_mult_Ocomm__neutral,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),one_one(B)) = A3 ) ).

% mult.comm_neutral
tff(fact_646_abs__minus__commute,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) = aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)) ) ).

% abs_minus_commute
tff(fact_647_Nat_Odiff__cancel,axiom,
    ! [K: nat,M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),M)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),N) ).

% Nat.diff_cancel
tff(fact_648_diff__cancel2,axiom,
    ! [M: nat,K: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),N) ).

% diff_cancel2
tff(fact_649_diff__add__inverse,axiom,
    ! [N: nat,M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)),N) = M ).

% diff_add_inverse
tff(fact_650_diff__add__inverse2,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),N) = M ).

% diff_add_inverse2
tff(fact_651_le__diff__conv,axiom,
    ! [J: nat,K: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)),I)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)) ) ).

% le_diff_conv
tff(fact_652_Nat_Ole__diff__conv2,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K))
      <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),J) ) ) ).

% Nat.le_diff_conv2
tff(fact_653_Nat_Odiff__add__assoc,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J)),K) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)) ) ) ).

% Nat.diff_add_assoc
tff(fact_654_Nat_Odiff__add__assoc2,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),I)),K) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)),I) ) ) ).

% Nat.diff_add_assoc2
tff(fact_655_Nat_Ole__imp__diff__is__add,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I) = K )
      <=> ( J = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),I) ) ) ) ).

% Nat.le_imp_diff_is_add
tff(fact_656_add__mult__distrib,axiom,
    ! [M: nat,N: nat,K: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),K) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),K)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),K)) ).

% add_mult_distrib
tff(fact_657_add__mult__distrib2,axiom,
    ! [K: nat,M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),M)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),N)) ).

% add_mult_distrib2
tff(fact_658_mlex__leI,axiom,
    ! [A3: nat,A6: nat,B2: nat,B4: nat,N5: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),A6)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),B2),B4)
       => 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),N5)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A6),N5)),B4)) ) ) ).

% mlex_leI
tff(fact_659_nat__mult__1,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),one_one(nat)),N) = N ).

% nat_mult_1
tff(fact_660_nat__mult__1__right,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),one_one(nat)) = N ).

% nat_mult_1_right
tff(fact_661_mult__eq__if,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N) = $ite(M = zero_zero(nat),zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))),N))) ).

% mult_eq_if
tff(fact_662_lambda__one,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ( aTP_Lamp_bj(B,B) = aa(B,fun(B,B),times_times(B),one_one(B)) ) ) ).

% lambda_one
tff(fact_663_is__num__normalize_I6_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [X2: B,Y: B] :
          ( neg_numeral_is_num(B,X2)
         => ( neg_numeral_is_num(B,Y)
           => neg_numeral_is_num(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)) ) ) ) ).

% is_num_normalize(6)
tff(fact_664_is__num__add__commute,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [X2: B,Y: B] :
          ( neg_numeral_is_num(B,X2)
         => ( neg_numeral_is_num(B,Y)
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Y),X2) ) ) ) ) ).

% is_num_add_commute
tff(fact_665_is__num__add__left__commute,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [X2: B,Y: B,Z2: B] :
          ( neg_numeral_is_num(B,X2)
         => ( neg_numeral_is_num(B,Y)
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),Y),Z2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Y),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Z2)) ) ) ) ) ).

% is_num_add_left_commute
tff(fact_666_is__num__normalize_I4_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => neg_numeral_is_num(B,one_one(B)) ) ).

% is_num_normalize(4)
tff(fact_667_le__iff__diff__le__0,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),zero_zero(B)) ) ) ).

% le_iff_diff_le_0
tff(fact_668_less__iff__diff__less__0,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),zero_zero(B)) ) ) ).

% less_iff_diff_less_0
tff(fact_669_ordered__cancel__comm__monoid__diff__class_Ole__imp__diff__is__add,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
           => ( ( aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3) = C2 )
            <=> ( B2 = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3) ) ) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.le_imp_diff_is_add
tff(fact_670_ordered__cancel__comm__monoid__diff__class_Oadd__diff__inverse,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)) = B2 ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.add_diff_inverse
tff(fact_671_ordered__cancel__comm__monoid__diff__class_Odiff__diff__right,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),B2) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_diff_right
tff(fact_672_ordered__cancel__comm__monoid__diff__class_Odiff__add__assoc2,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)),C2) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_add_assoc2
tff(fact_673_ordered__cancel__comm__monoid__diff__class_Oadd__diff__assoc2,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)),C2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)),A3) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.add_diff_assoc2
tff(fact_674_ordered__cancel__comm__monoid__diff__class_Odiff__add__assoc,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_add_assoc
tff(fact_675_ordered__cancel__comm__monoid__diff__class_Oadd__diff__assoc,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)),A3) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.add_diff_assoc
tff(fact_676_ordered__cancel__comm__monoid__diff__class_Ole__diff__conv2,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)),B2) ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.le_diff_conv2
tff(fact_677_le__add__diff,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)),A3)) ) ) ).

% le_add_diff
tff(fact_678_ordered__cancel__comm__monoid__diff__class_Odiff__add,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3)),A3) = B2 ) ) ) ).

% ordered_cancel_comm_monoid_diff_class.diff_add
tff(fact_679_le__diff__eq,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) ) ) ).

% le_diff_eq
tff(fact_680_diff__le__eq,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),C2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)) ) ) ).

% diff_le_eq
tff(fact_681_add__le__imp__le__diff,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [I: B,K: B,N: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),N)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),aa(B,B,aa(B,fun(B,B),minus_minus(B),N),K)) ) ) ).

% add_le_imp_le_diff
tff(fact_682_add__le__add__imp__diff__le,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [I: B,K: B,N: B,J: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),N)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),N),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),K))
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K)),N)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),N),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),K))
               => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),N),K)),J) ) ) ) ) ) ).

% add_le_add_imp_diff_le
tff(fact_683_less__diff__eq,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) ) ) ).

% less_diff_eq
tff(fact_684_diff__less__eq,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A3: B,B2: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)),C2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)) ) ) ).

% diff_less_eq
tff(fact_685_linordered__semidom__class_Oadd__diff__inverse,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,B2: B] :
          ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) = A3 ) ) ) ).

% linordered_semidom_class.add_diff_inverse
tff(fact_686_ab__group__add__class_Oab__diff__conv__add__uminus,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,uminus_uminus(B),B2)) ) ).

% ab_group_add_class.ab_diff_conv_add_uminus
tff(fact_687_diff__conv__add__uminus,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,uminus_uminus(B),B2)) ) ).

% diff_conv_add_uminus
tff(fact_688_group__cancel_Osub2,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [B5: B,K: B,B2: B,A3: B] :
          ( ( B5 = aa(B,B,aa(B,fun(B,B),plus_plus(B),K),B2) )
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B5) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),K)),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) ) ) ) ).

% group_cancel.sub2
tff(fact_689_abs__triangle__ineq2__sym,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2))),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),A3))) ) ).

% abs_triangle_ineq2_sym
tff(fact_690_abs__triangle__ineq3,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2)))),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))) ) ).

% abs_triangle_ineq3
tff(fact_691_abs__triangle__ineq2,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2))),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))) ) ).

% abs_triangle_ineq2
tff(fact_692_add__scale__eq__noteq,axiom,
    ! [B: $tType] :
      ( semiri1453513574482234551roduct(B)
     => ! [R: B,A3: B,B2: B,C2: B,D3: B] :
          ( ( R != zero_zero(B) )
         => ( ( ( A3 = B2 )
              & ( C2 != D3 ) )
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),R),C2)) != aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),aa(B,B,aa(B,fun(B,B),times_times(B),R),D3)) ) ) ) ) ).

% add_scale_eq_noteq
tff(fact_693_less__1__mult,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [M: B,N: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),N)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),M),N)) ) ) ) ).

% less_1_mult
tff(fact_694_square__eq__1__iff,axiom,
    ! [B: $tType] :
      ( ring_15535105094025558882visors(B)
     => ! [X2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2) = one_one(B) )
        <=> ( ( X2 = one_one(B) )
            | ( X2 = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ) ) ).

% square_eq_1_iff
tff(fact_695_diff__add__0,axiom,
    ! [N: nat,M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)) = zero_zero(nat) ).

% diff_add_0
tff(fact_696_less__diff__conv,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K))
    <=> 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) ) ).

% less_diff_conv
tff(fact_697_add__diff__inverse__nat,axiom,
    ! [M: nat,N: nat] :
      ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),N)) = M ) ) ).

% add_diff_inverse_nat
tff(fact_698_less__diff__conv2,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K)),I)
      <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)) ) ) ).

% less_diff_conv2
tff(fact_699_mlex__snd__decrI,axiom,
    ! [A3: nat,A6: nat,B2: nat,B4: nat,N5: nat] :
      ( ( A3 = A6 )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),B4)
       => 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),N5)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A6),N5)),B4)) ) ) ).

% mlex_snd_decrI
tff(fact_700_mlex__fst__decrI,axiom,
    ! [A3: nat,A6: nat,B2: nat,N5: nat,B4: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),A6)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B2),N5)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),B4),N5)
         => 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),N5)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A6),N5)),B4)) ) ) ) ).

% mlex_fst_decrI
tff(fact_701_mlex__bound,axiom,
    ! [A3: nat,A4: nat,B2: nat,N5: 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),N5)
       => 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),N5)),B2)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A4),N5)) ) ) ).

% mlex_bound
tff(fact_702_mult__eq__self__implies__10,axiom,
    ! [M: nat,N: nat] :
      ( ( M = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N) )
     => ( ( N = one_one(nat) )
        | ( M = zero_zero(nat) ) ) ) ).

% mult_eq_self_implies_10
tff(fact_703_map__comp__Some__iff,axiom,
    ! [D: $tType,C: $tType,B: $tType,M1: fun(C,option(B)),M22: fun(D,option(C)),K: D,V: B] :
      ( ( map_comp(C,B,D,M1,M22,K) = aa(B,option(B),some(B),V) )
    <=> ? [K5: C] :
          ( ( aa(D,option(C),M22,K) = aa(C,option(C),some(C),K5) )
          & ( aa(C,option(B),M1,K5) = aa(B,option(B),some(B),V) ) ) ) ).

% map_comp_Some_iff
tff(fact_704_field__le__mult__one__interval,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B,Y: B] :
          ( ! [Z3: B] :
              ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),Z3)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),Z3),one_one(B))
               => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),Z3),X2)),Y) ) )
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y) ) ) ).

% field_le_mult_one_interval
tff(fact_705_abs__diff__le__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,A3: B,R: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),A3))),R)
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),R)),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),R)) ) ) ) ).

% abs_diff_le_iff
tff(fact_706_abs__diff__triangle__ineq,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B,C2: B,D3: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),D3)))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),C2))),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),D3)))) ) ).

% abs_diff_triangle_ineq
tff(fact_707_abs__triangle__ineq4,axiom,
    ! [B: $tType] :
      ( ordere166539214618696060dd_abs(B)
     => ! [A3: B,B2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,abs_abs(B),A3)),aa(B,B,abs_abs(B),B2))) ) ).

% abs_triangle_ineq4
tff(fact_708_abs__diff__less__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,A3: B,R: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),A3))),R)
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),R)),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),R)) ) ) ) ).

% abs_diff_less_iff
tff(fact_709_sum__squares__ge__zero,axiom,
    ! [B: $tType] :
      ( linordered_ring(B)
     => ! [X2: B,Y: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Y))) ) ).

% sum_squares_ge_zero
tff(fact_710_mult__left__le,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [C2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),one_one(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),A3) ) ) ) ).

% mult_left_le
tff(fact_711_mult__le__one,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),one_one(B)) ) ) ) ) ).

% mult_le_one
tff(fact_712_mult__right__le__one__le,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),Y)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),Y)),X2) ) ) ) ) ).

% mult_right_le_one_le
tff(fact_713_mult__left__le__one__le,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),Y)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),Y),X2)),X2) ) ) ) ) ).

% mult_left_le_one_le
tff(fact_714_not__sum__squares__lt__zero,axiom,
    ! [B: $tType] :
      ( linordered_ring(B)
     => ! [X2: B,Y: B] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Y))),zero_zero(B)) ) ).

% not_sum_squares_lt_zero
tff(fact_715_nat__diff__split,axiom,
    ! [P: fun(nat,$o),A3: nat,B2: nat] :
      ( aa(nat,$o,P,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),A3),B2))
    <=> ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
         => aa(nat,$o,P,zero_zero(nat)) )
        & ! [D5: nat] :
            ( ( A3 = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),B2),D5) )
           => aa(nat,$o,P,D5) ) ) ) ).

% nat_diff_split
tff(fact_716_nat__diff__split__asm,axiom,
    ! [P: fun(nat,$o),A3: nat,B2: nat] :
      ( aa(nat,$o,P,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),A3),B2))
    <=> ~ ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
            & ~ aa(nat,$o,P,zero_zero(nat)) )
          | ? [D5: nat] :
              ( ( A3 = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),B2),D5) )
              & ~ aa(nat,$o,P,D5) ) ) ) ).

% nat_diff_split_asm
tff(fact_717_dbl__dec__def,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [X2: B] : neg_numeral_dbl_dec(B,X2) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),X2)),one_one(B)) ) ).

% dbl_dec_def
tff(fact_718_mult__le__cancel__left1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),B2) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),one_one(B)) ) ) ) ) ).

% mult_le_cancel_left1
tff(fact_719_mult__le__cancel__left2,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3)),C2)
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B)) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),A3) ) ) ) ) ).

% mult_le_cancel_left2
tff(fact_720_mult__le__cancel__right1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),B2) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),one_one(B)) ) ) ) ) ).

% mult_le_cancel_right1
tff(fact_721_mult__le__cancel__right2,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),C2)
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B)) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),A3) ) ) ) ) ).

% mult_le_cancel_right2
tff(fact_722_mult__less__cancel__left1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),B2) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),one_one(B)) ) ) ) ) ).

% mult_less_cancel_left1
tff(fact_723_mult__less__cancel__left2,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3)),C2)
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B)) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3) ) ) ) ) ).

% mult_less_cancel_left2
tff(fact_724_mult__less__cancel__right1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),B2) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),one_one(B)) ) ) ) ) ).

% mult_less_cancel_right1
tff(fact_725_mult__less__cancel__right2,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [A3: B,C2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),C2)
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),C2)
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B)) )
            & ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),zero_zero(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3) ) ) ) ) ).

% mult_less_cancel_right2
tff(fact_726_convex__bound__le,axiom,
    ! [B: $tType] :
      ( linord6961819062388156250ring_1(B)
     => ! [X2: B,A3: B,Y: B,U: B,V: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y),A3)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),U)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),V)
               => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),U),V) = one_one(B) )
                 => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),U),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),V),Y))),A3) ) ) ) ) ) ) ).

% convex_bound_le
tff(fact_727_is__num_Ocases,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [A3: B] :
          ( neg_numeral_is_num(B,A3)
         => ( ( A3 != one_one(B) )
           => ( ! [X3: B] :
                  ( ( A3 = aa(B,B,uminus_uminus(B),X3) )
                 => ~ neg_numeral_is_num(B,X3) )
             => ~ ! [X3: B,Y4: B] :
                    ( ( A3 = aa(B,B,aa(B,fun(B,B),plus_plus(B),X3),Y4) )
                   => ( neg_numeral_is_num(B,X3)
                     => ~ neg_numeral_is_num(B,Y4) ) ) ) ) ) ) ).

% is_num.cases
tff(fact_728_is__num_Osimps,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [A3: B] :
          ( neg_numeral_is_num(B,A3)
        <=> ( ( A3 = one_one(B) )
            | ? [X4: B] :
                ( ( A3 = aa(B,B,uminus_uminus(B),X4) )
                & neg_numeral_is_num(B,X4) )
            | ? [X4: B,Y3: B] :
                ( ( A3 = aa(B,B,aa(B,fun(B,B),plus_plus(B),X4),Y3) )
                & neg_numeral_is_num(B,X4)
                & neg_numeral_is_num(B,Y3) ) ) ) ) ).

% is_num.simps
tff(fact_729_sum__squares__gt__zero__iff,axiom,
    ! [B: $tType] :
      ( linord4710134922213307826strict(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Y)))
        <=> ( ( X2 != zero_zero(B) )
            | ( Y != zero_zero(B) ) ) ) ) ).

% sum_squares_gt_zero_iff
tff(fact_730_sum__squares__le__zero__iff,axiom,
    ! [B: $tType] :
      ( linord4710134922213307826strict(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Y))),zero_zero(B))
        <=> ( ( X2 = zero_zero(B) )
            & ( Y = zero_zero(B) ) ) ) ) ).

% sum_squares_le_zero_iff
tff(fact_731_incr__lemma,axiom,
    ! [D3: int,Z2: int,X2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D3)
     => aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z2),aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,abs_abs(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X2),Z2))),one_one(int))),D3))) ) ).

% incr_lemma
tff(fact_732_decr__lemma,axiom,
    ! [D3: int,X2: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D3)
     => aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X2),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,abs_abs(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X2),Z2))),one_one(int))),D3))),Z2) ) ).

% decr_lemma
tff(fact_733_sum__squares__eq__zero__iff,axiom,
    ! [B: $tType] :
      ( linord4710134922213307826strict(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Y)) = zero_zero(B) )
        <=> ( ( X2 = zero_zero(B) )
            & ( Y = zero_zero(B) ) ) ) ) ).

% sum_squares_eq_zero_iff
tff(fact_734_frac__unique__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,A3: B] :
          ( ( archimedean_frac(B,X2) = A3 )
        <=> ( member(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),A3),ring_1_Ints(B))
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B)) ) ) ) ).

% frac_unique_iff
tff(fact_735_scaling__mono,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [U: B,V: B,R: B,S: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),U),V)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),R)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),R),S)
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),U),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),R),aa(B,B,aa(B,fun(B,B),minus_minus(B),V),U))),S))),V) ) ) ) ) ).

% scaling_mono
tff(fact_736_divide__le__eq__1__neg,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),one_one(B))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ) ).

% divide_le_eq_1_neg
tff(fact_737_divide__le__eq__1__pos,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),one_one(B))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ) ).

% divide_le_eq_1_pos
tff(fact_738_div__by__1,axiom,
    ! [B: $tType] :
      ( semidom_divide(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),one_one(B)) = A3 ) ).

% div_by_1
tff(fact_739_div__self,axiom,
    ! [B: $tType] :
      ( semidom_divide(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),A3) = one_one(B) ) ) ) ).

% div_self
tff(fact_740_zero__eq__1__divide__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( ( zero_zero(B) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% zero_eq_1_divide_iff
tff(fact_741_one__divide__eq__0__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3) = zero_zero(B) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% one_divide_eq_0_iff
tff(fact_742_eq__divide__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [B2: B,A3: B] :
          ( ( one_one(B) = aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3) )
        <=> ( ( A3 != zero_zero(B) )
            & ( A3 = B2 ) ) ) ) ).

% eq_divide_eq_1
tff(fact_743_divide__eq__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [B2: B,A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3) = one_one(B) )
        <=> ( ( A3 != zero_zero(B) )
            & ( A3 = B2 ) ) ) ) ).

% divide_eq_eq_1
tff(fact_744_divide__self__if,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B] :
          aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),A3) = $ite(A3 = zero_zero(B),zero_zero(B),one_one(B)) ) ).

% divide_self_if
tff(fact_745_divide__self,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),A3) = one_one(B) ) ) ) ).

% divide_self
tff(fact_746_one__eq__divide__iff,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [A3: B,B2: B] :
          ( ( one_one(B) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) )
        <=> ( ( B2 != zero_zero(B) )
            & ( A3 = B2 ) ) ) ) ).

% one_eq_divide_iff
tff(fact_747_divide__eq__1__iff,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = one_one(B) )
        <=> ( ( B2 != zero_zero(B) )
            & ( A3 = B2 ) ) ) ) ).

% divide_eq_1_iff
tff(fact_748_divide__minus1,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),X2) ) ).

% divide_minus1
tff(fact_749_zero__le__divide__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3) ) ) ).

% zero_le_divide_1_iff
tff(fact_750_divide__le__0__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3)),zero_zero(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),zero_zero(B)) ) ) ).

% divide_le_0_1_iff
tff(fact_751_zero__less__divide__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3) ) ) ).

% zero_less_divide_1_iff
tff(fact_752_less__divide__eq__1__pos,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ) ).

% less_divide_eq_1_pos
tff(fact_753_less__divide__eq__1__neg,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ) ).

% less_divide_eq_1_neg
tff(fact_754_divide__less__eq__1__pos,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),one_one(B))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ) ).

% divide_less_eq_1_pos
tff(fact_755_divide__less__eq__1__neg,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),one_one(B))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ) ).

% divide_less_eq_1_neg
tff(fact_756_divide__less__0__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3)),zero_zero(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B)) ) ) ).

% divide_less_0_1_iff
tff(fact_757_nonzero__divide__mult__cancel__right,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [B2: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3) ) ) ) ).

% nonzero_divide_mult_cancel_right
tff(fact_758_nonzero__divide__mult__cancel__left,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [A3: B,B2: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),B2) ) ) ) ).

% nonzero_divide_mult_cancel_left
tff(fact_759_le__divide__eq__1__pos,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ) ).

% le_divide_eq_1_pos
tff(fact_760_le__divide__eq__1__neg,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ) ).

% le_divide_eq_1_neg
tff(fact_761_int__distrib_I2_J,axiom,
    ! [W: int,Z1: int,Z22: int] : aa(int,int,aa(int,fun(int,int),times_times(int),W),aa(int,int,aa(int,fun(int,int),plus_plus(int),Z1),Z22)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),W),Z1)),aa(int,int,aa(int,fun(int,int),times_times(int),W),Z22)) ).

% int_distrib(2)
tff(fact_762_int__distrib_I1_J,axiom,
    ! [Z1: int,Z22: int,W: int] : aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),Z1),Z22)),W) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),Z1),W)),aa(int,int,aa(int,fun(int,int),times_times(int),Z22),W)) ).

% int_distrib(1)
tff(fact_763_plus__int__code_I2_J,axiom,
    ! [L: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),zero_zero(int)),L) = L ).

% plus_int_code(2)
tff(fact_764_plus__int__code_I1_J,axiom,
    ! [K: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),K),zero_zero(int)) = K ).

% plus_int_code(1)
tff(fact_765_zero__integer_Orsp,axiom,
    zero_zero(int) = zero_zero(int) ).

% zero_integer.rsp
tff(fact_766_add__divide__distrib,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),C2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2)) ) ).

% add_divide_distrib
tff(fact_767_int__div__pos__eq,axiom,
    ! [A3: int,B2: int,Q3: int,R: int] :
      ( ( A3 = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),R)
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R),B2)
         => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),A3),B2) = Q3 ) ) ) ) ).

% int_div_pos_eq
tff(fact_768_int__div__neg__eq,axiom,
    ! [A3: int,B2: int,Q3: int,R: int] :
      ( ( A3 = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),R),zero_zero(int))
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),B2),R)
         => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),A3),B2) = Q3 ) ) ) ) ).

% int_div_neg_eq
tff(fact_769_split__zdiv,axiom,
    ! [P: fun(int,$o),N: int,K: int] :
      ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),divide_divide(int),N),K))
    <=> ( ( ( K = zero_zero(int) )
         => aa(int,$o,P,zero_zero(int)) )
        & ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),K)
         => ! [I3: int,J2: int] :
              ( ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),J2)
                & aa(int,$o,aa(int,fun(int,$o),ord_less(int),J2),K)
                & ( N = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),K),I3)),J2) ) )
             => aa(int,$o,P,I3) ) )
        & ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),zero_zero(int))
         => ! [I3: int,J2: int] :
              ( ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),J2)
                & aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),J2),zero_zero(int))
                & ( N = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),K),I3)),J2) ) )
             => aa(int,$o,P,I3) ) ) ) ) ).

% split_zdiv
tff(fact_770_frac__lt__1,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less(B),archimedean_frac(B,X2)),one_one(B)) ) ).

% frac_lt_1
tff(fact_771_frac__1__eq,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : archimedean_frac(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),one_one(B))) = archimedean_frac(B,X2) ) ).

% frac_1_eq
tff(fact_772_right__inverse__eq,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [B2: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = one_one(B) )
          <=> ( A3 = B2 ) ) ) ) ).

% right_inverse_eq
tff(fact_773_less__divide__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) )
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ) ) ).

% less_divide_eq_1
tff(fact_774_divide__less__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),one_one(B))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) )
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) )
            | ( A3 = zero_zero(B) ) ) ) ) ).

% divide_less_eq_1
tff(fact_775_divide__add__eq__iff,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [Z2: B,X2: B,Y: B] :
          ( ( Z2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Z2)),Y) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Z2))),Z2) ) ) ) ).

% divide_add_eq_iff
tff(fact_776_add__divide__eq__iff,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [Z2: B,X2: B,Y: B] :
          ( ( Z2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),Y),Z2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),Z2)),Y)),Z2) ) ) ) ).

% add_divide_eq_iff
tff(fact_777_add__num__frac,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [Y: B,Z2: B,X2: B] :
          ( ( Y != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Y)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),times_times(B),Z2),Y))),Y) ) ) ) ).

% add_num_frac
tff(fact_778_add__frac__num,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [Y: B,X2: B,Z2: B] :
          ( ( Y != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Y)),Z2) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),times_times(B),Z2),Y))),Y) ) ) ) ).

% add_frac_num
tff(fact_779_add__frac__eq,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [Y: B,Z2: B,X2: B,W: B] :
          ( ( Y != zero_zero(B) )
         => ( ( Z2 != zero_zero(B) )
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Y)),aa(B,B,aa(B,fun(B,B),divide_divide(B),W),Z2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),X2),Z2)),aa(B,B,aa(B,fun(B,B),times_times(B),W),Y))),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Z2)) ) ) ) ) ).

% add_frac_eq
tff(fact_780_add__divide__eq__if__simps_I1_J,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,B2: B,Z2: B] :
          aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),Z2)) = $ite(Z2 = zero_zero(B),A3,aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),Z2)),B2)),Z2)) ) ).

% add_divide_eq_if_simps(1)
tff(fact_781_add__divide__eq__if__simps_I2_J,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,Z2: B,B2: B] :
          aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),Z2)),B2) = $ite(Z2 = zero_zero(B),B2,aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),Z2))),Z2)) ) ).

% add_divide_eq_if_simps(2)
tff(fact_782_less__half__sum,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),one_one(B)))) ) ) ).

% less_half_sum
tff(fact_783_gt__half__sum,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),one_one(B)))),B2) ) ) ).

% gt_half_sum
tff(fact_784_divide__eq__minus__1__iff,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = aa(B,B,uminus_uminus(B),one_one(B)) )
        <=> ( ( B2 != zero_zero(B) )
            & ( A3 = aa(B,B,uminus_uminus(B),B2) ) ) ) ) ).

% divide_eq_minus_1_iff
tff(fact_785_div__pos__geq,axiom,
    ! [L: int,K: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),L)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),L),K)
       => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),K),L) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),K),L)),L)),one_one(int)) ) ) ) ).

% div_pos_geq
tff(fact_786_frac__eq,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( ( archimedean_frac(B,X2) = X2 )
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),one_one(B)) ) ) ) ).

% frac_eq
tff(fact_787_frac__add,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Y: B] :
          archimedean_frac(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)) = $ite(aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),archimedean_frac(B,X2)),archimedean_frac(B,Y))),one_one(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),archimedean_frac(B,X2)),archimedean_frac(B,Y)),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),archimedean_frac(B,X2)),archimedean_frac(B,Y))),one_one(B))) ) ).

% frac_add
tff(fact_788_incr__mult__lemma,axiom,
    ! [D3: int,P: fun(int,$o),K: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D3)
     => ( ! [X3: int] :
            ( aa(int,$o,P,X3)
           => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),D3)) )
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),K)
         => ! [X: int] :
              ( aa(int,$o,P,X)
             => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),aa(int,int,aa(int,fun(int,int),times_times(int),K),D3))) ) ) ) ) ).

% incr_mult_lemma
tff(fact_789_divide__le__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),one_one(B))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) )
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) )
            | ( A3 = zero_zero(B) ) ) ) ) ).

% divide_le_eq_1
tff(fact_790_le__divide__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3))
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) )
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),zero_zero(B))
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ) ) ).

% le_divide_eq_1
tff(fact_791_minus__divide__add__eq__iff,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [Z2: B,X2: B,Y: B] :
          ( ( Z2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Z2))),Y) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),X2)),aa(B,B,aa(B,fun(B,B),times_times(B),Y),Z2))),Z2) ) ) ) ).

% minus_divide_add_eq_iff
tff(fact_792_add__divide__eq__if__simps_I3_J,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,Z2: B,B2: B] :
          aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),Z2))),B2) = $ite(Z2 = zero_zero(B),B2,aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),A3)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),Z2))),Z2)) ) ).

% add_divide_eq_if_simps(3)
tff(fact_793_frac__neg,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          archimedean_frac(B,aa(B,B,uminus_uminus(B),X2)) = $ite(member(B,X2,ring_1_Ints(B)),zero_zero(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),archimedean_frac(B,X2))) ) ).

% frac_neg
tff(fact_794_div__mult__self4,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,C2: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)),A3)),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)) ) ) ) ).

% div_mult_self4
tff(fact_795_div__mult__self3,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,C2: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2)),A3)),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)) ) ) ) ).

% div_mult_self3
tff(fact_796_div__mult__self2,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,A3: B,C2: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2))),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)) ) ) ) ).

% div_mult_self2
tff(fact_797_div__mult__self1,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,A3: B,C2: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2))),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)) ) ) ) ).

% div_mult_self1
tff(fact_798_div__minus1__right,axiom,
    ! [B: $tType] :
      ( euclid8851590272496341667cancel(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),A3) ) ).

% div_minus1_right
tff(fact_799_div__pos__neg__trivial,axiom,
    ! [K: int,L: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),K)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)),zero_zero(int))
       => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),K),L) = aa(int,int,uminus_uminus(int),one_one(int)) ) ) ) ).

% div_pos_neg_trivial
tff(fact_800_bits__div__by__1,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),one_one(B)) = A3 ) ).

% bits_div_by_1
tff(fact_801_dividend__less__times__div,axiom,
    ! [N: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)))) ) ).

% dividend_less_times_div
tff(fact_802_dividend__less__div__times,axiom,
    ! [N: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)),N))) ) ).

% dividend_less_div_times
tff(fact_803_split__div,axiom,
    ! [P: fun(nat,$o),M: nat,N: nat] :
      ( aa(nat,$o,P,aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N))
    <=> ( ( ( N = zero_zero(nat) )
         => aa(nat,$o,P,zero_zero(nat)) )
        & ( ( N != zero_zero(nat) )
         => ! [I3: nat,J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),N)
             => ( ( M = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),I3)),J2) )
               => aa(nat,$o,P,I3) ) ) ) ) ) ).

% split_div
tff(fact_804_div__less__dividend,axiom,
    ! [N: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)),M) ) ) ).

% div_less_dividend
tff(fact_805_div__eq__dividend__iff,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M)
     => ( ( aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N) = M )
      <=> ( N = one_one(nat) ) ) ) ).

% div_eq_dividend_iff
tff(fact_806_div__add__self1,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3)),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),one_one(B)) ) ) ) ).

% div_add_self1
tff(fact_807_div__add__self2,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),B2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),one_one(B)) ) ) ) ).

% div_add_self2
tff(fact_808_upto_Opinduct,axiom,
    ! [A0: int,A1: int,P: fun(int,fun(int,$o))] :
      ( aa(product_prod(int,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))
     => ( ! [I2: int,J3: int] :
            ( aa(product_prod(int,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),I2),J3))
           => ( ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),I2),J3)
               => aa(int,$o,aa(int,fun(int,$o),P,aa(int,int,aa(int,fun(int,int),plus_plus(int),I2),one_one(int))),J3) )
             => aa(int,$o,aa(int,fun(int,$o),P,I2),J3) ) )
       => aa(int,$o,aa(int,fun(int,$o),P,A0),A1) ) ) ).

% upto.pinduct
tff(fact_809_eucl__rel__int_Osimps,axiom,
    ! [A1: int,A22: int,A32: product_prod(int,int)] :
      ( eucl_rel_int(A1,A22,A32)
    <=> ( ? [K4: int] :
            ( ( A1 = K4 )
            & ( A22 = zero_zero(int) )
            & ( A32 = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),K4) ) )
        | ? [L3: int,K4: int,Q5: int] :
            ( ( A1 = K4 )
            & ( A22 = L3 )
            & ( A32 = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q5),zero_zero(int)) )
            & ( L3 != zero_zero(int) )
            & ( K4 = aa(int,int,aa(int,fun(int,int),times_times(int),Q5),L3) ) )
        | ? [R5: int,L3: int,K4: int,Q5: int] :
            ( ( A1 = K4 )
            & ( A22 = L3 )
            & ( A32 = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q5),R5) )
            & ( aa(int,int,sgn_sgn(int),R5) = aa(int,int,sgn_sgn(int),L3) )
            & aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,abs_abs(int),R5)),aa(int,int,abs_abs(int),L3))
            & ( K4 = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),Q5),L3)),R5) ) ) ) ) ).

% eucl_rel_int.simps
tff(fact_810_eucl__rel__int_Ocases,axiom,
    ! [A1: int,A22: int,A32: product_prod(int,int)] :
      ( eucl_rel_int(A1,A22,A32)
     => ( ( ( A22 = zero_zero(int) )
         => ( A32 != aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),A1) ) )
       => ( ! [Q2: int] :
              ( ( A32 = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q2),zero_zero(int)) )
             => ( ( A22 != zero_zero(int) )
               => ( A1 != aa(int,int,aa(int,fun(int,int),times_times(int),Q2),A22) ) ) )
         => ~ ! [R2: int,Q2: int] :
                ( ( A32 = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q2),R2) )
               => ( ( aa(int,int,sgn_sgn(int),R2) = aa(int,int,sgn_sgn(int),A22) )
                 => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,abs_abs(int),R2)),aa(int,int,abs_abs(int),A22))
                   => ( A1 != aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),Q2),A22)),R2) ) ) ) ) ) ) ) ).

% eucl_rel_int.cases
tff(fact_811_eucl__rel__int__iff,axiom,
    ! [K: int,L: int,Q3: int,R: int] :
      ( eucl_rel_int(K,L,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
    <=> ( ( K = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),L),Q3)),R) )
        & $ite(
            aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),L),
            ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),R)
            & aa(int,$o,aa(int,fun(int,$o),ord_less(int),R),L) ),
            $ite(
              aa(int,$o,aa(int,fun(int,$o),ord_less(int),L),zero_zero(int)),
              ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),L),R)
              & aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),R),zero_zero(int)) ),
              Q3 = zero_zero(int) ) ) ) ) ).

% eucl_rel_int_iff
tff(fact_812_power_Opower__eq__if,axiom,
    ! [B: $tType,One: B,Times: fun(B,fun(B,B)),P3: B,M: nat] :
      power2(B,One,Times,P3,M) = $ite(M = zero_zero(nat),One,aa(B,B,aa(B,fun(B,B),Times,P3),power2(B,One,Times,P3,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))))) ).

% power.power_eq_if
tff(fact_813_split__neg__lemma,axiom,
    ! [K: int,P: fun(int,fun(int,$o)),N: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),zero_zero(int))
     => ( aa(int,$o,aa(int,fun(int,$o),P,aa(int,int,aa(int,fun(int,int),divide_divide(int),N),K)),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),N),K))
      <=> ! [I3: int,J2: int] :
            ( ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),J2)
              & aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),J2),zero_zero(int))
              & ( N = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),K),I3)),J2) ) )
           => aa(int,$o,aa(int,fun(int,$o),P,I3),J2) ) ) ) ).

% split_neg_lemma
tff(fact_814_split__pos__lemma,axiom,
    ! [K: int,P: fun(int,fun(int,$o)),N: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),K)
     => ( aa(int,$o,aa(int,fun(int,$o),P,aa(int,int,aa(int,fun(int,int),divide_divide(int),N),K)),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),N),K))
      <=> ! [I3: int,J2: int] :
            ( ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),J2)
              & aa(int,$o,aa(int,fun(int,$o),ord_less(int),J2),K)
              & ( N = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),K),I3)),J2) ) )
           => aa(int,$o,aa(int,fun(int,$o),P,I3),J2) ) ) ) ).

% split_pos_lemma
tff(fact_815_mod__add__self2,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),B2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) ) ).

% mod_add_self2
tff(fact_816_mod__add__self1,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,A3: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3)),B2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) ) ).

% mod_add_self1
tff(fact_817_mod__by__1,axiom,
    ! [B: $tType] :
      ( semidom_modulo(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),one_one(B)) = zero_zero(B) ) ).

% mod_by_1
tff(fact_818_bits__mod__by__1,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),one_one(B)) = zero_zero(B) ) ).

% bits_mod_by_1
tff(fact_819_mod__mult__self1,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,C2: B,B2: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2))),B2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) ) ).

% mod_mult_self1
tff(fact_820_mod__mult__self2,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2))),B2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) ) ).

% mod_mult_self2
tff(fact_821_mod__mult__self3,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [C2: B,B2: B,A3: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2)),A3)),B2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) ) ).

% mod_mult_self3
tff(fact_822_mod__mult__self4,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [B2: B,C2: B,A3: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)),A3)),B2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) ) ).

% mod_mult_self4
tff(fact_823_mod__minus1__right,axiom,
    ! [B: $tType] :
      ( euclid8851590272496341667cancel(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(B,B,uminus_uminus(B),one_one(B))) = zero_zero(B) ) ).

% mod_minus1_right
tff(fact_824_mod__int__unique,axiom,
    ! [K: int,L: int,Q3: int,R: int] :
      ( eucl_rel_int(K,L,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
     => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),L) = R ) ) ).

% mod_int_unique
tff(fact_825_unique__quotient,axiom,
    ! [A3: int,B2: int,Q3: int,R: int,Q4: int,R3: int] :
      ( eucl_rel_int(A3,B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
     => ( eucl_rel_int(A3,B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q4),R3))
       => ( Q3 = Q4 ) ) ) ).

% unique_quotient
tff(fact_826_unique__remainder,axiom,
    ! [A3: int,B2: int,Q3: int,R: int,Q4: int,R3: int] :
      ( eucl_rel_int(A3,B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
     => ( eucl_rel_int(A3,B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q4),R3))
       => ( R = R3 ) ) ) ).

% unique_remainder
tff(fact_827_full__exhaustive__int_H_Ocases,axiom,
    ! [X2: product_prod(fun(product_prod(int,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(int,int))] :
      ~ ! [F3: fun(product_prod(int,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),D2: int,I2: int] : X2 != aa(product_prod(int,int),product_prod(fun(product_prod(int,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(int,int)),aa(fun(product_prod(int,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),fun(product_prod(int,int),product_prod(fun(product_prod(int,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(int,int))),product_Pair(fun(product_prod(int,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(int,int)),F3),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),D2),I2)) ).

% full_exhaustive_int'.cases
tff(fact_828_exhaustive__int_H_Ocases,axiom,
    ! [X2: product_prod(fun(int,option(product_prod($o,list(code_term)))),product_prod(int,int))] :
      ~ ! [F3: fun(int,option(product_prod($o,list(code_term)))),D2: int,I2: int] : X2 != aa(product_prod(int,int),product_prod(fun(int,option(product_prod($o,list(code_term)))),product_prod(int,int)),aa(fun(int,option(product_prod($o,list(code_term)))),fun(product_prod(int,int),product_prod(fun(int,option(product_prod($o,list(code_term)))),product_prod(int,int))),product_Pair(fun(int,option(product_prod($o,list(code_term)))),product_prod(int,int)),F3),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),D2),I2)) ).

% exhaustive_int'.cases
tff(fact_829_small__lazy_H_Ocases,axiom,
    ! [X2: product_prod(int,int)] :
      ~ ! [D2: int,I2: int] : X2 != aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),D2),I2) ).

% small_lazy'.cases
tff(fact_830_eucl__rel__int,axiom,
    ! [K: int,L: int] : eucl_rel_int(K,L,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),L)),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),L))) ).

% eucl_rel_int
tff(fact_831_mod__add__right__eq,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B2),C2))),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) ) ).

% mod_add_right_eq
tff(fact_832_mod__add__left__eq,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,C2: B,B2: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),C2)),B2)),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) ) ).

% mod_add_left_eq
tff(fact_833_mod__add__cong,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,C2: B,A6: B,B2: B,B4: B] :
          ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A6),C2) )
         => ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B2),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B4),C2) )
           => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A6),B4)),C2) ) ) ) ) ).

% mod_add_cong
tff(fact_834_mod__add__eq,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,C2: B,B2: B] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),C2)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B2),C2))),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) ) ).

% mod_add_eq
tff(fact_835_eucl__rel__int__by0,axiom,
    ! [K: int] : eucl_rel_int(K,zero_zero(int),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),K)) ).

% eucl_rel_int_by0
tff(fact_836_div__int__unique,axiom,
    ! [K: int,L: int,Q3: int,R: int] :
      ( eucl_rel_int(K,L,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
     => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),K),L) = Q3 ) ) ).

% div_int_unique
tff(fact_837_mod__eqE,axiom,
    ! [B: $tType] :
      ( euclid8851590272496341667cancel(B)
     => ! [A3: B,C2: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),C2) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B2),C2) )
         => ~ ! [D2: B] : B2 != aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),C2),D2)) ) ) ).

% mod_eqE
tff(fact_838_div__add1__eq,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),C2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),C2)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B2),C2))),C2)) ) ).

% div_add1_eq
tff(fact_839_mult__div__mod__eq,axiom,
    ! [B: $tType] :
      ( semiring_modulo(B)
     => ! [B2: B,A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2)) = A3 ) ).

% mult_div_mod_eq
tff(fact_840_mod__mult__div__eq,axiom,
    ! [B: $tType] :
      ( semiring_modulo(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2)),aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2))) = A3 ) ).

% mod_mult_div_eq
tff(fact_841_mod__div__mult__eq,axiom,
    ! [B: $tType] :
      ( semiring_modulo(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),B2)) = A3 ) ).

% mod_div_mult_eq
tff(fact_842_div__mult__mod__eq,axiom,
    ! [B: $tType] :
      ( semiring_modulo(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),B2)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2)) = A3 ) ).

% div_mult_mod_eq
tff(fact_843_mod__div__decomp,axiom,
    ! [B: $tType] :
      ( semiring_modulo(B)
     => ! [A3: B,B2: B] : A3 = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),B2)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2)) ) ).

% mod_div_decomp
tff(fact_844_cancel__div__mod__rules_I1_J,axiom,
    ! [B: $tType] :
      ( semidom_modulo(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),B2)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2))),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2) ) ).

% cancel_div_mod_rules(1)
tff(fact_845_cancel__div__mod__rules_I2_J,axiom,
    ! [B: $tType] :
      ( semidom_modulo(B)
     => ! [B2: B,A3: B,C2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2))),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),C2) ) ).

% cancel_div_mod_rules(2)
tff(fact_846_div__mult1__eq,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [A3: B,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),B2),C2))),C2)) ) ).

% div_mult1_eq
tff(fact_847_eucl__rel__int__dividesI,axiom,
    ! [L: int,K: int,Q3: int] :
      ( ( L != zero_zero(int) )
     => ( ( K = aa(int,int,aa(int,fun(int,int),times_times(int),Q3),L) )
       => eucl_rel_int(K,L,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),zero_zero(int))) ) ) ).

% eucl_rel_int_dividesI
tff(fact_848_div__mod__decomp__int,axiom,
    ! [A4: int,N: int] : A4 = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),A4),N)),N)),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),A4),N)) ).

% div_mod_decomp_int
tff(fact_849_mod__pos__neg__trivial,axiom,
    ! [K: int,L: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),K)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)),zero_zero(int))
       => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),L) = aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L) ) ) ) ).

% mod_pos_neg_trivial
tff(fact_850_unique__euclidean__semiring__numeral__class_Omod__mult2__eq,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [C2: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),C2)
         => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),C2))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2)) ) ) ) ).

% unique_euclidean_semiring_numeral_class.mod_mult2_eq
tff(fact_851_int__mod__pos__eq,axiom,
    ! [A3: int,B2: int,Q3: int,R: int] :
      ( ( A3 = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),R)
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),R),B2)
         => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),A3),B2) = R ) ) ) ) ).

% int_mod_pos_eq
tff(fact_852_int__mod__neg__eq,axiom,
    ! [A3: int,B2: int,Q3: int,R: int] :
      ( ( A3 = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),Q3)),R) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),R),zero_zero(int))
       => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),B2),R)
         => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),A3),B2) = R ) ) ) ) ).

% int_mod_neg_eq
tff(fact_853_split__zmod,axiom,
    ! [P: fun(int,$o),N: int,K: int] :
      ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),modulo_modulo(int),N),K))
    <=> ( ( ( K = zero_zero(int) )
         => aa(int,$o,P,N) )
        & ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),K)
         => ! [I3: int,J2: int] :
              ( ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),J2)
                & aa(int,$o,aa(int,fun(int,$o),ord_less(int),J2),K)
                & ( N = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),K),I3)),J2) ) )
             => aa(int,$o,P,J2) ) )
        & ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),zero_zero(int))
         => ! [I3: int,J2: int] :
              ( ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),J2)
                & aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),J2),zero_zero(int))
                & ( N = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),K),I3)),J2) ) )
             => aa(int,$o,P,J2) ) ) ) ) ).

% split_zmod
tff(fact_854_zmod__zmult2__eq,axiom,
    ! [C2: int,A3: int,B2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),C2)
     => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),A3),aa(int,int,aa(int,fun(int,int),times_times(int),B2),C2)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),B2),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),A3),B2)),C2))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),A3),B2)) ) ) ).

% zmod_zmult2_eq
tff(fact_855_zminus1__lemma,axiom,
    ! [A3: int,B2: int,Q3: int,R: int] :
      ( eucl_rel_int(A3,B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
     => ( ( B2 != zero_zero(int) )
       => eucl_rel_int(aa(int,int,uminus_uminus(int),A3),B2,
            aa(int,product_prod(int,int),
              aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),
                $ite(R = zero_zero(int),aa(int,int,uminus_uminus(int),Q3),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,uminus_uminus(int),Q3)),one_one(int)))),
              $ite(R = zero_zero(int),zero_zero(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),B2),R)))) ) ) ).

% zminus1_lemma
tff(fact_856_eucl__rel__int__remainderI,axiom,
    ! [R: int,L: int,K: int,Q3: int] :
      ( ( aa(int,int,sgn_sgn(int),R) = aa(int,int,sgn_sgn(int),L) )
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,abs_abs(int),R)),aa(int,int,abs_abs(int),L))
       => ( ( K = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),Q3),L)),R) )
         => eucl_rel_int(K,L,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R)) ) ) ) ).

% eucl_rel_int_remainderI
tff(fact_857_verit__le__mono__div__int,axiom,
    ! [A4: int,B5: int,N: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),A4),B5)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),N)
       => aa(int,$o,
            aa(int,fun(int,$o),ord_less_eq(int),
              aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),A4),N)),
                $ite(aa(int,int,aa(int,fun(int,int),modulo_modulo(int),B5),N) = zero_zero(int),one_one(int),zero_zero(int)))),
            aa(int,int,aa(int,fun(int,int),divide_divide(int),B5),N)) ) ) ).

% verit_le_mono_div_int
tff(fact_858_bezw__0,axiom,
    ! [X2: nat] : bezw(X2,zero_zero(nat)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),zero_zero(int)) ).

% bezw_0
tff(fact_859_verit__le__mono__div,axiom,
    ! [A4: nat,B5: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A4),B5)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
       => 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),divide_divide(nat),A4),N)),
                $ite(aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),B5),N) = zero_zero(nat),one_one(nat),zero_zero(nat)))),
            aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),B5),N)) ) ) ).

% verit_le_mono_div
tff(fact_860_zero__le__ceiling,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),archimedean_ceiling(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),one_one(B))),X2) ) ) ).

% zero_le_ceiling
tff(fact_861_ceiling__less__zero,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(B,X2)),zero_zero(int))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(B,B,uminus_uminus(B),one_one(B))) ) ) ).

% ceiling_less_zero
tff(fact_862_floor__add,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Y: B] :
          archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)) = $ite(aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),archimedean_frac(B,X2)),archimedean_frac(B,Y))),one_one(B)),aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),archim6421214686448440834_floor(B,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(B,X2)),archim6421214686448440834_floor(B,Y))),one_one(int))) ) ).

% floor_add
tff(fact_863_cpmi,axiom,
    ! [D4: int,P: fun(int,$o),P2: fun(int,$o),B5: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( ? [Z5: int] :
          ! [X3: int] :
            ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),X3),Z5)
           => ( aa(int,$o,P,X3)
            <=> aa(int,$o,P2,X3) ) )
       => ( ! [X3: int] :
              ( ! [Xa3: int] :
                  ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
                 => ! [Xb2: int] :
                      ( member(int,Xb2,B5)
                     => ( X3 != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb2),Xa3) ) ) )
             => ( aa(int,$o,P,X3)
               => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),D4)) ) )
         => ( ! [X3: int,K3: int] :
                ( aa(int,$o,P2,X3)
              <=> aa(int,$o,P2,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),aa(int,int,aa(int,fun(int,int),times_times(int),K3),D4))) )
           => ( ? [X_1: int] : aa(int,$o,P,X_1)
            <=> ( ? [X4: int] :
                    ( member(int,X4,set_or1337092689740270186AtMost(int,one_one(int),D4))
                    & aa(int,$o,P2,X4) )
                | ? [X4: int] :
                    ( member(int,X4,set_or1337092689740270186AtMost(int,one_one(int),D4))
                    & ? [Xa2: int] :
                        ( member(int,Xa2,B5)
                        & aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),Xa2),X4)) ) ) ) ) ) ) ) ) ).

% cpmi
tff(fact_864_cppi,axiom,
    ! [D4: int,P: fun(int,$o),P2: fun(int,$o),A4: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( ? [Z5: int] :
          ! [X3: int] :
            ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z5),X3)
           => ( aa(int,$o,P,X3)
            <=> aa(int,$o,P2,X3) ) )
       => ( ! [X3: int] :
              ( ! [Xa3: int] :
                  ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
                 => ! [Xb2: int] :
                      ( member(int,Xb2,A4)
                     => ( X3 != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb2),Xa3) ) ) )
             => ( aa(int,$o,P,X3)
               => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),D4)) ) )
         => ( ! [X3: int,K3: int] :
                ( aa(int,$o,P2,X3)
              <=> aa(int,$o,P2,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),aa(int,int,aa(int,fun(int,int),times_times(int),K3),D4))) )
           => ( ? [X_1: int] : aa(int,$o,P,X_1)
            <=> ( ? [X4: int] :
                    ( member(int,X4,set_or1337092689740270186AtMost(int,one_one(int),D4))
                    & aa(int,$o,P2,X4) )
                | ? [X4: int] :
                    ( member(int,X4,set_or1337092689740270186AtMost(int,one_one(int),D4))
                    & ? [Xa2: int] :
                        ( member(int,Xa2,A4)
                        & aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),Xa2),X4)) ) ) ) ) ) ) ) ) ).

% cppi
tff(fact_865_bset_I6_J,axiom,
    ! [D4: int,B5: set(int),T2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,B5)
                 => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X),T2)
           => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)),T2) ) ) ) ).

% bset(6)
tff(fact_866_bset_I8_J,axiom,
    ! [D4: int,T2: int,B5: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,aa(int,int,aa(int,fun(int,int),minus_minus(int),T2),one_one(int)),B5)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,B5)
                   => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),T2),X)
             => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),T2),aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)) ) ) ) ) ).

% bset(8)
tff(fact_867_aset_I6_J,axiom,
    ! [D4: int,T2: int,A4: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,aa(int,int,aa(int,fun(int,int),plus_plus(int),T2),one_one(int)),A4)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,A4)
                   => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X),T2)
             => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)),T2) ) ) ) ) ).

% aset(6)
tff(fact_868_atLeastAtMost__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,L: B,U: B] :
          ( member(B,I,set_or1337092689740270186AtMost(B,L,U))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),I)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),U) ) ) ) ).

% atLeastAtMost_iff
tff(fact_869_Icc__eq__Icc,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,Ha: B,L4: B,H2: B] :
          ( ( set_or1337092689740270186AtMost(B,L,Ha) = set_or1337092689740270186AtMost(B,L4,H2) )
        <=> ( ( ( L = L4 )
              & ( Ha = H2 ) )
            | ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),Ha)
              & ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L4),H2) ) ) ) ) ).

% Icc_eq_Icc
tff(fact_870_atLeastatMost__subset__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or1337092689740270186AtMost(B,A3,B2)),set_or1337092689740270186AtMost(B,C2,D3))
        <=> ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% atLeastatMost_subset_iff
tff(fact_871_floor__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ( archim6421214686448440834_floor(B,one_one(B)) = one_one(int) ) ) ).

% floor_one
tff(fact_872_ceiling__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ( archimedean_ceiling(B,one_one(B)) = one_one(int) ) ) ).

% ceiling_one
tff(fact_873_floor__add2,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Y: B] :
          ( ( member(B,X2,ring_1_Ints(B))
            | member(B,Y,ring_1_Ints(B)) )
         => ( archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),archim6421214686448440834_floor(B,Y)) ) ) ) ).

% floor_add2
tff(fact_874_zero__less__floor,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),archim6421214686448440834_floor(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),X2) ) ) ).

% zero_less_floor
tff(fact_875_floor__le__zero,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(B,X2)),zero_zero(int))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),one_one(B)) ) ) ).

% floor_le_zero
tff(fact_876_one__le__floor,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),one_one(int)),archim6421214686448440834_floor(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),X2) ) ) ).

% one_le_floor
tff(fact_877_floor__less__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archim6421214686448440834_floor(B,X2)),one_one(int))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),one_one(B)) ) ) ).

% floor_less_one
tff(fact_878_ceiling__le__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archimedean_ceiling(B,X2)),one_one(int))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),one_one(B)) ) ) ).

% ceiling_le_one
tff(fact_879_one__less__ceiling,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),one_one(int)),archimedean_ceiling(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),X2) ) ) ).

% one_less_ceiling
tff(fact_880_ceiling__add__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : archimedean_ceiling(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),one_one(B))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),archimedean_ceiling(B,X2)),one_one(int)) ) ).

% ceiling_add_one
tff(fact_881_floor__diff__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),one_one(B))) = aa(int,int,aa(int,fun(int,int),minus_minus(int),archim6421214686448440834_floor(B,X2)),one_one(int)) ) ).

% floor_diff_one
tff(fact_882_ceiling__diff__one,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : archimedean_ceiling(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),one_one(B))) = aa(int,int,aa(int,fun(int,int),minus_minus(int),archimedean_ceiling(B,X2)),one_one(int)) ) ).

% ceiling_diff_one
tff(fact_883_atLeastatMost__psubset__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),set_or1337092689740270186AtMost(B,A3,B2)),set_or1337092689740270186AtMost(B,C2,D3))
        <=> ( ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
              | ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
                & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3)
                & ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),A3)
                  | aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),D3) ) ) )
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),D3) ) ) ) ).

% atLeastatMost_psubset_iff
tff(fact_884_nat__mod__eq__iff,axiom,
    ! [X2: nat,N: nat,Y: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),Y),N) )
    <=> ? [Q1: nat,Q22: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X2),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),Q1)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Y),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),Q22)) ) ).

% nat_mod_eq_iff
tff(fact_885_le__floor__add,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Y: B] : aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),archim6421214686448440834_floor(B,Y))),archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y))) ) ).

% le_floor_add
tff(fact_886_bset_I1_J,axiom,
    ! [D4: int,B5: set(int),P: fun(int,$o),Q: fun(int,$o)] :
      ( ! [X3: int] :
          ( ! [Xa3: int] :
              ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb2: int] :
                  ( member(int,Xb2,B5)
                 => ( X3 != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb2),Xa3) ) ) )
         => ( aa(int,$o,P,X3)
           => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),D4)) ) )
     => ( ! [X3: int] :
            ( ! [Xa3: int] :
                ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb2: int] :
                    ( member(int,Xb2,B5)
                   => ( X3 != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb2),Xa3) ) ) )
           => ( aa(int,$o,Q,X3)
             => aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),D4)) ) )
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,B5)
                   => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
           => ( ( aa(int,$o,P,X)
                & aa(int,$o,Q,X) )
             => ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4))
                & aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)) ) ) ) ) ) ).

% bset(1)
tff(fact_887_bset_I2_J,axiom,
    ! [D4: int,B5: set(int),P: fun(int,$o),Q: fun(int,$o)] :
      ( ! [X3: int] :
          ( ! [Xa3: int] :
              ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb2: int] :
                  ( member(int,Xb2,B5)
                 => ( X3 != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb2),Xa3) ) ) )
         => ( aa(int,$o,P,X3)
           => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),D4)) ) )
     => ( ! [X3: int] :
            ( ! [Xa3: int] :
                ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb2: int] :
                    ( member(int,Xb2,B5)
                   => ( X3 != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb2),Xa3) ) ) )
           => ( aa(int,$o,Q,X3)
             => aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),minus_minus(int),X3),D4)) ) )
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,B5)
                   => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
           => ( ( aa(int,$o,P,X)
                | aa(int,$o,Q,X) )
             => ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4))
                | aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)) ) ) ) ) ) ).

% bset(2)
tff(fact_888_aset_I1_J,axiom,
    ! [D4: int,A4: set(int),P: fun(int,$o),Q: fun(int,$o)] :
      ( ! [X3: int] :
          ( ! [Xa3: int] :
              ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb2: int] :
                  ( member(int,Xb2,A4)
                 => ( X3 != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb2),Xa3) ) ) )
         => ( aa(int,$o,P,X3)
           => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),D4)) ) )
     => ( ! [X3: int] :
            ( ! [Xa3: int] :
                ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb2: int] :
                    ( member(int,Xb2,A4)
                   => ( X3 != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb2),Xa3) ) ) )
           => ( aa(int,$o,Q,X3)
             => aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),D4)) ) )
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,A4)
                   => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
           => ( ( aa(int,$o,P,X)
                & aa(int,$o,Q,X) )
             => ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4))
                & aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)) ) ) ) ) ) ).

% aset(1)
tff(fact_889_aset_I2_J,axiom,
    ! [D4: int,A4: set(int),P: fun(int,$o),Q: fun(int,$o)] :
      ( ! [X3: int] :
          ( ! [Xa3: int] :
              ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb2: int] :
                  ( member(int,Xb2,A4)
                 => ( X3 != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb2),Xa3) ) ) )
         => ( aa(int,$o,P,X3)
           => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),D4)) ) )
     => ( ! [X3: int] :
            ( ! [Xa3: int] :
                ( member(int,Xa3,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb2: int] :
                    ( member(int,Xb2,A4)
                   => ( X3 != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb2),Xa3) ) ) )
           => ( aa(int,$o,Q,X3)
             => aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),D4)) ) )
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,A4)
                   => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
           => ( ( aa(int,$o,P,X)
                | aa(int,$o,Q,X) )
             => ( aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4))
                | aa(int,$o,Q,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)) ) ) ) ) ) ).

% aset(2)
tff(fact_890_nat__mod__eq__lemma,axiom,
    ! [X2: nat,N: nat,Y: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),Y),N) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Y),X2)
       => ? [Q2: nat] : X2 = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Y),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),Q2)) ) ) ).

% nat_mod_eq_lemma
tff(fact_891_mod__eq__nat2E,axiom,
    ! [M: nat,Q3: nat,N: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),Q3) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),N),Q3) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ~ ! [S4: nat] : N != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Q3),S4)) ) ) ).

% mod_eq_nat2E
tff(fact_892_mod__eq__nat1E,axiom,
    ! [M: nat,Q3: nat,N: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),Q3) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),N),Q3) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M)
       => ~ ! [S4: nat] : M != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Q3),S4)) ) ) ).

% mod_eq_nat1E
tff(fact_893_ceiling__add__le,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Y: B] : aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archimedean_ceiling(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y))),aa(int,int,aa(int,fun(int,int),plus_plus(int),archimedean_ceiling(B,X2)),archimedean_ceiling(B,Y))) ) ).

% ceiling_add_le
tff(fact_894_mod__mult2__eq,axiom,
    ! [M: nat,N: nat,Q3: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),Q3)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)),Q3))),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),N)) ).

% mod_mult2_eq
tff(fact_895_div__mod__decomp,axiom,
    ! [A4: nat,N: nat] : A4 = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),A4),N)),N)),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),A4),N)) ).

% div_mod_decomp
tff(fact_896_one__add__floor,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),one_one(int)) = archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),one_one(B))) ) ).

% one_add_floor
tff(fact_897_split__mod,axiom,
    ! [P: fun(nat,$o),M: nat,N: nat] :
      ( aa(nat,$o,P,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),N))
    <=> ( ( ( N = zero_zero(nat) )
         => aa(nat,$o,P,M) )
        & ( ( N != zero_zero(nat) )
         => ! [I3: nat,J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),N)
             => ( ( M = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),I3)),J2) )
               => aa(nat,$o,P,J2) ) ) ) ) ) ).

% split_mod
tff(fact_898_bset_I3_J,axiom,
    ! [D4: int,T2: int,B5: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,aa(int,int,aa(int,fun(int,int),minus_minus(int),T2),one_one(int)),B5)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,B5)
                   => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
           => ( ( X = T2 )
             => ( aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4) = T2 ) ) ) ) ) ).

% bset(3)
tff(fact_899_bset_I4_J,axiom,
    ! [D4: int,T2: int,B5: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,T2,B5)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,B5)
                   => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
           => ( ( X != T2 )
             => ( aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4) != T2 ) ) ) ) ) ).

% bset(4)
tff(fact_900_bset_I5_J,axiom,
    ! [D4: int,B5: set(int),T2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,B5)
                 => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),X),T2)
           => aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)),T2) ) ) ) ).

% bset(5)
tff(fact_901_bset_I7_J,axiom,
    ! [D4: int,T2: int,B5: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,T2,B5)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,B5)
                   => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),T2),X)
             => aa(int,$o,aa(int,fun(int,$o),ord_less(int),T2),aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)) ) ) ) ) ).

% bset(7)
tff(fact_902_aset_I3_J,axiom,
    ! [D4: int,T2: int,A4: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,aa(int,int,aa(int,fun(int,int),plus_plus(int),T2),one_one(int)),A4)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,A4)
                   => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
           => ( ( X = T2 )
             => ( aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4) = T2 ) ) ) ) ) ).

% aset(3)
tff(fact_903_aset_I4_J,axiom,
    ! [D4: int,T2: int,A4: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,T2,A4)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,A4)
                   => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
           => ( ( X != T2 )
             => ( aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4) != T2 ) ) ) ) ) ).

% aset(4)
tff(fact_904_aset_I5_J,axiom,
    ! [D4: int,T2: int,A4: set(int)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ( member(int,T2,A4)
       => ! [X: int] :
            ( ! [Xa4: int] :
                ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
               => ! [Xb3: int] :
                    ( member(int,Xb3,A4)
                   => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
           => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),X),T2)
             => aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)),T2) ) ) ) ) ).

% aset(5)
tff(fact_905_aset_I7_J,axiom,
    ! [D4: int,A4: set(int),T2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,A4)
                 => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),T2),X)
           => aa(int,$o,aa(int,fun(int,$o),ord_less(int),T2),aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)) ) ) ) ).

% aset(7)
tff(fact_906_aset_I8_J,axiom,
    ! [D4: int,A4: set(int),T2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,A4)
                 => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),T2),X)
           => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),T2),aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)) ) ) ) ).

% aset(8)
tff(fact_907_ceiling__divide__lower,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Q3: B,P3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),Q3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),archimedean_ceiling(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),P3),Q3)))),one_one(B))),Q3)),P3) ) ) ).

% ceiling_divide_lower
tff(fact_908_floor__divide__upper,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Q3: B,P3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),Q3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),P3),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),P3),Q3)))),one_one(B))),Q3)) ) ) ).

% floor_divide_upper
tff(fact_909_power__decreasing__iff,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [B2: B,M: nat,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),one_one(B))
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),N))
            <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M) ) ) ) ) ).

% power_decreasing_iff
tff(fact_910_divmod__nat__def,axiom,
    ! [M: nat,N: nat] : divmod_nat(M,N) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),N)) ).

% divmod_nat_def
tff(fact_911_distrib__left__NO__MATCH,axiom,
    ! [B: $tType,C: $tType] :
      ( semiring(C)
     => ! [X2: B,Y: B,A3: C,B2: C,C2: C] :
          ( nO_MATCH(B,C,aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Y),A3)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),A3),aa(C,C,aa(C,fun(C,C),plus_plus(C),B2),C2)) = 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),C2)) ) ) ) ).

% distrib_left_NO_MATCH
tff(fact_912_distrib__right__NO__MATCH,axiom,
    ! [B: $tType,C: $tType] :
      ( semiring(C)
     => ! [X2: B,Y: B,C2: C,A3: C,B2: C] :
          ( nO_MATCH(B,C,aa(B,B,aa(B,fun(B,B),divide_divide(B),X2),Y),C2)
         => ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),A3),B2)),C2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),times_times(C),A3),C2)),aa(C,C,aa(C,fun(C,C),times_times(C),B2),C2)) ) ) ) ).

% distrib_right_NO_MATCH
tff(fact_913_Suc__times__mod__eq,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,zero_zero(nat))),M)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N))),M) = one_one(nat) ) ) ).

% Suc_times_mod_eq
tff(fact_914_div__add__self1__no__field,axiom,
    ! [B: $tType,C: $tType] :
      ( ( euclid4440199948858584721cancel(C)
        & field(B) )
     => ! [X2: B,B2: C,A3: C] :
          ( nO_MATCH(B,C,X2,B2)
         => ( ( B2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,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),aa(C,C,aa(C,fun(C,C),divide_divide(C),A3),B2)),one_one(C)) ) ) ) ) ).

% div_add_self1_no_field
tff(fact_915_div__add__self2__no__field,axiom,
    ! [B: $tType,C: $tType] :
      ( ( euclid4440199948858584721cancel(C)
        & field(B) )
     => ! [X2: B,B2: C,A3: C] :
          ( nO_MATCH(B,C,X2,B2)
         => ( ( B2 != zero_zero(C) )
           => ( aa(C,C,aa(C,fun(C,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),aa(C,C,aa(C,fun(C,C),divide_divide(C),A3),B2)),one_one(C)) ) ) ) ) ).

% div_add_self2_no_field
tff(fact_916_power__one,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),one_one(B)),N) = one_one(B) ) ).

% power_one
tff(fact_917_add__Suc__right,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,suc,N)) = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) ).

% add_Suc_right
tff(fact_918_power__one__right,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [A3: B] : aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),one_one(nat)) = A3 ) ).

% power_one_right
tff(fact_919_power__inject__exp,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,M: nat,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => ( ( aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),M) = aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N) )
          <=> ( M = N ) ) ) ) ).

% power_inject_exp
tff(fact_920_mult__Suc__right,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),aa(nat,nat,suc,N)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N)) ).

% mult_Suc_right
tff(fact_921_diff__Suc__1,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,suc,N)),one_one(nat)) = N ).

% diff_Suc_1
tff(fact_922_of__int__eq__1__iff,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [Z2: int] :
          ( ( aa(int,B,ring_1_of_int(B),Z2) = one_one(B) )
        <=> ( Z2 = one_one(int) ) ) ) ).

% of_int_eq_1_iff
tff(fact_923_of__int__1,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ( aa(int,B,ring_1_of_int(B),one_one(int)) = one_one(B) ) ) ).

% of_int_1
tff(fact_924_of__int__add,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [W: int,Z2: int] : aa(int,B,ring_1_of_int(B),aa(int,int,aa(int,fun(int,int),plus_plus(int),W),Z2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),W)),aa(int,B,ring_1_of_int(B),Z2)) ) ).

% of_int_add
tff(fact_925_power__strict__increasing__iff,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [B2: B,X2: nat,Y: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),X2)),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),Y))
          <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),Y) ) ) ) ).

% power_strict_increasing_iff
tff(fact_926_left__minus__one__mult__self,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),A3)) = A3 ) ).

% left_minus_one_mult_self
tff(fact_927_minus__one__mult__self,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)) = one_one(B) ) ).

% minus_one_mult_self
tff(fact_928_diff__Suc__diff__eq2,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K))),I) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,suc,J)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),I)) ) ) ).

% diff_Suc_diff_eq2
tff(fact_929_diff__Suc__diff__eq1,axiom,
    ! [K: nat,J: nat,I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),J)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),K))) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),K)),aa(nat,nat,suc,J)) ) ) ).

% diff_Suc_diff_eq1
tff(fact_930_Suc__diff,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),M)
       => ( aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))) ) ) ) ).

% Suc_diff
tff(fact_931_Suc__mod__mult__self4,axiom,
    ! [N: nat,K: nat,M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),K)),M))),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,M)),N) ).

% Suc_mod_mult_self4
tff(fact_932_Suc__mod__mult__self3,axiom,
    ! [K: nat,N: nat,M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),N)),M))),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,M)),N) ).

% Suc_mod_mult_self3
tff(fact_933_Suc__mod__mult__self2,axiom,
    ! [M: nat,N: nat,K: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),K)))),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,M)),N) ).

% Suc_mod_mult_self2
tff(fact_934_Suc__mod__mult__self1,axiom,
    ! [M: nat,K: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),N)))),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,M)),N) ).

% Suc_mod_mult_self1
tff(fact_935_ceiling__add__of__int,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Z2: int] : archimedean_ceiling(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(int,B,ring_1_of_int(B),Z2))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),archimedean_ceiling(B,X2)),Z2) ) ).

% ceiling_add_of_int
tff(fact_936_power__strict__decreasing__iff,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [B2: B,M: nat,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),one_one(B))
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),N))
            <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M) ) ) ) ) ).

% power_strict_decreasing_iff
tff(fact_937_power__increasing__iff,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [B2: B,X2: nat,Y: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),X2)),aa(nat,B,aa(B,fun(nat,B),power_power(B),B2),Y))
          <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),X2),Y) ) ) ) ).

% power_increasing_iff
tff(fact_938_Suc__diff__1,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) = N ) ) ).

% Suc_diff_1
tff(fact_939_of__int__1__le__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [Z2: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(int,B,ring_1_of_int(B),Z2))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),one_one(int)),Z2) ) ) ).

% of_int_1_le_iff
tff(fact_940_of__int__le__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [Z2: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Z2),one_one(int)) ) ) ).

% of_int_le_1_iff
tff(fact_941_of__int__less__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [Z2: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z2),one_one(int)) ) ) ).

% of_int_less_1_iff
tff(fact_942_of__int__1__less__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [Z2: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(int,B,ring_1_of_int(B),Z2))
        <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),one_one(int)),Z2) ) ) ).

% of_int_1_less_iff
tff(fact_943_power__gt1,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,suc,N))) ) ) ).

% power_gt1
tff(fact_944_add__Suc__shift,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,suc,M)),N) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,suc,N)) ).

% add_Suc_shift
tff(fact_945_add__Suc,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,suc,M)),N) = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) ).

% add_Suc
tff(fact_946_nat__arith_Osuc1,axiom,
    ! [A4: nat,K: nat,A3: nat] :
      ( ( A4 = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),A3) )
     => ( aa(nat,nat,suc,A4) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),aa(nat,nat,suc,A3)) ) ) ).

% nat_arith.suc1
tff(fact_947_power__Suc__le__self,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,suc,N))),A3) ) ) ) ).

% power_Suc_le_self
tff(fact_948_power__Suc__less__one,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,suc,N))),one_one(B)) ) ) ) ).

% power_Suc_less_one
tff(fact_949_power__minus_H,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [X2: B,N: nat] :
          ( nO_MATCH(B,B,one_one(B),X2)
         => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),X2)),N) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)) ) ) ) ).

% power_minus'
tff(fact_950_one__le__power,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),A3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ) ).

% one_le_power
tff(fact_951_left__right__inverse__power,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [X2: B,Y: B,N: nat] :
          ( ( aa(B,B,aa(B,fun(B,B),times_times(B),X2),Y) = one_one(B) )
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),N)) = one_one(B) ) ) ) ).

% left_right_inverse_power
tff(fact_952_power__0,axiom,
    ! [B: $tType] :
      ( power(B)
     => ! [A3: B] : aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),zero_zero(nat)) = one_one(B) ) ).

% power_0
tff(fact_953_power__one__over,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3)),N) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ).

% power_one_over
tff(fact_954_power__add,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [A3: B,M: nat,N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ).

% power_add
tff(fact_955_nat__compl__induct_H,axiom,
    ! [P: fun(nat,$o),N: nat] :
      ( aa(nat,$o,P,zero_zero(nat))
     => ( ! [N3: nat] :
            ( ! [Nn: nat] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Nn),N3)
               => aa(nat,$o,P,Nn) )
           => aa(nat,$o,P,aa(nat,nat,suc,N3)) )
       => aa(nat,$o,P,N) ) ) ).

% nat_compl_induct'
tff(fact_956_nat__compl__induct,axiom,
    ! [P: fun(nat,$o),N: nat] :
      ( aa(nat,$o,P,zero_zero(nat))
     => ( ! [N3: nat] :
            ( ! [Nn: nat] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Nn),N3)
               => aa(nat,$o,P,Nn) )
           => aa(nat,$o,P,aa(nat,nat,suc,N3)) )
       => aa(nat,$o,P,N) ) ) ).

% nat_compl_induct
tff(fact_957_one__is__add,axiom,
    ! [M: nat,N: nat] :
      ( ( aa(nat,nat,suc,zero_zero(nat)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N) )
    <=> ( ( ( M = aa(nat,nat,suc,zero_zero(nat)) )
          & ( N = zero_zero(nat) ) )
        | ( ( M = zero_zero(nat) )
          & ( N = aa(nat,nat,suc,zero_zero(nat)) ) ) ) ) ).

% one_is_add
tff(fact_958_add__is__1,axiom,
    ! [M: nat,N: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N) = aa(nat,nat,suc,zero_zero(nat)) )
    <=> ( ( ( M = aa(nat,nat,suc,zero_zero(nat)) )
          & ( N = zero_zero(nat) ) )
        | ( ( M = zero_zero(nat) )
          & ( N = aa(nat,nat,suc,zero_zero(nat)) ) ) ) ) ).

% add_is_1
tff(fact_959_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_960_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_961_less__imp__Suc__add,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
     => ? [K3: nat] : N = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K3)) ) ).

% less_imp_Suc_add
tff(fact_962_less__iff__Suc__add,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
    <=> ? [K4: nat] : N = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K4)) ) ).

% less_iff_Suc_add
tff(fact_963_less__add__Suc2,axiom,
    ! [I: nat,M: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),I))) ).

% less_add_Suc2
tff(fact_964_less__add__Suc1,axiom,
    ! [I: nat,M: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),M))) ).

% less_add_Suc1
tff(fact_965_less__natE,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
     => ~ ! [Q2: nat] : N != aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),Q2)) ) ).

% less_natE
tff(fact_966_Suc__to__right,axiom,
    ! [N: nat,M: nat] :
      ( ( aa(nat,nat,suc,N) = M )
     => ( N = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),aa(nat,nat,suc,zero_zero(nat))) ) ) ).

% Suc_to_right
tff(fact_967_One__nat__def,axiom,
    one_one(nat) = aa(nat,nat,suc,zero_zero(nat)) ).

% One_nat_def
tff(fact_968_mult__Suc,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,suc,M)),N) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N)) ).

% mult_Suc
tff(fact_969_Suc__eq__plus1__left,axiom,
    ! [N: nat] : aa(nat,nat,suc,N) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),N) ).

% Suc_eq_plus1_left
tff(fact_970_plus__1__eq__Suc,axiom,
    aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)) = suc ).

% plus_1_eq_Suc
tff(fact_971_Suc__eq__plus1,axiom,
    ! [N: nat] : aa(nat,nat,suc,N) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)) ).

% Suc_eq_plus1
tff(fact_972_diff__Suc__eq__diff__pred,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),aa(nat,nat,suc,N)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))),N) ).

% diff_Suc_eq_diff_pred
tff(fact_973_power__le__one,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)),one_one(B)) ) ) ) ).

% power_le_one
tff(fact_974_power__less__power__Suc,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N))) ) ) ).

% power_less_power_Suc
tff(fact_975_power__gt1__lemma,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N))) ) ) ).

% power_gt1_lemma
tff(fact_976_power__0__left,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [N: nat] :
          aa(nat,B,aa(B,fun(nat,B),power_power(B),zero_zero(B)),N) = $ite(N = zero_zero(nat),one_one(B),zero_zero(B)) ) ).

% power_0_left
tff(fact_977_power__strict__increasing,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [N: nat,N5: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N5)) ) ) ) ).

% power_strict_increasing
tff(fact_978_power__less__imp__less__exp,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,M: nat,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N))
           => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N) ) ) ) ).

% power_less_imp_less_exp
tff(fact_979_power__minus,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [A3: B,N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),A3)),N) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ).

% power_minus
tff(fact_980_power__increasing,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [N: nat,N5: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),A3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N5)) ) ) ) ).

% power_increasing
tff(fact_981_floor__add__int,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Z2: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),Z2) = archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(int,B,ring_1_of_int(B),Z2))) ) ).

% floor_add_int
tff(fact_982_int__add__floor,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Z2: int,X2: B] : aa(int,int,aa(int,fun(int,int),plus_plus(int),Z2),archim6421214686448440834_floor(B,X2)) = archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),Z2)),X2)) ) ).

% int_add_floor
tff(fact_983_nat__induct__non__zero,axiom,
    ! [N: nat,P: fun(nat,$o)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,$o,P,one_one(nat))
       => ( ! [N3: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N3)
             => ( aa(nat,$o,P,N3)
               => aa(nat,$o,P,aa(nat,nat,suc,N3)) ) )
         => aa(nat,$o,P,N) ) ) ) ).

% nat_induct_non_zero
tff(fact_984_of__int__leD,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [N: int,X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(int,B,ring_1_of_int(B),N))),X2)
         => ( ( N = zero_zero(int) )
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),X2) ) ) ) ).

% of_int_leD
tff(fact_985_of__int__lessD,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [N: int,X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),aa(int,B,ring_1_of_int(B),N))),X2)
         => ( ( N = zero_zero(int) )
            | aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),X2) ) ) ) ).

% of_int_lessD
tff(fact_986_floor__exists,axiom,
    ! [B: $tType] :
      ( archim462609752435547400_field(B)
     => ! [X2: B] :
        ? [Z3: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),Z3)),X2)
          & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(int,B,ring_1_of_int(B),aa(int,int,aa(int,fun(int,int),plus_plus(int),Z3),one_one(int)))) ) ) ).

% floor_exists
tff(fact_987_floor__exists1,axiom,
    ! [B: $tType] :
      ( archim462609752435547400_field(B)
     => ! [X2: B] :
        ? [X3: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),X3)),X2)
          & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(int,B,ring_1_of_int(B),aa(int,int,aa(int,fun(int,int),plus_plus(int),X3),one_one(int))))
          & ! [Y5: int] :
              ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),Y5)),X2)
                & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(int,B,ring_1_of_int(B),aa(int,int,aa(int,fun(int,int),plus_plus(int),Y5),one_one(int)))) )
             => ( Y5 = X3 ) ) ) ) ).

% floor_exists1
tff(fact_988_power__Suc__less,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N))),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ) ) ).

% power_Suc_less
tff(fact_989_power__strict__decreasing,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [N: nat,N5: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N5)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ) ) ) ).

% power_strict_decreasing
tff(fact_990_power__decreasing,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [N: nat,N5: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N5)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ) ) ) ).

% power_decreasing
tff(fact_991_power__le__imp__le__exp,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,M: nat,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N))
           => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ) ) ).

% power_le_imp_le_exp
tff(fact_992_self__le__power,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ) ) ).

% self_le_power
tff(fact_993_one__less__power,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [A3: B,N: nat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) ) ) ) ).

% one_less_power
tff(fact_994_nz__le__conv__less,axiom,
    ! [K: nat,M: 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),M)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),aa(nat,nat,suc,zero_zero(nat)))),M) ) ) ).

% nz_le_conv_less
tff(fact_995_ceiling__altdef,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          archimedean_ceiling(B,X2) = $ite(X2 = aa(int,B,ring_1_of_int(B),archim6421214686448440834_floor(B,X2)),archim6421214686448440834_floor(B,X2),aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),one_one(int))) ) ).

% ceiling_altdef
tff(fact_996_Suc__diff__eq__diff__pred,axiom,
    ! [N: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,suc,M)),N) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ) ) ).

% Suc_diff_eq_diff_pred
tff(fact_997_Suc__pred_H,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( N = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ) ) ).

% Suc_pred'
tff(fact_998_add__eq__if,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N) = $ite(M = zero_zero(nat),N,aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))),N))) ).

% add_eq_if
tff(fact_999_Suc__n__minus__m__eq,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),M)
       => ( aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))) ) ) ) ).

% Suc_n_minus_m_eq
tff(fact_1000_floor__unique,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Z2: int,X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),Z2)),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B)))
           => ( archim6421214686448440834_floor(B,X2) = Z2 ) ) ) ) ).

% floor_unique
tff(fact_1001_floor__eq__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,A3: int] :
          ( ( archim6421214686448440834_floor(B,X2) = A3 )
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),A3)),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),A3)),one_one(B))) ) ) ) ).

% floor_eq_iff
tff(fact_1002_floor__split,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [P: fun(int,$o),T2: B] :
          ( aa(int,$o,P,archim6421214686448440834_floor(B,T2))
        <=> ! [I3: int] :
              ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),I3)),T2)
                & aa(B,$o,aa(B,fun(B,$o),ord_less(B),T2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),I3)),one_one(B))) )
             => aa(int,$o,P,I3) ) ) ) ).

% floor_split
tff(fact_1003_ceiling__correct,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),archimedean_ceiling(B,X2))),one_one(B))),X2)
          & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(int,B,ring_1_of_int(B),archimedean_ceiling(B,X2))) ) ) ).

% ceiling_correct
tff(fact_1004_ceiling__unique,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Z2: int,X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(int,B,ring_1_of_int(B),Z2))
           => ( archimedean_ceiling(B,X2) = Z2 ) ) ) ) ).

% ceiling_unique
tff(fact_1005_ceiling__eq__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,A3: int] :
          ( ( archimedean_ceiling(B,X2) = A3 )
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),A3)),one_one(B))),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(int,B,ring_1_of_int(B),A3)) ) ) ) ).

% ceiling_eq_iff
tff(fact_1006_ceiling__split,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [P: fun(int,$o),T2: B] :
          ( aa(int,$o,P,archimedean_ceiling(B,T2))
        <=> ! [I3: int] :
              ( ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),I3)),one_one(B))),T2)
                & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),T2),aa(int,B,ring_1_of_int(B),I3)) )
             => aa(int,$o,P,I3) ) ) ) ).

% ceiling_split
tff(fact_1007_less__floor__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Z2: int,X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),Z2),archim6421214686448440834_floor(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))),X2) ) ) ).

% less_floor_iff
tff(fact_1008_floor__le__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Z2: int] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(B,X2)),Z2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))) ) ) ).

% floor_le_iff
tff(fact_1009_ceiling__less__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Z2: int] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(B,X2)),Z2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))) ) ) ).

% ceiling_less_iff
tff(fact_1010_le__ceiling__iff,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [Z2: int,X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Z2),archimedean_ceiling(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),Z2)),one_one(B))),X2) ) ) ).

% le_ceiling_iff
tff(fact_1011_floor__correct,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),archim6421214686448440834_floor(B,X2))),X2)
          & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(int,B,ring_1_of_int(B),aa(int,int,aa(int,fun(int,int),plus_plus(int),archim6421214686448440834_floor(B,X2)),one_one(int)))) ) ) ).

% floor_correct
tff(fact_1012_power__diff__power__eq,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [A3: B,M: nat,N: nat] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),N)),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M)))) ) ) ) ).

% power_diff_power_eq
tff(fact_1013_power__eq__if,axiom,
    ! [B: $tType] :
      ( power(B)
     => ! [P3: B,M: nat] :
          aa(nat,B,aa(B,fun(nat,B),power_power(B),P3),M) = $ite(M = zero_zero(nat),one_one(B),aa(B,B,aa(B,fun(B,B),times_times(B),P3),aa(nat,B,aa(B,fun(nat,B),power_power(B),P3),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))))) ) ).

% power_eq_if
tff(fact_1014_power__minus__mult,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [N: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))),A3) = aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N) ) ) ) ).

% power_minus_mult
tff(fact_1015_neg__one__power__add__eq__neg__one__power__diff,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [K: nat,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),N)
         => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K)) = aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),K)) ) ) ) ).

% neg_one_power_add_eq_neg_one_power_diff
tff(fact_1016_option_Osize__gen_I2_J,axiom,
    ! [B: $tType,X2: fun(B,nat),X22: B] : aa(option(B),nat,size_option(B,X2),aa(B,option(B),some(B),X22)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,X2,X22)),aa(nat,nat,suc,zero_zero(nat))) ).

% option.size_gen(2)
tff(fact_1017_Heap_Osize__gen,axiom,
    ! [B: $tType,Xa: fun(B,nat),X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] : aa(heap_Time_Heap(B),nat,heap_Time_size_Heap(B,Xa),aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2)) = aa(nat,nat,suc,zero_zero(nat)) ).

% Heap.size_gen
tff(fact_1018_num_Osize__gen_I2_J,axiom,
    ! [X22: num] : size_num(aa(num,num,bit0,X22)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),size_num(X22)),aa(nat,nat,suc,zero_zero(nat))) ).

% num.size_gen(2)
tff(fact_1019_normalize__negative,axiom,
    ! [Q3: int,P3: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),Q3),zero_zero(int))
     => ( normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3)) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),P3)),aa(int,int,uminus_uminus(int),Q3))) ) ) ).

% normalize_negative
tff(fact_1020_option_Osize__gen_I1_J,axiom,
    ! [B: $tType,X2: fun(B,nat)] : aa(option(B),nat,size_option(B,X2),none(B)) = aa(nat,nat,suc,zero_zero(nat)) ).

% option.size_gen(1)
tff(fact_1021_Heap_Osize_I2_J,axiom,
    ! [B: $tType,X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] : aa(heap_Time_Heap(B),nat,size_size(heap_Time_Heap(B)),aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2)) = aa(nat,nat,suc,zero_zero(nat)) ).

% Heap.size(2)
tff(fact_1022_num_Osize_I5_J,axiom,
    ! [X22: num] : aa(num,nat,size_size(num),aa(num,num,bit0,X22)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,size_size(num),X22)),aa(nat,nat,suc,zero_zero(nat))) ).

% num.size(5)
tff(fact_1023_option_Osize_I3_J,axiom,
    ! [B: $tType] : aa(option(B),nat,size_size(option(B)),none(B)) = aa(nat,nat,suc,zero_zero(nat)) ).

% option.size(3)
tff(fact_1024_normalize__denom__zero,axiom,
    ! [P3: int] : normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),zero_zero(int))) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)) ).

% normalize_denom_zero
tff(fact_1025_option_Osize__neq,axiom,
    ! [B: $tType,X2: option(B)] : aa(option(B),nat,size_size(option(B)),X2) != zero_zero(nat) ).

% option.size_neq
tff(fact_1026_Heap_Osize__neq,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B)] : aa(heap_Time_Heap(B),nat,size_size(heap_Time_Heap(B)),X2) != zero_zero(nat) ).

% Heap.size_neq
tff(fact_1027_option_Osize__gen__o__map,axiom,
    ! [C: $tType,B: $tType,F: fun(C,nat),G: fun(B,C)] : aa(fun(option(B),option(C)),fun(option(B),nat),aa(fun(option(C),nat),fun(fun(option(B),option(C)),fun(option(B),nat)),comp(option(C),nat,option(B)),size_option(C,F)),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),G)) = size_option(B,aa(fun(B,C),fun(B,nat),aa(fun(C,nat),fun(fun(B,C),fun(B,nat)),comp(C,nat,B),F),G)) ).

% option.size_gen_o_map
tff(fact_1028_normalize__denom__pos,axiom,
    ! [R: product_prod(int,int),P3: int,Q3: int] :
      ( ( normalize(R) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) )
     => aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),Q3) ) ).

% normalize_denom_pos
tff(fact_1029_normalize__crossproduct,axiom,
    ! [Q3: int,S: int,P3: int,R: int] :
      ( ( Q3 != zero_zero(int) )
     => ( ( S != zero_zero(int) )
       => ( ( normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3)) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),R),S)) )
         => ( aa(int,int,aa(int,fun(int,int),times_times(int),P3),S) = aa(int,int,aa(int,fun(int,int),times_times(int),R),Q3) ) ) ) ) ).

% normalize_crossproduct
tff(fact_1030_option_Osize_I4_J,axiom,
    ! [B: $tType,X22: B] : aa(option(B),nat,size_size(option(B)),aa(B,option(B),some(B),X22)) = aa(nat,nat,suc,zero_zero(nat)) ).

% option.size(4)
tff(fact_1031_divmod__nat__if,axiom,
    ! [M: nat,N: nat] :
      divmod_nat(M,N) = $ite(
        ( ( N = zero_zero(nat) )
        | aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N) ),
        aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),zero_zero(nat)),M),
        aa(product_prod(nat,nat),product_prod(nat,nat),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_bk(nat,fun(nat,product_prod(nat,nat)))),divmod_nat(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),N),N)) ) ).

% divmod_nat_if
tff(fact_1032_sum__gp__multiplied,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [M: nat,N: nat,X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),set_or1337092689740270186AtMost(nat,M,N))) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(nat,nat,suc,N))) ) ) ) ).

% sum_gp_multiplied
tff(fact_1033_pair__lessI2,axiom,
    ! [A3: nat,B2: nat,S: nat,T2: 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),S),T2)
       => member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),A3),S)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),B2),T2)),fun_pair_less) ) ) ).

% pair_lessI2
tff(fact_1034_pair__less__iff1,axiom,
    ! [X2: nat,Y: nat,Z2: nat] :
      ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Y)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Z2)),fun_pair_less)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Y),Z2) ) ).

% pair_less_iff1
tff(fact_1035_Suc__times__numeral__mod__eq,axiom,
    ! [K: num,N: nat] :
      ( ( aa(num,nat,numeral_numeral(nat),K) != one_one(nat) )
     => ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),K)),N))),aa(num,nat,numeral_numeral(nat),K)) = one_one(nat) ) ) ).

% Suc_times_numeral_mod_eq
tff(fact_1036_one__int_Otransfer,axiom,
    aa(int,$o,aa(product_prod(nat,nat),fun(int,$o),pcr_int,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),one_one(nat)),zero_zero(nat))),one_one(int)) ).

% one_int.transfer
tff(fact_1037_less__than__iff,axiom,
    ! [X2: nat,Y: nat] :
      ( member(product_prod(nat,nat),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Y),less_than)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),Y) ) ).

% less_than_iff
tff(fact_1038_one__int__def,axiom,
    one_one(int) = aa(product_prod(nat,nat),int,abs_Integ,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),one_one(nat)),zero_zero(nat))) ).

% one_int_def
tff(fact_1039_sum__telescope_H_H,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [M: nat,N: nat,F: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bl(fun(nat,B),fun(nat,B),F)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),N)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,N)),aa(nat,B,F,M)) ) ) ) ).

% sum_telescope''
tff(fact_1040_case__prod__conv,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,fun(D,B)),A3: C,B2: D] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),F),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2)) = aa(D,B,aa(C,fun(D,B),F,A3),B2) ).

% case_prod_conv
tff(fact_1041_case__prod__curry,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(product_prod(B,C),D)] : aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),product_curry(B,C,D,F)) = F ).

% case_prod_curry
tff(fact_1042_curry__case__prod,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,fun(C,D))] : product_curry(B,C,D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F)) = F ).

% curry_case_prod
tff(fact_1043_distrib__right__numeral,axiom,
    ! [B: $tType] :
      ( ( numeral(B)
        & semiring(B) )
     => ! [A3: B,B2: B,V: num] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),aa(num,B,numeral_numeral(B),V)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(num,B,numeral_numeral(B),V))),aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(num,B,numeral_numeral(B),V))) ) ).

% distrib_right_numeral
tff(fact_1044_distrib__left__numeral,axiom,
    ! [B: $tType] :
      ( ( numeral(B)
        & semiring(B) )
     => ! [V: num,B2: B,C2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),V)),aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),V)),B2)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),V)),C2)) ) ).

% distrib_left_numeral
tff(fact_1045_add__neg__numeral__simps_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N))) = aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),M)),aa(num,B,numeral_numeral(B),N))) ) ).

% add_neg_numeral_simps(3)
tff(fact_1046_add__numeral__left,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [V: num,W: num,Z2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),V)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),W)),Z2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),V),W))),Z2) ) ).

% add_numeral_left
tff(fact_1047_numeral__plus__numeral,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),M)),aa(num,B,numeral_numeral(B),N)) = aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ) ).

% numeral_plus_numeral
tff(fact_1048_semiring__norm_I168_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [V: num,W: num,Y: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),V))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),W))),Y)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),V),W)))),Y) ) ).

% semiring_norm(168)
tff(fact_1049_diff__numeral__simps_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(num,B,numeral_numeral(B),N)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N))) ) ).

% diff_numeral_simps(3)
tff(fact_1050_diff__numeral__simps_I2_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(num,B,numeral_numeral(B),M)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N))) = aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ) ).

% diff_numeral_simps(2)
tff(fact_1051_ceiling__add__numeral,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,V: num] : archimedean_ceiling(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(num,B,numeral_numeral(B),V))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),archimedean_ceiling(B,X2)),aa(num,int,numeral_numeral(int),V)) ) ).

% ceiling_add_numeral
tff(fact_1052_power__add__numeral,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [A3: B,M: num,N: num] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),M))),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),N))) = aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N))) ) ).

% power_add_numeral
tff(fact_1053_power__add__numeral2,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [A3: B,M: num,N: num,B2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),M))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),N))),B2)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)))),B2) ) ).

% power_add_numeral2
tff(fact_1054_numeral__less__floor,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [V: num,X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(num,int,numeral_numeral(int),V)),archim6421214686448440834_floor(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),V)),one_one(B))),X2) ) ) ).

% numeral_less_floor
tff(fact_1055_floor__le__numeral,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(B,X2)),aa(num,int,numeral_numeral(int),V))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),V)),one_one(B))) ) ) ).

% floor_le_numeral
tff(fact_1056_sum_Ocl__ivl__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,N)),M),zero_zero(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))),aa(nat,B,G,aa(nat,nat,suc,N)))) ) ).

% sum.cl_ivl_Suc
tff(fact_1057_ceiling__less__numeral,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(B,X2)),aa(num,int,numeral_numeral(int),V))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(num,B,numeral_numeral(B),V)),one_one(B))) ) ) ).

% ceiling_less_numeral
tff(fact_1058_numeral__le__ceiling,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [V: num,X2: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(num,int,numeral_numeral(int),V)),archimedean_ceiling(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(num,B,numeral_numeral(B),V)),one_one(B))),X2) ) ) ).

% numeral_le_ceiling
tff(fact_1059_neg__numeral__less__floor,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [V: num,X2: B] :
          ( 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(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),V))),one_one(B))),X2) ) ) ).

% neg_numeral_less_floor
tff(fact_1060_floor__le__neg__numeral,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),archim6421214686448440834_floor(B,X2)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),V)))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),V))),one_one(B))) ) ) ).

% floor_le_neg_numeral
tff(fact_1061_ceiling__less__neg__numeral,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,V: num] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),archimedean_ceiling(B,X2)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),V)))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),V))),one_one(B))) ) ) ).

% ceiling_less_neg_numeral
tff(fact_1062_neg__numeral__le__ceiling,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [V: num,X2: B] :
          ( 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(B,X2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),V))),one_one(B))),X2) ) ) ).

% neg_numeral_le_ceiling
tff(fact_1063_nested__case__prod__simp,axiom,
    ! [E: $tType,B: $tType,D: $tType,C: $tType,F: fun(C,fun(D,fun(E,B))),X2: product_prod(C,D),Y: E] : aa(E,B,aa(product_prod(C,D),fun(E,B),aa(fun(C,fun(D,fun(E,B))),fun(product_prod(C,D),fun(E,B)),product_case_prod(C,D,fun(E,B)),F),X2),Y) = aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),aa(E,fun(C,fun(D,B)),aTP_Lamp_bm(fun(C,fun(D,fun(E,B))),fun(E,fun(C,fun(D,B))),F),Y)),X2) ).

% nested_case_prod_simp
tff(fact_1064_prod_Ocase__distrib,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,Ha: fun(C,B),F: fun(D,fun(E,C)),Prod: product_prod(D,E)] : aa(C,B,Ha,aa(product_prod(D,E),C,aa(fun(D,fun(E,C)),fun(product_prod(D,E),C),product_case_prod(D,E,C),F),Prod)) = aa(product_prod(D,E),B,aa(fun(D,fun(E,B)),fun(product_prod(D,E),B),product_case_prod(D,E,B),aa(fun(D,fun(E,C)),fun(D,fun(E,B)),aTP_Lamp_bn(fun(C,B),fun(fun(D,fun(E,C)),fun(D,fun(E,B))),Ha),F)),Prod) ).

% prod.case_distrib
tff(fact_1065_sum_OatLeast__Suc__atMost__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.atLeast_Suc_atMost_Suc_shift
tff(fact_1066_sum_OatLeastAtMost__shift__bounds,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),K))),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.atLeastAtMost_shift_bounds
tff(fact_1067_split__cong,axiom,
    ! [D: $tType,C: $tType,B: $tType,Q3: product_prod(B,C),F: fun(B,fun(C,D)),G: fun(B,fun(C,D)),P3: product_prod(B,C)] :
      ( ! [X3: B,Y4: C] :
          ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4) = Q3 )
         => ( aa(C,D,aa(B,fun(C,D),F,X3),Y4) = aa(C,D,aa(B,fun(C,D),G,X3),Y4) ) )
     => ( ( P3 = Q3 )
       => ( aa(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F),P3) = aa(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),G),Q3) ) ) ) ).

% split_cong
tff(fact_1068_old_Oprod_Ocase,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,fun(D,B)),X1: C,X22: D] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),F),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X1),X22)) = aa(D,B,aa(C,fun(D,B),F,X1),X22) ).

% old.prod.case
tff(fact_1069_uminus__int_Oabs__eq,axiom,
    ! [X2: product_prod(nat,nat)] : aa(int,int,uminus_uminus(int),aa(product_prod(nat,nat),int,abs_Integ,X2)) = aa(product_prod(nat,nat),int,abs_Integ,aa(product_prod(nat,nat),product_prod(nat,nat),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_bo(nat,fun(nat,product_prod(nat,nat)))),X2)) ).

% uminus_int.abs_eq
tff(fact_1070_case__prod__Pair__iden,axiom,
    ! [C: $tType,B: $tType,P3: product_prod(B,C)] : aa(product_prod(B,C),product_prod(B,C),aa(fun(B,fun(C,product_prod(B,C))),fun(product_prod(B,C),product_prod(B,C)),product_case_prod(B,C,product_prod(B,C)),product_Pair(B,C)),P3) = P3 ).

% case_prod_Pair_iden
tff(fact_1071_sum_Oshift__bounds__cl__Suc__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.shift_bounds_cl_Suc_ivl
tff(fact_1072_sum_Oshift__bounds__cl__nat__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_bq(fun(nat,B),fun(nat,fun(nat,B)),G),K)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.shift_bounds_cl_nat_ivl
tff(fact_1073_cond__case__prod__eta,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,fun(C,D)),G: fun(product_prod(B,C),D)] :
      ( ! [X3: B,Y4: C] : aa(C,D,aa(B,fun(C,D),F,X3),Y4) = aa(product_prod(B,C),D,G,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4))
     => ( aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F) = G ) ) ).

% cond_case_prod_eta
tff(fact_1074_case__prod__eta,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(product_prod(B,C),D)] : aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),aTP_Lamp_br(fun(product_prod(B,C),D),fun(B,fun(C,D)),F)) = F ).

% case_prod_eta
tff(fact_1075_case__prodE2,axiom,
    ! [C: $tType,B: $tType,D: $tType,Q: fun(B,$o),P: fun(C,fun(D,B)),Z2: product_prod(C,D)] :
      ( aa(B,$o,Q,aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),P),Z2))
     => ~ ! [X3: C,Y4: D] :
            ( ( Z2 = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X3),Y4) )
           => ~ aa(B,$o,Q,aa(D,B,aa(C,fun(D,B),P,X3),Y4)) ) ) ).

% case_prodE2
tff(fact_1076_eq__Abs__Integ,axiom,
    ! [Z2: int] :
      ~ ! [X3: nat,Y4: nat] : Z2 != aa(product_prod(nat,nat),int,abs_Integ,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X3),Y4)) ).

% eq_Abs_Integ
tff(fact_1077_one__le__numeral,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [N: num] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(num,B,numeral_numeral(B),N)) ) ).

% one_le_numeral
tff(fact_1078_not__numeral__less__one,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [N: num] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(num,B,numeral_numeral(B),N)),one_one(B)) ) ).

% not_numeral_less_one
tff(fact_1079_one__plus__numeral__commute,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(num,B,numeral_numeral(B),X2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),X2)),one_one(B)) ) ).

% one_plus_numeral_commute
tff(fact_1080_numeral__Bit0,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [N: num] : aa(num,B,numeral_numeral(B),aa(num,num,bit0,N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),N)),aa(num,B,numeral_numeral(B),N)) ) ).

% numeral_Bit0
tff(fact_1081_one__neq__neg__numeral,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [N: num] : one_one(B) != aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N)) ) ).

% one_neq_neg_numeral
tff(fact_1082_numeral__neq__neg__one,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [N: num] : aa(num,B,numeral_numeral(B),N) != aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% numeral_neq_neg_one
tff(fact_1083_uncurry__def,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,fun(C,D))] : uncurry(B,C,D,F) = aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F) ).

% uncurry_def
tff(fact_1084_internal__case__prod__def,axiom,
    ! [D: $tType,C: $tType,B: $tType] : produc5280177257484947105e_prod(B,C,D) = product_case_prod(B,C,D) ).

% internal_case_prod_def
tff(fact_1085_sum_OatLeastAtMost__rev,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_bs(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or1337092689740270186AtMost(nat,N,M)) ) ).

% sum.atLeastAtMost_rev
tff(fact_1086_numeral__code_I2_J,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [N: num] :
          aa(num,B,numeral_numeral(B),aa(num,num,bit0,N)) = $let(
            m: B,
            m:= aa(num,B,numeral_numeral(B),N),
            aa(B,B,aa(B,fun(B,B),plus_plus(B),m),m) ) ) ).

% numeral_code(2)
tff(fact_1087_sum__shift__lb__Suc0__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [F: fun(nat,B),K: nat] :
          ( ( aa(nat,B,F,zero_zero(nat)) = zero_zero(B) )
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),K)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or1337092689740270186AtMost(nat,zero_zero(nat),K)) ) ) ) ).

% sum_shift_lb_Suc0_0
tff(fact_1088_sum_OatLeast0__atMost__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))),aa(nat,B,G,aa(nat,nat,suc,N))) ) ).

% sum.atLeast0_atMost_Suc
tff(fact_1089_sum_OatLeast0__atMost__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) ) ).

% sum.atLeast0_atMost_Suc_shift
tff(fact_1090_sum_OatLeast__Suc__atMost,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),N))) ) ) ) ).

% sum.atLeast_Suc_atMost
tff(fact_1091_sum_Onat__ivl__Suc_H,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,suc,N))
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,aa(nat,nat,suc,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))) ) ) ) ).

% sum.nat_ivl_Suc'
tff(fact_1092_neg__numeral__le__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),one_one(B)) ) ).

% neg_numeral_le_one
tff(fact_1093_neg__one__le__numeral,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),M)) ) ).

% neg_one_le_numeral
tff(fact_1094_neg__numeral__le__neg__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% neg_numeral_le_neg_one
tff(fact_1095_not__numeral__le__neg__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(num,B,numeral_numeral(B),M)),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% not_numeral_le_neg_one
tff(fact_1096_not__one__le__neg__numeral,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))) ) ).

% not_one_le_neg_numeral
tff(fact_1097_not__neg__one__less__neg__numeral,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))) ) ).

% not_neg_one_less_neg_numeral
tff(fact_1098_not__one__less__neg__numeral,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))) ) ).

% not_one_less_neg_numeral
tff(fact_1099_not__numeral__less__neg__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(num,B,numeral_numeral(B),M)),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% not_numeral_less_neg_one
tff(fact_1100_neg__one__less__numeral,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),M)) ) ).

% neg_one_less_numeral
tff(fact_1101_neg__numeral__less__one,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] : aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),one_one(B)) ) ).

% neg_numeral_less_one
tff(fact_1102_sum_OSuc__reindex__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))),aa(nat,B,G,aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N))) ) ) ) ).

% sum.Suc_reindex_ivl
tff(fact_1103_sum__Suc__diff,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [M: nat,N: nat,F: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,suc,N))
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bt(fun(nat,B),fun(nat,B),F)),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,aa(nat,nat,suc,N))),aa(nat,B,F,M)) ) ) ) ).

% sum_Suc_diff
tff(fact_1104_sum__power__add,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,M: nat,I4: set(nat)] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_bu(B,fun(nat,fun(nat,B)),X2),M)),I4) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),I4)) ) ).

% sum_power_add
tff(fact_1105_sum_OatLeast__atMost__pred__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aTP_Lamp_bv(nat,nat))),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.atLeast_atMost_pred_shift
tff(fact_1106_sum__atLeastAtMost__code,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [F: fun(nat,B),A3: nat,B2: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or1337092689740270186AtMost(nat,A3,B2)) = set_fo6178422350223883121st_nat(B,aTP_Lamp_bw(fun(nat,B),fun(nat,fun(B,B)),F),A3,B2,zero_zero(B)) ) ).

% sum_atLeastAtMost_code
tff(fact_1107_sum_Oub__add__nat,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B),P3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)))
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),P3))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),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)))) ) ) ) ).

% sum.ub_add_nat
tff(fact_1108_sum_OatLeastAtMost__shift__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),M))),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ) ) ).

% sum.atLeastAtMost_shift_0
tff(fact_1109_zero__int__def,axiom,
    zero_zero(int) = aa(product_prod(nat,nat),int,abs_Integ,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),zero_zero(nat)),zero_zero(nat))) ).

% zero_int_def
tff(fact_1110_pair__lessI1,axiom,
    ! [A3: nat,B2: nat,S: nat,T2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
     => member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),A3),S)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),B2),T2)),fun_pair_less) ) ).

% pair_lessI1
tff(fact_1111_zero__int_Otransfer,axiom,
    aa(int,$o,aa(product_prod(nat,nat),fun(int,$o),pcr_int,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),zero_zero(nat)),zero_zero(nat))),zero_zero(int)) ).

% zero_int.transfer
tff(fact_1112_sum__natinterval__diff,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [F: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bx(fun(nat,B),fun(nat,B),F)),set_or1337092689740270186AtMost(nat,M,N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,M)),aa(nat,B,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)))),zero_zero(B)) ) ).

% sum_natinterval_diff
tff(fact_1113_convex__sum__bound__le,axiom,
    ! [B: $tType,C: $tType] :
      ( linordered_idom(C)
     => ! [I4: set(B),X2: fun(B,C),A3: fun(B,C),B2: C,Delta: C] :
          ( ! [I2: B] :
              ( member(B,I2,I4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(B,C,X2,I2)) )
         => ( ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),X2),I4) = one_one(C) )
           => ( ! [I2: B] :
                  ( member(B,I2,I4)
                 => 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),minus_minus(C),aa(B,C,A3,I2)),B2))),Delta) )
             => 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),minus_minus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),aa(fun(B,C),fun(B,C),aTP_Lamp_by(fun(B,C),fun(fun(B,C),fun(B,C)),X2),A3)),I4)),B2))),Delta) ) ) ) ) ).

% convex_sum_bound_le
tff(fact_1114_sum__comp__morphism,axiom,
    ! [B: $tType,C: $tType,D: $tType] :
      ( ( comm_monoid_add(C)
        & comm_monoid_add(B) )
     => ! [Ha: fun(C,B),G: fun(D,C),A4: set(D)] :
          ( ( aa(C,B,Ha,zero_zero(C)) = zero_zero(B) )
         => ( ! [X3: C,Y4: C] : aa(C,B,Ha,aa(C,C,aa(C,fun(C,C),plus_plus(C),X3),Y4)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(C,B,Ha,X3)),aa(C,B,Ha,Y4))
           => ( aa(set(D),B,aa(fun(D,B),fun(set(D),B),groups7311177749621191930dd_sum(D,B),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Ha),G)),A4) = aa(C,B,Ha,aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),G),A4)) ) ) ) ) ).

% sum_comp_morphism
tff(fact_1115_sum__gp,axiom,
    ! [B: $tType] :
      ( ( division_ring(B)
        & comm_ring(B) )
     => ! [X2: B,M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),set_or1337092689740270186AtMost(nat,M,N)) = $ite(
            aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),
            zero_zero(B),
            $ite(X2 = one_one(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))),M)),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),M)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(nat,nat,suc,N)))),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2))) ) ) ).

% sum_gp
tff(fact_1116_divmod__digit__1_I1_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),B2)))
             => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),B2)))),one_one(B)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) ) ) ) ) ) ).

% divmod_digit_1(1)
tff(fact_1117_sum__gp__offset,axiom,
    ! [B: $tType] :
      ( ( division_ring(B)
        & comm_ring(B) )
     => ! [X2: B,M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N))) = $ite(X2 = one_one(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),M)),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(nat,nat,suc,N))))),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2))) ) ).

% sum_gp_offset
tff(fact_1118_Sum__Icc__nat,axiom,
    ! [M: nat,N: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_bz(nat,nat)),set_or1337092689740270186AtMost(nat,M,N)) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) ).

% Sum_Icc_nat
tff(fact_1119_arith__series__nat,axiom,
    ! [A3: nat,D3: nat,N: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aa(nat,fun(nat,nat),aTP_Lamp_ca(nat,fun(nat,fun(nat,nat)),A3),D3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,suc,N)),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),aa(num,num,bit0,one2))),A3)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),D3)))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) ).

% arith_series_nat
tff(fact_1120_mod__double__modulus,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: B,X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2)
           => ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),X2),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),X2),M) )
              | ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),X2),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),X2),M)),M) ) ) ) ) ) ).

% mod_double_modulus
tff(fact_1121_sum_Odistrib,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(C,B),Ha: fun(C,B),A4: set(C)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7311177749621191930dd_sum(C,B),aa(fun(C,B),fun(C,B),aTP_Lamp_cb(fun(C,B),fun(fun(C,B),fun(C,B)),G),Ha)),A4) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7311177749621191930dd_sum(C,B),G),A4)),aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7311177749621191930dd_sum(C,B),Ha),A4)) ) ).

% sum.distrib
tff(fact_1122_case__prodI,axiom,
    ! [B: $tType,C: $tType,F: fun(B,fun(C,$o)),A3: B,B2: C] :
      ( aa(C,$o,aa(B,fun(C,$o),F,A3),B2)
     => aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),F),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)) ) ).

% case_prodI
tff(fact_1123_case__prodI2,axiom,
    ! [C: $tType,B: $tType,P3: product_prod(B,C),C2: fun(B,fun(C,$o))] :
      ( ! [A5: B,B3: C] :
          ( ( P3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3) )
         => aa(C,$o,aa(B,fun(C,$o),C2,A5),B3) )
     => aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),C2),P3) ) ).

% case_prodI2
tff(fact_1124_mem__case__prodI,axiom,
    ! [B: $tType,C: $tType,D: $tType,Z2: B,C2: fun(C,fun(D,set(B))),A3: C,B2: D] :
      ( member(B,Z2,aa(D,set(B),aa(C,fun(D,set(B)),C2,A3),B2))
     => member(B,Z2,aa(product_prod(C,D),set(B),aa(fun(C,fun(D,set(B))),fun(product_prod(C,D),set(B)),product_case_prod(C,D,set(B)),C2),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),A3),B2))) ) ).

% mem_case_prodI
tff(fact_1125_mem__case__prodI2,axiom,
    ! [D: $tType,C: $tType,B: $tType,P3: product_prod(B,C),Z2: D,C2: fun(B,fun(C,set(D)))] :
      ( ! [A5: B,B3: C] :
          ( ( P3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3) )
         => member(D,Z2,aa(C,set(D),aa(B,fun(C,set(D)),C2,A5),B3)) )
     => member(D,Z2,aa(product_prod(B,C),set(D),aa(fun(B,fun(C,set(D))),fun(product_prod(B,C),set(D)),product_case_prod(B,C,set(D)),C2),P3)) ) ).

% mem_case_prodI2
tff(fact_1126_case__prodI2_H,axiom,
    ! [B: $tType,C: $tType,D: $tType,P3: product_prod(B,C),C2: fun(B,fun(C,fun(D,$o))),X2: D] :
      ( ! [A5: B,B3: C] :
          ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3) = P3 )
         => aa(D,$o,aa(C,fun(D,$o),aa(B,fun(C,fun(D,$o)),C2,A5),B3),X2) )
     => aa(D,$o,aa(product_prod(B,C),fun(D,$o),aa(fun(B,fun(C,fun(D,$o))),fun(product_prod(B,C),fun(D,$o)),product_case_prod(B,C,fun(D,$o)),C2),P3),X2) ) ).

% case_prodI2'
tff(fact_1127_one__eq__numeral__iff,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: num] :
          ( ( one_one(B) = aa(num,B,numeral_numeral(B),N) )
        <=> ( one2 = N ) ) ) ).

% one_eq_numeral_iff
tff(fact_1128_numeral__eq__one__iff,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: num] :
          ( ( aa(num,B,numeral_numeral(B),N) = one_one(B) )
        <=> ( N = one2 ) ) ) ).

% numeral_eq_one_iff
tff(fact_1129_of__nat__add,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [M: nat,N: nat] : aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),M)),aa(nat,B,semiring_1_of_nat(B),N)) ) ).

% of_nat_add
tff(fact_1130_of__nat__1,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ( aa(nat,B,semiring_1_of_nat(B),one_one(nat)) = one_one(B) ) ) ).

% of_nat_1
tff(fact_1131_of__nat__1__eq__iff,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: nat] :
          ( ( one_one(B) = aa(nat,B,semiring_1_of_nat(B),N) )
        <=> ( N = one_one(nat) ) ) ) ).

% of_nat_1_eq_iff
tff(fact_1132_of__nat__eq__1__iff,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: nat] :
          ( ( aa(nat,B,semiring_1_of_nat(B),N) = one_one(B) )
        <=> ( N = one_one(nat) ) ) ) ).

% of_nat_eq_1_iff
tff(fact_1133_semiring__norm_I2_J,axiom,
    aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),one2) = aa(num,num,bit0,one2) ).

% semiring_norm(2)
tff(fact_1134_numeral__le__one__iff,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [N: num] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(num,B,numeral_numeral(B),N)),one_one(B))
        <=> aa(num,$o,aa(num,fun(num,$o),ord_less_eq(num),N),one2) ) ) ).

% numeral_le_one_iff
tff(fact_1135_one__less__numeral__iff,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [N: num] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(num,B,numeral_numeral(B),N))
        <=> aa(num,$o,aa(num,fun(num,$o),ord_less(num),one2),N) ) ) ).

% one_less_numeral_iff
tff(fact_1136_numeral__eq__neg__one__iff,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [N: num] :
          ( ( aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N)) = aa(B,B,uminus_uminus(B),one_one(B)) )
        <=> ( N = one2 ) ) ) ).

% numeral_eq_neg_one_iff
tff(fact_1137_neg__one__eq__numeral__iff,axiom,
    ! [B: $tType] :
      ( ring_char_0(B)
     => ! [N: num] :
          ( ( aa(B,B,uminus_uminus(B),one_one(B)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N)) )
        <=> ( N = one2 ) ) ) ).

% neg_one_eq_numeral_iff
tff(fact_1138_of__nat__Suc,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [M: nat] : aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,M)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(nat,B,semiring_1_of_nat(B),M)) ) ).

% of_nat_Suc
tff(fact_1139_Suc__numeral,axiom,
    ! [N: num] : aa(nat,nat,suc,aa(num,nat,numeral_numeral(nat),N)) = aa(num,nat,numeral_numeral(nat),aa(num,num,aa(num,fun(num,num),plus_plus(num),N),one2)) ).

% Suc_numeral
tff(fact_1140_not__neg__one__le__neg__numeral__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] :
          ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M)))
        <=> ( M != one2 ) ) ) ).

% not_neg_one_le_neg_numeral_iff
tff(fact_1141_one__add__one,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)) ) ) ).

% one_add_one
tff(fact_1142_neg__numeral__less__neg__one__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [M: num] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(B,B,uminus_uminus(B),one_one(B)))
        <=> ( M != one2 ) ) ) ).

% neg_numeral_less_neg_one_iff
tff(fact_1143_bits__one__mod__two__eq__one,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = one_one(B) ) ) ).

% bits_one_mod_two_eq_one
tff(fact_1144_one__mod__two__eq__one,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = one_one(B) ) ) ).

% one_mod_two_eq_one
tff(fact_1145_add__2__eq__Suc,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N) = aa(nat,nat,suc,aa(nat,nat,suc,N)) ).

% add_2_eq_Suc
tff(fact_1146_add__2__eq__Suc_H,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = aa(nat,nat,suc,aa(nat,nat,suc,N)) ).

% add_2_eq_Suc'
tff(fact_1147_Suc__1,axiom,
    aa(nat,nat,suc,one_one(nat)) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) ).

% Suc_1
tff(fact_1148_numeral__plus__one,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),N)),one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),N),one2)) ) ).

% numeral_plus_one
tff(fact_1149_one__plus__numeral,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(num,B,numeral_numeral(B),N)) = aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),N)) ) ).

% one_plus_numeral
tff(fact_1150_add__self__div__2,axiom,
    ! [M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),M)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = M ).

% add_self_div_2
tff(fact_1151_bits__1__div__2,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = zero_zero(B) ) ) ).

% bits_1_div_2
tff(fact_1152_one__div__two__eq__zero,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = zero_zero(B) ) ) ).

% one_div_two_eq_zero
tff(fact_1153_add__neg__numeral__special_I9_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ) ).

% add_neg_numeral_special(9)
tff(fact_1154_diff__numeral__special_I11_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(B,B,uminus_uminus(B),one_one(B))) = aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)) ) ) ).

% diff_numeral_special(11)
tff(fact_1155_diff__numeral__special_I10_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),one_one(B))),one_one(B)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ) ).

% diff_numeral_special(10)
tff(fact_1156_not__mod__2__eq__0__eq__1,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) != zero_zero(B) )
        <=> ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = one_one(B) ) ) ) ).

% not_mod_2_eq_0_eq_1
tff(fact_1157_not__mod__2__eq__1__eq__0,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) != one_one(B) )
        <=> ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = zero_zero(B) ) ) ) ).

% not_mod_2_eq_1_eq_0
tff(fact_1158_minus__1__div__2__eq,axiom,
    ! [B: $tType] :
      ( euclid8789492081693882211th_nat(B)
     => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% minus_1_div_2_eq
tff(fact_1159_bits__minus__1__mod__2__eq,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = one_one(B) ) ) ).

% bits_minus_1_mod_2_eq
tff(fact_1160_minus__1__mod__2__eq,axiom,
    ! [B: $tType] :
      ( euclid8789492081693882211th_nat(B)
     => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = one_one(B) ) ) ).

% minus_1_mod_2_eq
tff(fact_1161_diff__numeral__special_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N))) = aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),N)) ) ).

% diff_numeral_special(3)
tff(fact_1162_diff__numeral__special_I4_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),one_one(B)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),one2))) ) ).

% diff_numeral_special(4)
tff(fact_1163_add__self__mod__2,axiom,
    ! [M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),M)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = zero_zero(nat) ).

% add_self_mod_2
tff(fact_1164_power__minus1__even,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)) = one_one(B) ) ).

% power_minus1_even
tff(fact_1165_mod2__gr__0,axiom,
    ! [M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))
    <=> ( aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = one_one(nat) ) ) ).

% mod2_gr_0
tff(fact_1166_lex__prod__def,axiom,
    ! [B: $tType,C: $tType,Ra: set(product_prod(B,B)),Rb: set(product_prod(C,C))] : lex_prod(B,C,Ra,Rb) = aa(fun(product_prod(product_prod(B,C),product_prod(B,C)),$o),set(product_prod(product_prod(B,C),product_prod(B,C))),collect(product_prod(product_prod(B,C),product_prod(B,C))),aa(fun(product_prod(B,C),fun(product_prod(B,C),$o)),fun(product_prod(product_prod(B,C),product_prod(B,C)),$o),product_case_prod(product_prod(B,C),product_prod(B,C),$o),aa(fun(B,fun(C,fun(product_prod(B,C),$o))),fun(product_prod(B,C),fun(product_prod(B,C),$o)),product_case_prod(B,C,fun(product_prod(B,C),$o)),aa(set(product_prod(C,C)),fun(B,fun(C,fun(product_prod(B,C),$o))),aTP_Lamp_cd(set(product_prod(B,B)),fun(set(product_prod(C,C)),fun(B,fun(C,fun(product_prod(B,C),$o)))),Ra),Rb)))) ).

% lex_prod_def
tff(fact_1167_same__fst__def,axiom,
    ! [C: $tType,B: $tType,P: fun(B,$o),R4: fun(B,set(product_prod(C,C)))] : same_fst(B,C,P,R4) = aa(fun(product_prod(product_prod(B,C),product_prod(B,C)),$o),set(product_prod(product_prod(B,C),product_prod(B,C))),collect(product_prod(product_prod(B,C),product_prod(B,C))),aa(fun(product_prod(B,C),fun(product_prod(B,C),$o)),fun(product_prod(product_prod(B,C),product_prod(B,C)),$o),product_case_prod(product_prod(B,C),product_prod(B,C),$o),aa(fun(B,fun(C,fun(product_prod(B,C),$o))),fun(product_prod(B,C),fun(product_prod(B,C),$o)),product_case_prod(B,C,fun(product_prod(B,C),$o)),aa(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(product_prod(B,C),$o))),aTP_Lamp_cf(fun(B,$o),fun(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(product_prod(B,C),$o)))),P),R4)))) ).

% same_fst_def
tff(fact_1168_mem__case__prodE,axiom,
    ! [C: $tType,B: $tType,D: $tType,Z2: B,C2: fun(C,fun(D,set(B))),P3: product_prod(C,D)] :
      ( member(B,Z2,aa(product_prod(C,D),set(B),aa(fun(C,fun(D,set(B))),fun(product_prod(C,D),set(B)),product_case_prod(C,D,set(B)),C2),P3))
     => ~ ! [X3: C,Y4: D] :
            ( ( P3 = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),X3),Y4) )
           => ~ member(B,Z2,aa(D,set(B),aa(C,fun(D,set(B)),C2,X3),Y4)) ) ) ).

% mem_case_prodE
tff(fact_1169_case__prodD,axiom,
    ! [B: $tType,C: $tType,F: fun(B,fun(C,$o)),A3: B,B2: C] :
      ( aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),F),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2))
     => aa(C,$o,aa(B,fun(C,$o),F,A3),B2) ) ).

% case_prodD
tff(fact_1170_case__prodE,axiom,
    ! [B: $tType,C: $tType,C2: fun(B,fun(C,$o)),P3: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),C2),P3)
     => ~ ! [X3: B,Y4: C] :
            ( ( P3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4) )
           => ~ aa(C,$o,aa(B,fun(C,$o),C2,X3),Y4) ) ) ).

% case_prodE
tff(fact_1171_add__One__commute,axiom,
    ! [N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),N) = aa(num,num,aa(num,fun(num,num),plus_plus(num),N),one2) ).

% add_One_commute
tff(fact_1172_case__prodD_H,axiom,
    ! [C: $tType,B: $tType,D: $tType,R4: fun(B,fun(C,fun(D,$o))),A3: B,B2: C,C2: D] :
      ( aa(D,$o,aa(product_prod(B,C),fun(D,$o),aa(fun(B,fun(C,fun(D,$o))),fun(product_prod(B,C),fun(D,$o)),product_case_prod(B,C,fun(D,$o)),R4),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)),C2)
     => aa(D,$o,aa(C,fun(D,$o),aa(B,fun(C,fun(D,$o)),R4,A3),B2),C2) ) ).

% case_prodD'
tff(fact_1173_case__prodE_H,axiom,
    ! [C: $tType,B: $tType,D: $tType,C2: fun(B,fun(C,fun(D,$o))),P3: product_prod(B,C),Z2: D] :
      ( aa(D,$o,aa(product_prod(B,C),fun(D,$o),aa(fun(B,fun(C,fun(D,$o))),fun(product_prod(B,C),fun(D,$o)),product_case_prod(B,C,fun(D,$o)),C2),P3),Z2)
     => ~ ! [X3: B,Y4: C] :
            ( ( P3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4) )
           => ~ aa(D,$o,aa(C,fun(D,$o),aa(B,fun(C,fun(D,$o)),C2,X3),Y4),Z2) ) ) ).

% case_prodE'
tff(fact_1174_sum_OatLeast__int__atMost__int__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(int,B),M: nat,N: nat] : aa(set(int),B,aa(fun(int,B),fun(set(int),B),groups7311177749621191930dd_sum(int,B),G),set_or1337092689740270186AtMost(int,aa(nat,int,semiring_1_of_nat(int),M),aa(nat,int,semiring_1_of_nat(int),N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,int),fun(nat,B),aa(fun(int,B),fun(fun(nat,int),fun(nat,B)),comp(int,B,nat),G),semiring_1_of_nat(int))),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.atLeast_int_atMost_int_shift
tff(fact_1175_less__int_Oabs__eq,axiom,
    ! [Xa: product_prod(nat,nat),X2: product_prod(nat,nat)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(product_prod(nat,nat),int,abs_Integ,Xa)),aa(product_prod(nat,nat),int,abs_Integ,X2))
    <=> aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o)))),Xa),X2) ) ).

% less_int.abs_eq
tff(fact_1176_less__eq__int_Oabs__eq,axiom,
    ! [Xa: product_prod(nat,nat),X2: product_prod(nat,nat)] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(product_prod(nat,nat),int,abs_Integ,Xa)),aa(product_prod(nat,nat),int,abs_Integ,X2))
    <=> aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o)))),Xa),X2) ) ).

% less_eq_int.abs_eq
tff(fact_1177_Collect__case__prod__mono,axiom,
    ! [C: $tType,B: $tType,A4: fun(B,fun(C,$o)),B5: fun(B,fun(C,$o))] :
      ( aa(fun(B,fun(C,$o)),$o,aa(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),$o),ord_less_eq(fun(B,fun(C,$o))),A4),B5)
     => aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),A4))),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),B5))) ) ).

% Collect_case_prod_mono
tff(fact_1178_zadd__int__left,axiom,
    ! [M: nat,N: nat,Z2: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),M)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),N)),Z2)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N))),Z2) ).

% zadd_int_left
tff(fact_1179_int__plus,axiom,
    ! [N: nat,M: nat] : aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),N)),aa(nat,int,semiring_1_of_nat(int),M)) ).

% int_plus
tff(fact_1180_int__ops_I5_J,axiom,
    ! [A3: nat,B2: nat] : aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),A3)),aa(nat,int,semiring_1_of_nat(int),B2)) ).

% int_ops(5)
tff(fact_1181_int__ops_I2_J,axiom,
    aa(nat,int,semiring_1_of_nat(int),one_one(nat)) = one_one(int) ).

% int_ops(2)
tff(fact_1182_zle__iff__zadd,axiom,
    ! [W: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),W),Z2)
    <=> ? [N7: nat] : Z2 = aa(int,int,aa(int,fun(int,int),plus_plus(int),W),aa(nat,int,semiring_1_of_nat(int),N7)) ) ).

% zle_iff_zadd
tff(fact_1183_numeral__One,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ( aa(num,B,numeral_numeral(B),one2) = one_one(B) ) ) ).

% numeral_One
tff(fact_1184_numerals_I1_J,axiom,
    aa(num,nat,numeral_numeral(nat),one2) = one_one(nat) ).

% numerals(1)
tff(fact_1185_execute__bind__case,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(C),G: fun(C,heap_Time_Heap(B)),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),heap_Time_bind(C,B,F,G)),Ha) = aa(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),case_option(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(C,product_prod(heap_ext(product_unit),nat))),none(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(C,fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),product_case_prod(C,product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_cl(fun(C,heap_Time_Heap(B)),fun(C,fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),G))),aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),F),Ha)) ).

% execute_bind_case
tff(fact_1186_Sum__Icc__int,axiom,
    ! [M: int,N: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),M),N)
     => ( aa(set(int),int,aa(fun(int,int),fun(set(int),int),groups7311177749621191930dd_sum(int,int),aTP_Lamp_cm(int,int)),set_or1337092689740270186AtMost(int,M,N)) = aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,aa(int,fun(int,int),times_times(int),N),aa(int,int,aa(int,fun(int,int),plus_plus(int),N),one_one(int)))),aa(int,int,aa(int,fun(int,int),times_times(int),M),aa(int,int,aa(int,fun(int,int),minus_minus(int),M),one_one(int))))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))) ) ) ).

% Sum_Icc_int
tff(fact_1187_Heap__Time__Monad_Obind__def,axiom,
    ! [B: $tType,C: $tType,F: heap_Time_Heap(C),G: fun(C,heap_Time_Heap(B))] : heap_Time_bind(C,B,F,G) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aa(fun(C,heap_Time_Heap(B)),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_cn(heap_Time_Heap(C),fun(fun(C,heap_Time_Heap(B)),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),F),G)) ).

% Heap_Time_Monad.bind_def
tff(fact_1188_zless__iff__Suc__zadd,axiom,
    ! [W: int,Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),W),Z2)
    <=> ? [N7: nat] : Z2 = aa(int,int,aa(int,fun(int,int),plus_plus(int),W),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,suc,N7))) ) ).

% zless_iff_Suc_zadd
tff(fact_1189_int__ops_I4_J,axiom,
    ! [A3: nat] : aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,suc,A3)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),A3)),one_one(int)) ).

% int_ops(4)
tff(fact_1190_int__Suc,axiom,
    ! [N: nat] : aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,suc,N)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),N)),one_one(int)) ).

% int_Suc
tff(fact_1191_int__bit__induct,axiom,
    ! [P: fun(int,$o),K: int] :
      ( aa(int,$o,P,zero_zero(int))
     => ( aa(int,$o,P,aa(int,int,uminus_uminus(int),one_one(int)))
       => ( ! [K3: int] :
              ( aa(int,$o,P,K3)
             => ( ( K3 != zero_zero(int) )
               => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),times_times(int),K3),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))) ) )
         => ( ! [K3: int] :
                ( aa(int,$o,P,K3)
               => ( ( K3 != aa(int,int,uminus_uminus(int),one_one(int)) )
                 => aa(int,$o,P,aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),K3),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))) ) )
           => aa(int,$o,P,K) ) ) ) ) ).

% int_bit_induct
tff(fact_1192_uminus__numeral__One,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),one2)) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% uminus_numeral_One
tff(fact_1193_int__def,axiom,
    ! [N: nat] : aa(nat,int,semiring_1_of_nat(int),N) = aa(product_prod(nat,nat),int,abs_Integ,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),N),zero_zero(nat))) ).

% int_def
tff(fact_1194_num__of__nat__One,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),one_one(nat))
     => ( aa(nat,num,num_of_nat,N) = one2 ) ) ).

% num_of_nat_One
tff(fact_1195_neg__zdiv__mult__2,axiom,
    ! [A3: int,B2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),A3),zero_zero(int))
     => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),B2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),A3)) = aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),B2),one_one(int))),A3) ) ) ).

% neg_zdiv_mult_2
tff(fact_1196_pos__zdiv__mult__2,axiom,
    ! [A3: int,B2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),A3)
     => ( aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),B2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),A3)) = aa(int,int,aa(int,fun(int,int),divide_divide(int),B2),A3) ) ) ).

% pos_zdiv_mult_2
tff(fact_1197_pos__zmod__mult__2,axiom,
    ! [A3: int,B2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),A3)
     => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),B2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),A3)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),B2),A3))) ) ) ).

% pos_zmod_mult_2
tff(fact_1198_mod__mult2__eq_H,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [A3: B,M: nat,N: nat] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),M)),aa(nat,B,semiring_1_of_nat(B),N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),M)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(nat,B,semiring_1_of_nat(B),M))),aa(nat,B,semiring_1_of_nat(B),N)))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(nat,B,semiring_1_of_nat(B),M))) ) ).

% mod_mult2_eq'
tff(fact_1199_numeral__num__of__nat__unfold,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [N: nat] :
          aa(num,B,numeral_numeral(B),aa(nat,num,num_of_nat,N)) = $ite(N = zero_zero(nat),one_one(B),aa(nat,B,semiring_1_of_nat(B),N)) ) ).

% numeral_num_of_nat_unfold
tff(fact_1200_double__arith__series,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,D3: B,N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aTP_Lamp_co(B,fun(B,fun(nat,B)),A3),D3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),A3)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),D3))) ) ).

% double_arith_series
tff(fact_1201_double__gauss__sum,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),semiring_1_of_nat(B)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B))) ) ).

% double_gauss_sum
tff(fact_1202_neg__zmod__mult__2,axiom,
    ! [A3: int,B2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),A3),zero_zero(int))
     => ( aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),B2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),A3)) = aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),B2),one_one(int))),A3))),one_one(int)) ) ) ).

% neg_zmod_mult_2
tff(fact_1203_mult__2,axiom,
    ! [B: $tType] :
      ( semiring_numeral(B)
     => ! [Z2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Z2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),Z2) ) ).

% mult_2
tff(fact_1204_mult__2__right,axiom,
    ! [B: $tType] :
      ( semiring_numeral(B)
     => ! [Z2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),Z2),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),Z2) ) ).

% mult_2_right
tff(fact_1205_left__add__twice,axiom,
    ! [B: $tType] :
      ( semiring_numeral(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),A3)),B2) ) ).

% left_add_twice
tff(fact_1206_pos__eucl__rel__int__mult__2,axiom,
    ! [B2: int,A3: int,Q3: int,R: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),B2)
     => ( eucl_rel_int(A3,B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
       => eucl_rel_int(aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),A3)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),B2),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),R)))) ) ) ).

% pos_eucl_rel_int_mult_2
tff(fact_1207_one__power2,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),one_one(B)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = one_one(B) ) ) ).

% one_power2
tff(fact_1208_nat__1__add__1,axiom,
    aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),one_one(nat)) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) ).

% nat_1_add_1
tff(fact_1209_Suc__nat__number__of__add,axiom,
    ! [V: num,N: nat] : aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),V)),N)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,aa(num,fun(num,num),plus_plus(num),V),one2))),N) ).

% Suc_nat_number_of_add
tff(fact_1210_double__gauss__sum__from__Suc__0,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),semiring_1_of_nat(B)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B))) ) ).

% double_gauss_sum_from_Suc_0
tff(fact_1211_arith__series,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [A3: B,D3: B,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aTP_Lamp_cp(B,fun(B,fun(nat,B)),A3),D3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),A3)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),D3)))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ).

% arith_series
tff(fact_1212_gauss__sum,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),semiring_1_of_nat(B)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B)))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ).

% gauss_sum
tff(fact_1213_nat__approx__posE,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [E2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),E2)
         => ~ ! [N3: nat] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,N3)))),E2) ) ) ).

% nat_approx_posE
tff(fact_1214_neg__eucl__rel__int__mult__2,axiom,
    ! [B2: int,A3: int,Q3: int,R: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),B2),zero_zero(int))
     => ( eucl_rel_int(aa(int,int,aa(int,fun(int,int),plus_plus(int),A3),one_one(int)),B2,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R))
       => eucl_rel_int(aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),A3)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),B2),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),R)),one_one(int)))) ) ) ).

% neg_eucl_rel_int_mult_2
tff(fact_1215_gauss__sum__from__Suc__0,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),semiring_1_of_nat(B)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B)))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ).

% gauss_sum_from_Suc_0
tff(fact_1216_exp__add__not__zero__imp__right,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [M: nat,N: nat] :
          ( ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) != zero_zero(B) )
         => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N) != zero_zero(B) ) ) ) ).

% exp_add_not_zero_imp_right
tff(fact_1217_exp__add__not__zero__imp__left,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [M: nat,N: nat] :
          ( ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) != zero_zero(B) )
         => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M) != zero_zero(B) ) ) ) ).

% exp_add_not_zero_imp_left
tff(fact_1218_sum__power2__eq__zero__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) = zero_zero(B) )
        <=> ( ( X2 = zero_zero(B) )
            & ( Y = zero_zero(B) ) ) ) ) ).

% sum_power2_eq_zero_iff
tff(fact_1219_div__exp__eq,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,M: nat,N: nat] : aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N))) ) ).

% div_exp_eq
tff(fact_1220_power2__eq__1__iff,axiom,
    ! [B: $tType] :
      ( ring_15535105094025558882visors(B)
     => ! [A3: B] :
          ( ( aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = one_one(B) )
        <=> ( ( A3 = one_one(B) )
            | ( A3 = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ) ) ).

% power2_eq_1_iff
tff(fact_1221_plus__int_Oabs__eq,axiom,
    ! [Xa: product_prod(nat,nat),X2: product_prod(nat,nat)] : aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(product_prod(nat,nat),int,abs_Integ,Xa)),aa(product_prod(nat,nat),int,abs_Integ,X2)) = aa(product_prod(nat,nat),int,abs_Integ,aa(product_prod(nat,nat),product_prod(nat,nat),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cr(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat))))),Xa),X2)) ).

% plus_int.abs_eq
tff(fact_1222_abs__square__eq__1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          ( ( aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = one_one(B) )
        <=> ( aa(B,B,abs_abs(B),X2) = one_one(B) ) ) ) ).

% abs_square_eq_1
tff(fact_1223_minus__int_Oabs__eq,axiom,
    ! [Xa: product_prod(nat,nat),X2: product_prod(nat,nat)] : aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(product_prod(nat,nat),int,abs_Integ,Xa)),aa(product_prod(nat,nat),int,abs_Integ,X2)) = aa(product_prod(nat,nat),int,abs_Integ,aa(product_prod(nat,nat),product_prod(nat,nat),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_ct(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat))))),Xa),X2)) ).

% minus_int.abs_eq
tff(fact_1224_nat__induct2,axiom,
    ! [P: fun(nat,$o),N: nat] :
      ( aa(nat,$o,P,zero_zero(nat))
     => ( aa(nat,$o,P,one_one(nat))
       => ( ! [N3: nat] :
              ( aa(nat,$o,P,N3)
             => aa(nat,$o,P,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N3),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) )
         => aa(nat,$o,P,N) ) ) ) ).

% nat_induct2
tff(fact_1225_times__int_Oabs__eq,axiom,
    ! [Xa: product_prod(nat,nat),X2: product_prod(nat,nat)] : aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(nat,nat),int,abs_Integ,Xa)),aa(product_prod(nat,nat),int,abs_Integ,X2)) = aa(product_prod(nat,nat),int,abs_Integ,aa(product_prod(nat,nat),product_prod(nat,nat),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cv(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat))))),Xa),X2)) ).

% times_int.abs_eq
tff(fact_1226_sum__power2__le__zero__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),zero_zero(B))
        <=> ( ( X2 = zero_zero(B) )
            & ( Y = zero_zero(B) ) ) ) ) ).

% sum_power2_le_zero_iff
tff(fact_1227_sum__power2__ge__zero,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))) ) ).

% sum_power2_ge_zero
tff(fact_1228_bits__stable__imp__add__self,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = A3 )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))) = zero_zero(B) ) ) ) ).

% bits_stable_imp_add_self
tff(fact_1229_not__sum__power2__lt__zero,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] : ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),zero_zero(B)) ) ).

% not_sum_power2_lt_zero
tff(fact_1230_sum__power2__gt__zero__iff,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))))
        <=> ( ( X2 != zero_zero(B) )
            | ( Y != zero_zero(B) ) ) ) ) ).

% sum_power2_gt_zero_iff
tff(fact_1231_power2__sum,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [X2: B,Y: B] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),X2)),Y)) ) ).

% power2_sum
tff(fact_1232_square__le__1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,uminus_uminus(B),one_one(B))),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),one_one(B)) ) ) ) ).

% square_le_1
tff(fact_1233_abs__square__le__1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),one_one(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),X2)),one_one(B)) ) ) ).

% abs_square_le_1
tff(fact_1234_abs__square__less__1,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),one_one(B))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),X2)),one_one(B)) ) ) ).

% abs_square_less_1
tff(fact_1235_div__exp__mod__exp__eq,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat,M: nat] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) ) ).

% div_exp_mod_exp_eq
tff(fact_1236_ex__power__ivl2,axiom,
    ! [B2: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),B2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),K)
       => ? [N3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),B2),N3)),K)
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),B2),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N3),one_one(nat)))) ) ) ) ).

% ex_power_ivl2
tff(fact_1237_ex__power__ivl1,axiom,
    ! [B2: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),B2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),K)
       => ? [N3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),B2),N3)),K)
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),B2),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N3),one_one(nat)))) ) ) ) ).

% ex_power_ivl1
tff(fact_1238_power2__diff,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [X2: B,Y: B] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Y)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),X2)),Y)) ) ).

% power2_diff
tff(fact_1239_power__minus1__odd,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% power_minus1_odd
tff(fact_1240_mask__eq__sum__exp,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)),one_one(B)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(fun(nat,$o),set(nat),collect(nat),aTP_Lamp_cw(nat,fun(nat,$o),N))) ) ).

% mask_eq_sum_exp
tff(fact_1241_sum_Oin__pairs,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),M),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_cx(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% sum.in_pairs
tff(fact_1242_gauss__sum__nat,axiom,
    ! [N: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_bz(nat,nat)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,suc,N))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) ).

% gauss_sum_nat
tff(fact_1243_divmod__step__eq,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [L: num,Q3: B,R: B] :
          unique1321980374590559556d_step(B,L,aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),R)) = $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(num,B,numeral_numeral(B),L)),R),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Q3)),one_one(B))),aa(B,B,aa(B,fun(B,B),minus_minus(B),R),aa(num,B,numeral_numeral(B),L))),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Q3)),R)) ) ).

% divmod_step_eq
tff(fact_1244_divmod__step__def,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [L: num,Qr: product_prod(B,B)] : unique1321980374590559556d_step(B,L,Qr) = aa(product_prod(B,B),product_prod(B,B),aa(fun(B,fun(B,product_prod(B,B))),fun(product_prod(B,B),product_prod(B,B)),product_case_prod(B,B,product_prod(B,B)),aTP_Lamp_cy(num,fun(B,fun(B,product_prod(B,B))),L)),Qr) ) ).

% divmod_step_def
tff(fact_1245_divmod__step__nat__def,axiom,
    ! [L: num,Qr: product_prod(nat,nat)] : unique1321980374590559556d_step(nat,L,Qr) = aa(product_prod(nat,nat),product_prod(nat,nat),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_cz(num,fun(nat,fun(nat,product_prod(nat,nat))),L)),Qr) ).

% divmod_step_nat_def
tff(fact_1246_divmod__step__int__def,axiom,
    ! [L: num,Qr: product_prod(int,int)] : unique1321980374590559556d_step(int,L,Qr) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_da(num,fun(int,fun(int,product_prod(int,int))),L)),Qr) ).

% divmod_step_int_def
tff(fact_1247_set__bit__0,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se5668285175392031749et_bit(B),zero_zero(nat)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))) ) ).

% set_bit_0
tff(fact_1248_mlex__eq,axiom,
    ! [B: $tType,F: fun(B,nat),R4: set(product_prod(B,B))] : mlex_prod(B,F,R4) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aTP_Lamp_db(fun(B,nat),fun(set(product_prod(B,B)),fun(B,fun(B,$o))),F),R4))) ).

% mlex_eq
tff(fact_1249_unset__bit__Suc,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se2638667681897837118et_bit(B),aa(nat,nat,suc,N)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(nat,fun(B,B),bit_se2638667681897837118et_bit(B),N),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))))) ) ).

% unset_bit_Suc
tff(fact_1250_flip__bit__Suc,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se8732182000553998342ip_bit(B),aa(nat,nat,suc,N)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(nat,fun(B,B),bit_se8732182000553998342ip_bit(B),N),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))))) ) ).

% flip_bit_Suc
tff(fact_1251_set__bit__Suc,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se5668285175392031749et_bit(B),aa(nat,nat,suc,N)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(nat,fun(B,B),bit_se5668285175392031749et_bit(B),N),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))))) ) ).

% set_bit_Suc
tff(fact_1252_split__part,axiom,
    ! [C: $tType,B: $tType,P: $o,Q: fun(B,fun(C,$o)),X: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aTP_Lamp_dc($o,fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),(P)),Q)),X)
    <=> ( (P)
        & aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),Q),X) ) ) ).

% split_part
tff(fact_1253_prod_Odisc__eq__case,axiom,
    ! [C: $tType,B: $tType,Prod: product_prod(B,C)] : aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_dd(B,fun(C,$o))),Prod) ).

% prod.disc_eq_case
tff(fact_1254_divmod__step__integer__def,axiom,
    ! [L: num,Qr: product_prod(code_integer,code_integer)] : unique1321980374590559556d_step(code_integer,L,Qr) = aa(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer),aa(fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),product_case_prod(code_integer,code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_de(num,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),L)),Qr) ).

% divmod_step_integer_def
tff(fact_1255_signed__take__bit__rec,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat,A3: B] :
          bit_ri4674362597316999326ke_bit(B,N,A3) = $ite(N = zero_zero(nat),aa(B,B,uminus_uminus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),bit_ri4674362597316999326ke_bit(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))))) ) ).

% signed_take_bit_rec
tff(fact_1256_round__unique,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,Y: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))),aa(int,B,ring_1_of_int(B),Y))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),Y)),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))))
           => ( archimedean_round(B,X2) = Y ) ) ) ) ).

% round_unique
tff(fact_1257_rel__of__def,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),P: fun(product_prod(B,C),$o)] : rel_of(B,C,M,P) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(fun(product_prod(B,C),$o),fun(B,fun(C,$o)),aTP_Lamp_df(fun(B,option(C)),fun(fun(product_prod(B,C),$o),fun(B,fun(C,$o))),M),P))) ).

% rel_of_def
tff(fact_1258_dbl__simps_I4_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl(B,aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ) ).

% dbl_simps(4)
tff(fact_1259_round__altdef,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] :
          archimedean_round(B,X2) = $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),archimedean_frac(B,X2)),archimedean_ceiling(B,X2),archim6421214686448440834_floor(B,X2)) ) ).

% round_altdef
tff(fact_1260_round__unique_H,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B,N: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),aa(int,B,ring_1_of_int(B),N)))),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))
         => ( archimedean_round(B,X2) = N ) ) ) ).

% round_unique'
tff(fact_1261_of__int__round__abs__le,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,abs_abs(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(int,B,ring_1_of_int(B),archimedean_round(B,X2))),X2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))) ) ).

% of_int_round_abs_le
tff(fact_1262_divmod__algorithm__code_I5_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num,N: num] : unique8689654367752047608divmod(B,aa(num,num,bit0,M),aa(num,num,bit0,N)) = aa(product_prod(B,B),product_prod(B,B),aa(fun(B,fun(B,product_prod(B,B))),fun(product_prod(B,B),product_prod(B,B)),product_case_prod(B,B,product_prod(B,B)),aTP_Lamp_dg(B,fun(B,product_prod(B,B)))),unique8689654367752047608divmod(B,M,N)) ) ).

% divmod_algorithm_code(5)
tff(fact_1263_signed__take__bit__of__minus__1,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat] : bit_ri4674362597316999326ke_bit(B,N,aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% signed_take_bit_of_minus_1
tff(fact_1264_signed__take__bit__Suc__1,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat] : bit_ri4674362597316999326ke_bit(B,aa(nat,nat,suc,N),one_one(B)) = one_one(B) ) ).

% signed_take_bit_Suc_1
tff(fact_1265_signed__take__bit__numeral__of__1,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [K: num] : bit_ri4674362597316999326ke_bit(B,aa(num,nat,numeral_numeral(nat),K),one_one(B)) = one_one(B) ) ).

% signed_take_bit_numeral_of_1
tff(fact_1266_round__1,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ( archimedean_round(B,one_one(B)) = one_one(int) ) ) ).

% round_1
tff(fact_1267_divmod__algorithm__code_I2_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num] : unique8689654367752047608divmod(B,M,one2) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(num,B,numeral_numeral(B),M)),zero_zero(B)) ) ).

% divmod_algorithm_code(2)
tff(fact_1268_dbl__simps_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl(B,one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)) ) ) ).

% dbl_simps(3)
tff(fact_1269_divmod__algorithm__code_I3_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [N: num] : unique8689654367752047608divmod(B,one2,aa(num,num,bit0,N)) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),zero_zero(B)),aa(num,B,numeral_numeral(B),one2)) ) ).

% divmod_algorithm_code(3)
tff(fact_1270_less__eq__integer__code_I1_J,axiom,
    aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),zero_zero(code_integer)),zero_zero(code_integer)) ).

% less_eq_integer_code(1)
tff(fact_1271_sgn__integer__code,axiom,
    ! [K: code_integer] :
      aa(code_integer,code_integer,sgn_sgn(code_integer),K) = $ite(
        K = zero_zero(code_integer),
        zero_zero(code_integer),
        $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),K),zero_zero(code_integer)),aa(code_integer,code_integer,uminus_uminus(code_integer),one_one(code_integer)),one_one(code_integer)) ) ).

% sgn_integer_code
tff(fact_1272_exhaustive__integer_H_Ocases,axiom,
    ! [X2: product_prod(fun(code_integer,option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer))] :
      ~ ! [F3: fun(code_integer,option(product_prod($o,list(code_term)))),D2: code_integer,I2: code_integer] : X2 != aa(product_prod(code_integer,code_integer),product_prod(fun(code_integer,option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer)),aa(fun(code_integer,option(product_prod($o,list(code_term)))),fun(product_prod(code_integer,code_integer),product_prod(fun(code_integer,option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer))),product_Pair(fun(code_integer,option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer)),F3),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),D2),I2)) ).

% exhaustive_integer'.cases
tff(fact_1273_full__exhaustive__integer_H_Ocases,axiom,
    ! [X2: product_prod(fun(product_prod(code_integer,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer))] :
      ~ ! [F3: fun(product_prod(code_integer,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),D2: code_integer,I2: code_integer] : X2 != aa(product_prod(code_integer,code_integer),product_prod(fun(product_prod(code_integer,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer)),aa(fun(product_prod(code_integer,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),fun(product_prod(code_integer,code_integer),product_prod(fun(product_prod(code_integer,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer))),product_Pair(fun(product_prod(code_integer,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_integer,code_integer)),F3),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),D2),I2)) ).

% full_exhaustive_integer'.cases
tff(fact_1274_times__integer__code_I1_J,axiom,
    ! [K: code_integer] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),K),zero_zero(code_integer)) = zero_zero(code_integer) ).

% times_integer_code(1)
tff(fact_1275_times__integer__code_I2_J,axiom,
    ! [L: code_integer] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),zero_zero(code_integer)),L) = zero_zero(code_integer) ).

% times_integer_code(2)
tff(fact_1276_minus__integer__code_I1_J,axiom,
    ! [K: code_integer] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),K),zero_zero(code_integer)) = K ).

% minus_integer_code(1)
tff(fact_1277_plus__integer__code_I2_J,axiom,
    ! [L: code_integer] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),zero_zero(code_integer)),L) = L ).

% plus_integer_code(2)
tff(fact_1278_plus__integer__code_I1_J,axiom,
    ! [K: code_integer] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),K),zero_zero(code_integer)) = K ).

% plus_integer_code(1)
tff(fact_1279_minus__integer__code_I2_J,axiom,
    ! [L: code_integer] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),zero_zero(code_integer)),L) = aa(code_integer,code_integer,uminus_uminus(code_integer),L) ).

% minus_integer_code(2)
tff(fact_1280_divmod__integer_H__def,axiom,
    ! [M: num,N: num] : unique8689654367752047608divmod(code_integer,M,N) = aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),aa(num,code_integer,numeral_numeral(code_integer),M)),aa(num,code_integer,numeral_numeral(code_integer),N))),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),aa(num,code_integer,numeral_numeral(code_integer),M)),aa(num,code_integer,numeral_numeral(code_integer),N))) ).

% divmod_integer'_def
tff(fact_1281_signed__take__bit__add,axiom,
    ! [N: nat,K: int,L: int] : bit_ri4674362597316999326ke_bit(int,N,aa(int,int,aa(int,fun(int,int),plus_plus(int),bit_ri4674362597316999326ke_bit(int,N,K)),bit_ri4674362597316999326ke_bit(int,N,L))) = bit_ri4674362597316999326ke_bit(int,N,aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)) ).

% signed_take_bit_add
tff(fact_1282_dbl__def,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [X2: B] : neg_numeral_dbl(B,X2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),X2) ) ).

% dbl_def
tff(fact_1283_divmod__int__def,axiom,
    ! [M: num,N: num] : unique8689654367752047608divmod(int,M,N) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(num,int,numeral_numeral(int),M)),aa(num,int,numeral_numeral(int),N))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(num,int,numeral_numeral(int),M)),aa(num,int,numeral_numeral(int),N))) ).

% divmod_int_def
tff(fact_1284_divmod__def,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num,N: num] : unique8689654367752047608divmod(B,M,N) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(num,B,numeral_numeral(B),M)),aa(num,B,numeral_numeral(B),N))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(num,B,numeral_numeral(B),M)),aa(num,B,numeral_numeral(B),N))) ) ).

% divmod_def
tff(fact_1285_divmod_H__nat__def,axiom,
    ! [M: num,N: num] : unique8689654367752047608divmod(nat,M,N) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(num,nat,numeral_numeral(nat),M)),aa(num,nat,numeral_numeral(nat),N))),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(num,nat,numeral_numeral(nat),M)),aa(num,nat,numeral_numeral(nat),N))) ).

% divmod'_nat_def
tff(fact_1286_signed__take__bit__int__greater__eq,axiom,
    ! [K: int,N: nat] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),aa(int,int,uminus_uminus(int),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N)))
     => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(nat,nat,suc,N)))),bit_ri4674362597316999326ke_bit(int,N,K)) ) ).

% signed_take_bit_int_greater_eq
tff(fact_1287_divmod__divmod__step,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num,N: num] :
          unique8689654367752047608divmod(B,M,N) = $ite(aa(num,$o,aa(num,fun(num,$o),ord_less(num),M),N),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),zero_zero(B)),aa(num,B,numeral_numeral(B),M)),unique1321980374590559556d_step(B,N,unique8689654367752047608divmod(B,M,aa(num,num,bit0,N)))) ) ).

% divmod_divmod_step
tff(fact_1288_round__def,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : archimedean_round(B,X2) = archim6421214686448440834_floor(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))) ) ).

% round_def
tff(fact_1289_signed__take__bit__Suc,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat,A3: B] : bit_ri4674362597316999326ke_bit(B,aa(nat,nat,suc,N),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),bit_ri4674362597316999326ke_bit(B,N,aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))))) ) ).

% signed_take_bit_Suc
tff(fact_1290_of__int__round__le,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(int,B,ring_1_of_int(B),archimedean_round(B,X2))),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))) ) ).

% of_int_round_le
tff(fact_1291_of__int__round__ge,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))),aa(int,B,ring_1_of_int(B),archimedean_round(B,X2))) ) ).

% of_int_round_ge
tff(fact_1292_of__int__round__gt,axiom,
    ! [B: $tType] :
      ( archim2362893244070406136eiling(B)
     => ! [X2: B] : aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))),aa(int,B,ring_1_of_int(B),archimedean_round(B,X2))) ) ).

% of_int_round_gt
tff(fact_1293_integer__of__int__code,axiom,
    ! [K: int] :
      aa(int,code_integer,code_integer_of_int,K) = $ite(
        aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),zero_zero(int)),
        aa(code_integer,code_integer,uminus_uminus(code_integer),aa(int,code_integer,code_integer_of_int,aa(int,int,uminus_uminus(int),K))),
        $ite(
          K = zero_zero(int),
          zero_zero(code_integer),
          $let(
            l: code_integer,
            l:= aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))),aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))),
            $ite(aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))) = zero_zero(int),l,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),l),one_one(code_integer))) ) ) ) ).

% integer_of_int_code
tff(fact_1294_divmod__algorithm__code_I6_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num,N: num] : unique8689654367752047608divmod(B,aa(num,num,bit1,M),aa(num,num,bit0,N)) = aa(product_prod(B,B),product_prod(B,B),aa(fun(B,fun(B,product_prod(B,B))),fun(product_prod(B,B),product_prod(B,B)),product_case_prod(B,B,product_prod(B,B)),aTP_Lamp_dh(B,fun(B,product_prod(B,B)))),unique8689654367752047608divmod(B,M,N)) ) ).

% divmod_algorithm_code(6)
tff(fact_1295_of__nat__code,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [N: nat] : aa(nat,B,semiring_1_of_nat(B),N) = semiri8178284476397505188at_aux(B,aTP_Lamp_di(B,B),N,zero_zero(B)) ) ).

% of_nat_code
tff(fact_1296_signed__take__bit__Suc__minus__bit1,axiom,
    ! [N: nat,K: num] : bit_ri4674362597316999326ke_bit(int,aa(nat,nat,suc,N),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,K)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),bit_ri4674362597316999326ke_bit(int,N,aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),K))),one_one(int)))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),one_one(int)) ).

% signed_take_bit_Suc_minus_bit1
tff(fact_1297_concat__bit__Suc,axiom,
    ! [N: nat,K: int,L: int] : bit_concat_bit(aa(nat,nat,suc,N),K,L) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),bit_concat_bit(N,aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),L))) ).

% concat_bit_Suc
tff(fact_1298_even__succ__mod__exp,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),A3)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N))) ) ) ) ) ).

% even_succ_mod_exp
tff(fact_1299_even__succ__div__exp,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
           => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),A3)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) ) ) ) ) ).

% even_succ_div_exp
tff(fact_1300_take__bit__rec,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] :
          aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),A3) = $ite(N = zero_zero(nat),zero_zero(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))) ) ).

% take_bit_rec
tff(fact_1301_nat__dvd__1__iff__1,axiom,
    ! [M: nat] :
      ( dvd_dvd(nat,M,one_one(nat))
    <=> ( M = one_one(nat) ) ) ).

% nat_dvd_1_iff_1
tff(fact_1302_integer__of__int__eq__of__int,axiom,
    code_integer_of_int = ring_1_of_int(code_integer) ).

% integer_of_int_eq_of_int
tff(fact_1303_dvd__add__triv__right__iff,axiom,
    ! [B: $tType] :
      ( comm_s4317794764714335236cancel(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),A3))
        <=> dvd_dvd(B,A3,B2) ) ) ).

% dvd_add_triv_right_iff
tff(fact_1304_dvd__add__triv__left__iff,axiom,
    ! [B: $tType] :
      ( comm_s4317794764714335236cancel(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))
        <=> dvd_dvd(B,A3,B2) ) ) ).

% dvd_add_triv_left_iff
tff(fact_1305_dvd__add__times__triv__right__iff,axiom,
    ! [B: $tType] :
      ( comm_s4317794764714335236cancel(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3)))
        <=> dvd_dvd(B,A3,B2) ) ) ).

% dvd_add_times_triv_right_iff
tff(fact_1306_dvd__add__times__triv__left__iff,axiom,
    ! [B: $tType] :
      ( comm_s4317794764714335236cancel(B)
     => ! [A3: B,C2: B,B2: B] :
          ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3)),B2))
        <=> dvd_dvd(B,A3,B2) ) ) ).

% dvd_add_times_triv_left_iff
tff(fact_1307_unit__prod,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( dvd_dvd(B,B2,one_one(B))
           => dvd_dvd(B,aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2),one_one(B)) ) ) ) ).

% unit_prod
tff(fact_1308_div__add,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [C2: B,A3: B,B2: B] :
          ( dvd_dvd(B,C2,A3)
         => ( dvd_dvd(B,C2,B2)
           => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),C2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2)) ) ) ) ) ).

% div_add
tff(fact_1309_unit__div__1__div__1,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3)) = A3 ) ) ) ).

% unit_div_1_div_1
tff(fact_1310_unit__div__1__unit,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => dvd_dvd(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3),one_one(B)) ) ) ).

% unit_div_1_unit
tff(fact_1311_unit__div,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( dvd_dvd(B,B2,one_one(B))
           => dvd_dvd(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2),one_one(B)) ) ) ) ).

% unit_div
tff(fact_1312_take__bit__Suc__1,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,suc,N)),one_one(B)) = one_one(B) ) ).

% take_bit_Suc_1
tff(fact_1313_take__bit__numeral__1,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [L: num] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(num,nat,numeral_numeral(nat),L)),one_one(B)) = one_one(B) ) ).

% take_bit_numeral_1
tff(fact_1314_semiring__norm_I9_J,axiom,
    ! [M: num,N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,bit1,M)),aa(num,num,bit0,N)) = aa(num,num,bit1,aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% semiring_norm(9)
tff(fact_1315_semiring__norm_I7_J,axiom,
    ! [M: num,N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,bit0,M)),aa(num,num,bit1,N)) = aa(num,num,bit1,aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% semiring_norm(7)
tff(fact_1316_semiring__norm_I16_J,axiom,
    ! [M: num,N: num] : aa(num,num,aa(num,fun(num,num),times_times(num),aa(num,num,bit1,M)),aa(num,num,bit1,N)) = aa(num,num,bit1,aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)),aa(num,num,bit0,aa(num,num,aa(num,fun(num,num),times_times(num),M),N)))) ).

% semiring_norm(16)
tff(fact_1317_unit__mult__div__div,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),B2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3) ) ) ) ).

% unit_mult_div_div
tff(fact_1318_unit__div__mult__self,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),A3) = B2 ) ) ) ).

% unit_div_mult_self
tff(fact_1319_take__bit__of__1__eq__0__iff,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [N: nat] :
          ( ( aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),one_one(B)) = zero_zero(B) )
        <=> ( N = zero_zero(nat) ) ) ) ).

% take_bit_of_1_eq_0_iff
tff(fact_1320_semiring__norm_I10_J,axiom,
    ! [M: num,N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,bit1,M)),aa(num,num,bit1,N)) = aa(num,num,bit0,aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)),one2)) ).

% semiring_norm(10)
tff(fact_1321_semiring__norm_I8_J,axiom,
    ! [M: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,bit1,M)),one2) = aa(num,num,bit0,aa(num,num,aa(num,fun(num,num),plus_plus(num),M),one2)) ).

% semiring_norm(8)
tff(fact_1322_semiring__norm_I5_J,axiom,
    ! [M: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,bit0,M)),one2) = aa(num,num,bit1,M) ).

% semiring_norm(5)
tff(fact_1323_semiring__norm_I4_J,axiom,
    ! [N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),aa(num,num,bit1,N)) = aa(num,num,bit0,aa(num,num,aa(num,fun(num,num),plus_plus(num),N),one2)) ).

% semiring_norm(4)
tff(fact_1324_semiring__norm_I3_J,axiom,
    ! [N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),aa(num,num,bit0,N)) = aa(num,num,bit1,N) ).

% semiring_norm(3)
tff(fact_1325_odd__add,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B,B2: B] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))
        <=> ~ ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
            <=> ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),B2) ) ) ) ).

% odd_add
tff(fact_1326_even__add,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))
        <=> ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
          <=> dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),B2) ) ) ) ).

% even_add
tff(fact_1327_dbl__inc__simps_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl_inc(B,one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,one2)) ) ) ).

% dbl_inc_simps(3)
tff(fact_1328_even__plus__one__iff,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B)))
        <=> ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3) ) ) ).

% even_plus_one_iff
tff(fact_1329_even__diff,axiom,
    ! [B: $tType] :
      ( ring_parity(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2))
        <=> dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ).

% even_diff
tff(fact_1330_neg__one__even__power,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [N: nat] :
          ( dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N)
         => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N) = one_one(B) ) ) ) ).

% neg_one_even_power
tff(fact_1331_neg__one__odd__power,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [N: nat] :
          ( ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N)
         => ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ) ).

% neg_one_odd_power
tff(fact_1332_even__diff__nat,axiom,
    ! [M: nat,N: nat] :
      ( dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),N))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
        | dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) ) ) ).

% even_diff_nat
tff(fact_1333_divmod__algorithm__code_I4_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [N: num] : unique8689654367752047608divmod(B,one2,aa(num,num,bit1,N)) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),zero_zero(B)),aa(num,B,numeral_numeral(B),one2)) ) ).

% divmod_algorithm_code(4)
tff(fact_1334_mod__Suc__eq__mod__add3,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,N)))) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),N)) ).

% mod_Suc_eq_mod_add3
tff(fact_1335_Suc__mod__eq__add3__mod__numeral,axiom,
    ! [M: nat,V: num] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,M)))),aa(num,nat,numeral_numeral(nat),V)) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),M)),aa(num,nat,numeral_numeral(nat),V)) ).

% Suc_mod_eq_add3_mod_numeral
tff(fact_1336_div__Suc__eq__div__add3,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,N)))) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),N)) ).

% div_Suc_eq_div_add3
tff(fact_1337_Suc__div__eq__add3__div__numeral,axiom,
    ! [M: nat,V: num] : aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,M)))),aa(num,nat,numeral_numeral(nat),V)) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),M)),aa(num,nat,numeral_numeral(nat),V)) ).

% Suc_div_eq_add3_div_numeral
tff(fact_1338_dbl__dec__simps_I4_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ( neg_numeral_dbl_dec(B,aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,one2))) ) ) ).

% dbl_dec_simps(4)
tff(fact_1339_even__succ__div__2,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),A3)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ) ) ).

% even_succ_div_2
tff(fact_1340_odd__succ__div__two,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [A3: B] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),one_one(B)) ) ) ) ).

% odd_succ_div_two
tff(fact_1341_even__succ__div__two,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [A3: B] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ) ) ).

% even_succ_div_two
tff(fact_1342_odd__two__times__div__two__nat,axiom,
    ! [N: nat] :
      ( ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)) ) ) ).

% odd_two_times_div_two_nat
tff(fact_1343_odd__two__times__div__two__succ,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [A3: B] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))),one_one(B)) = A3 ) ) ) ).

% odd_two_times_div_two_succ
tff(fact_1344_semiring__parity__class_Oeven__mask__iff,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [N: nat] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)),one_one(B)))
        <=> ( N = zero_zero(nat) ) ) ) ).

% semiring_parity_class.even_mask_iff
tff(fact_1345_zmod__numeral__Bit1,axiom,
    ! [V: num,W: num] : aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,V))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,W))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(num,int,numeral_numeral(int),V)),aa(num,int,numeral_numeral(int),W)))),one_one(int)) ).

% zmod_numeral_Bit1
tff(fact_1346_divmod__algorithm__code_I8_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num,N: num] :
          unique8689654367752047608divmod(B,aa(num,num,bit1,M),aa(num,num,bit1,N)) = $ite(aa(num,$o,aa(num,fun(num,$o),ord_less(num),M),N),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),zero_zero(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit1,M))),unique1321980374590559556d_step(B,aa(num,num,bit1,N),unique8689654367752047608divmod(B,aa(num,num,bit1,M),aa(num,num,bit0,aa(num,num,bit1,N))))) ) ).

% divmod_algorithm_code(8)
tff(fact_1347_divmod__algorithm__code_I7_J,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [M: num,N: num] :
          unique8689654367752047608divmod(B,aa(num,num,bit0,M),aa(num,num,bit1,N)) = $ite(aa(num,$o,aa(num,fun(num,$o),ord_less_eq(num),M),N),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),zero_zero(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,M))),unique1321980374590559556d_step(B,aa(num,num,bit1,N),unique8689654367752047608divmod(B,aa(num,num,bit0,M),aa(num,num,bit0,aa(num,num,bit1,N))))) ) ).

% divmod_algorithm_code(7)
tff(fact_1348_signed__take__bit__Suc__bit1,axiom,
    ! [N: nat,K: num] : bit_ri4674362597316999326ke_bit(int,aa(nat,nat,suc,N),aa(num,int,numeral_numeral(int),aa(num,num,bit1,K))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),bit_ri4674362597316999326ke_bit(int,N,aa(num,int,numeral_numeral(int),K))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),one_one(int)) ).

% signed_take_bit_Suc_bit1
tff(fact_1349_uminus__integer__code_I1_J,axiom,
    aa(code_integer,code_integer,uminus_uminus(code_integer),zero_zero(code_integer)) = zero_zero(code_integer) ).

% uminus_integer_code(1)
tff(fact_1350_take__bit__integer_Oabs__eq,axiom,
    ! [Xa: nat,X2: int] : aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se2584673776208193580ke_bit(code_integer),Xa),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),Xa),X2)) ).

% take_bit_integer.abs_eq
tff(fact_1351_abs__integer__code,axiom,
    ! [K: code_integer] :
      aa(code_integer,code_integer,abs_abs(code_integer),K) = $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),K),zero_zero(code_integer)),aa(code_integer,code_integer,uminus_uminus(code_integer),K),K) ).

% abs_integer_code
tff(fact_1352_less__integer__code_I1_J,axiom,
    ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),zero_zero(code_integer)),zero_zero(code_integer)) ).

% less_integer_code(1)
tff(fact_1353_unset__bit__integer_Oabs__eq,axiom,
    ! [Xa: nat,X2: int] : aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se2638667681897837118et_bit(code_integer),Xa),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(nat,fun(int,int),bit_se2638667681897837118et_bit(int),Xa),X2)) ).

% unset_bit_integer.abs_eq
tff(fact_1354_flip__bit__integer_Oabs__eq,axiom,
    ! [Xa: nat,X2: int] : aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se8732182000553998342ip_bit(code_integer),Xa),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(nat,fun(int,int),bit_se8732182000553998342ip_bit(int),Xa),X2)) ).

% flip_bit_integer.abs_eq
tff(fact_1355_set__bit__integer_Oabs__eq,axiom,
    ! [Xa: nat,X2: int] : aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se5668285175392031749et_bit(code_integer),Xa),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(nat,fun(int,int),bit_se5668285175392031749et_bit(int),Xa),X2)) ).

% set_bit_integer.abs_eq
tff(fact_1356_take__bit__add,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [N: nat,A3: B,B2: B] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),A3)),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),B2))) = aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ).

% take_bit_add
tff(fact_1357_zero__integer__def,axiom,
    zero_zero(code_integer) = aa(int,code_integer,code_integer_of_int,zero_zero(int)) ).

% zero_integer_def
tff(fact_1358_less__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2))
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),Xa),X2) ) ).

% less_integer.abs_eq
tff(fact_1359_uminus__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_integer,uminus_uminus(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,uminus_uminus(int),X2)) ).

% uminus_integer.abs_eq
tff(fact_1360_abs__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_integer,abs_abs(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,abs_abs(int),X2)) ).

% abs_integer.abs_eq
tff(fact_1361_dvd__add__right__iff,axiom,
    ! [B: $tType] :
      ( comm_s4317794764714335236cancel(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,B2)
         => ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2))
          <=> dvd_dvd(B,A3,C2) ) ) ) ).

% dvd_add_right_iff
tff(fact_1362_dvd__add__left__iff,axiom,
    ! [B: $tType] :
      ( comm_s4317794764714335236cancel(B)
     => ! [A3: B,C2: B,B2: B] :
          ( dvd_dvd(B,A3,C2)
         => ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2))
          <=> dvd_dvd(B,A3,B2) ) ) ) ).

% dvd_add_left_iff
tff(fact_1363_dvd__add,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,B2)
         => ( dvd_dvd(B,A3,C2)
           => dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),B2),C2)) ) ) ) ).

% dvd_add
tff(fact_1364_divide__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),divide_divide(int),Xa),X2)) ).

% divide_integer.abs_eq
tff(fact_1365_dvd__unit__imp__unit,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,B2)
         => ( dvd_dvd(B,B2,one_one(B))
           => dvd_dvd(B,A3,one_one(B)) ) ) ) ).

% dvd_unit_imp_unit
tff(fact_1366_unit__imp__dvd,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => dvd_dvd(B,B2,A3) ) ) ).

% unit_imp_dvd
tff(fact_1367_one__dvd,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A3: B] : dvd_dvd(B,one_one(B),A3) ) ).

% one_dvd
tff(fact_1368_modulo__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),modulo_modulo(int),Xa),X2)) ).

% modulo_integer.abs_eq
tff(fact_1369_sgn__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_integer,sgn_sgn(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,sgn_sgn(int),X2)) ).

% sgn_integer.abs_eq
tff(fact_1370_concat__bit__assoc,axiom,
    ! [N: nat,K: int,M: nat,L: int,R: int] : bit_concat_bit(N,K,bit_concat_bit(M,L,R)) = bit_concat_bit(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),bit_concat_bit(N,K,L),R) ).

% concat_bit_assoc
tff(fact_1371_not__is__unit__0,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ~ dvd_dvd(B,zero_zero(B),one_one(B)) ) ).

% not_is_unit_0
tff(fact_1372_pinf_I9_J,axiom,
    ! [B: $tType] :
      ( ( plus(B)
        & linorder(B)
        & dvd(B) )
     => ! [D3: B,S: B] :
        ? [Z3: B] :
        ! [X: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),Z3),X)
         => ( dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S))
          <=> dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S)) ) ) ) ).

% pinf(9)
tff(fact_1373_pinf_I10_J,axiom,
    ! [B: $tType] :
      ( ( plus(B)
        & linorder(B)
        & dvd(B) )
     => ! [D3: B,S: B] :
        ? [Z3: B] :
        ! [X: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),Z3),X)
         => ( ~ dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S))
          <=> ~ dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S)) ) ) ) ).

% pinf(10)
tff(fact_1374_minf_I9_J,axiom,
    ! [B: $tType] :
      ( ( plus(B)
        & linorder(B)
        & dvd(B) )
     => ! [D3: B,S: B] :
        ? [Z3: B] :
        ! [X: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X),Z3)
         => ( dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S))
          <=> dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S)) ) ) ) ).

% minf(9)
tff(fact_1375_minf_I10_J,axiom,
    ! [B: $tType] :
      ( ( plus(B)
        & linorder(B)
        & dvd(B) )
     => ! [D3: B,S: B] :
        ? [Z3: B] :
        ! [X: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X),Z3)
         => ( ~ dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S))
          <=> ~ dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),S)) ) ) ) ).

% minf(10)
tff(fact_1376_unit__mult__right__cancel,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( ( aa(B,B,aa(B,fun(B,B),times_times(B),B2),A3) = aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3) )
          <=> ( B2 = C2 ) ) ) ) ).

% unit_mult_right_cancel
tff(fact_1377_unit__mult__left__cancel,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2) )
          <=> ( B2 = C2 ) ) ) ) ).

% unit_mult_left_cancel
tff(fact_1378_mult__unit__dvd__iff_H,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( dvd_dvd(B,aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2),C2)
          <=> dvd_dvd(B,B2,C2) ) ) ) ).

% mult_unit_dvd_iff'
tff(fact_1379_dvd__mult__unit__iff_H,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2))
          <=> dvd_dvd(B,A3,C2) ) ) ) ).

% dvd_mult_unit_iff'
tff(fact_1380_mult__unit__dvd__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( dvd_dvd(B,aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2),C2)
          <=> dvd_dvd(B,A3,C2) ) ) ) ).

% mult_unit_dvd_iff
tff(fact_1381_dvd__mult__unit__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2))
          <=> dvd_dvd(B,A3,C2) ) ) ) ).

% dvd_mult_unit_iff
tff(fact_1382_is__unit__mult__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2),one_one(B))
        <=> ( dvd_dvd(B,A3,one_one(B))
            & dvd_dvd(B,B2,one_one(B)) ) ) ) ).

% is_unit_mult_iff
tff(fact_1383_div__plus__div__distrib__dvd__left,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [C2: B,A3: B,B2: B] :
          ( dvd_dvd(B,C2,A3)
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),C2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2)) ) ) ) ).

% div_plus_div_distrib_dvd_left
tff(fact_1384_div__plus__div__distrib__dvd__right,axiom,
    ! [B: $tType] :
      ( euclid4440199948858584721cancel(B)
     => ! [C2: B,B2: B,A3: B] :
          ( dvd_dvd(B,C2,B2)
         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),C2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2)) ) ) ) ).

% div_plus_div_distrib_dvd_right
tff(fact_1385_unit__div__cancel,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3) = aa(B,B,aa(B,fun(B,B),divide_divide(B),C2),A3) )
          <=> ( B2 = C2 ) ) ) ) ).

% unit_div_cancel
tff(fact_1386_div__unit__dvd__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( dvd_dvd(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2),C2)
          <=> dvd_dvd(B,A3,C2) ) ) ) ).

% div_unit_dvd_iff
tff(fact_1387_dvd__div__unit__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( dvd_dvd(B,A3,aa(B,B,aa(B,fun(B,B),divide_divide(B),C2),B2))
          <=> dvd_dvd(B,A3,C2) ) ) ) ).

% dvd_div_unit_iff
tff(fact_1388_xor__num_Ocases,axiom,
    ! [X2: product_prod(num,num)] :
      ( ( X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),one2) )
     => ( ! [N3: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit0,N3))
       => ( ! [N3: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit1,N3))
         => ( ! [M4: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),one2)
           => ( ! [M4: num,N3: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit0,N3))
             => ( ! [M4: num,N3: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit1,N3))
               => ( ! [M4: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),one2)
                 => ( ! [M4: num,N3: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit0,N3))
                   => ~ ! [M4: num,N3: num] : X2 != aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit1,N3)) ) ) ) ) ) ) ) ) ).

% xor_num.cases
tff(fact_1389_plus__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),plus_plus(int),Xa),X2)) ).

% plus_integer.abs_eq
tff(fact_1390_bezout__lemma__nat,axiom,
    ! [D3: nat,A3: nat,B2: nat,X2: nat,Y: nat] :
      ( dvd_dvd(nat,D3,A3)
     => ( dvd_dvd(nat,D3,B2)
       => ( ( ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),X2) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),B2),Y)),D3) )
            | ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),B2),X2) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),Y)),D3) ) )
         => ? [X3: nat,Y4: nat] :
              ( dvd_dvd(nat,D3,A3)
              & dvd_dvd(nat,D3,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2))
              & ( ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),X3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2)),Y4)),D3) )
                | ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2)),X3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),Y4)),D3) ) ) ) ) ) ) ).

% bezout_lemma_nat
tff(fact_1391_bezout__add__nat,axiom,
    ! [A3: nat,B2: nat] :
    ? [D2: nat,X3: nat,Y4: nat] :
      ( dvd_dvd(nat,D2,A3)
      & dvd_dvd(nat,D2,B2)
      & ( ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),X3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),B2),Y4)),D2) )
        | ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),B2),X3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),Y4)),D2) ) ) ) ).

% bezout_add_nat
tff(fact_1392_one__integer__def,axiom,
    one_one(code_integer) = aa(int,code_integer,code_integer_of_int,one_one(int)) ).

% one_integer_def
tff(fact_1393_less__eq__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2))
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),Xa),X2) ) ).

% less_eq_integer.abs_eq
tff(fact_1394_times__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),times_times(int),Xa),X2)) ).

% times_integer.abs_eq
tff(fact_1395_zdvd__period,axiom,
    ! [A3: int,D3: int,X2: int,T2: int,C2: int] :
      ( dvd_dvd(int,A3,D3)
     => ( dvd_dvd(int,A3,aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),T2))
      <=> dvd_dvd(int,A3,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),aa(int,int,aa(int,fun(int,int),times_times(int),C2),D3))),T2)) ) ) ).

% zdvd_period
tff(fact_1396_zdvd__reduce,axiom,
    ! [K: int,N: int,M: int] :
      ( dvd_dvd(int,K,aa(int,int,aa(int,fun(int,int),plus_plus(int),N),aa(int,int,aa(int,fun(int,int),times_times(int),K),M)))
    <=> dvd_dvd(int,K,N) ) ).

% zdvd_reduce
tff(fact_1397_minus__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),minus_minus(int),Xa),X2)) ).

% minus_integer.abs_eq
tff(fact_1398_unity__coeff__ex,axiom,
    ! [B: $tType] :
      ( ( dvd(B)
        & semiring_0(B) )
     => ! [P: fun(B,$o),L: B] :
          ( ? [X4: B] : aa(B,$o,P,aa(B,B,aa(B,fun(B,B),times_times(B),L),X4))
        <=> ? [X4: B] :
              ( dvd_dvd(B,L,aa(B,B,aa(B,fun(B,B),plus_plus(B),X4),zero_zero(B)))
              & aa(B,$o,P,X4) ) ) ) ).

% unity_coeff_ex
tff(fact_1399_unit__dvdE,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ~ ( ( A3 != zero_zero(B) )
             => ! [C3: B] : B2 != aa(B,B,aa(B,fun(B,B),times_times(B),A3),C3) ) ) ) ).

% unit_dvdE
tff(fact_1400_inf__period_I4_J,axiom,
    ! [B: $tType] :
      ( ( comm_ring(B)
        & dvd(B) )
     => ! [D3: B,D4: B,T2: B] :
          ( dvd_dvd(B,D3,D4)
         => ! [X: B,K7: B] :
              ( ~ dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),T2))
            <=> ~ dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X),aa(B,B,aa(B,fun(B,B),times_times(B),K7),D4))),T2)) ) ) ) ).

% inf_period(4)
tff(fact_1401_inf__period_I3_J,axiom,
    ! [B: $tType] :
      ( ( comm_ring(B)
        & dvd(B) )
     => ! [D3: B,D4: B,T2: B] :
          ( dvd_dvd(B,D3,D4)
         => ! [X: B,K7: B] :
              ( dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),X),T2))
            <=> dvd_dvd(B,D3,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X),aa(B,B,aa(B,fun(B,B),times_times(B),K7),D4))),T2)) ) ) ) ).

% inf_period(3)
tff(fact_1402_unit__div__eq__0__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = zero_zero(B) )
          <=> ( A3 = zero_zero(B) ) ) ) ) ).

% unit_div_eq_0_iff
tff(fact_1403_numeral__Bit1,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [N: num] : aa(num,B,numeral_numeral(B),aa(num,num,bit1,N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),N)),aa(num,B,numeral_numeral(B),N))),one_one(B)) ) ).

% numeral_Bit1
tff(fact_1404_unit__eq__div1,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = C2 )
          <=> ( A3 = aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2) ) ) ) ) ).

% unit_eq_div1
tff(fact_1405_unit__eq__div2,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( ( A3 = aa(B,B,aa(B,fun(B,B),divide_divide(B),C2),B2) )
          <=> ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2) = C2 ) ) ) ) ).

% unit_eq_div2
tff(fact_1406_div__mult__unit2,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [C2: B,B2: B,A3: B] :
          ( dvd_dvd(B,C2,one_one(B))
         => ( dvd_dvd(B,B2,A3)
           => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),C2) ) ) ) ) ).

% div_mult_unit2
tff(fact_1407_unit__div__commute,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B,C2: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2)),B2) ) ) ) ).

% unit_div_commute
tff(fact_1408_unit__div__mult__swap,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [C2: B,A3: B,B2: B] :
          ( dvd_dvd(B,C2,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),C2) ) ) ) ).

% unit_div_mult_swap
tff(fact_1409_is__unit__div__mult2__eq,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,C2: B,A3: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( dvd_dvd(B,C2,one_one(B))
           => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),C2) ) ) ) ) ).

% is_unit_div_mult2_eq
tff(fact_1410_unit__imp__mod__eq__0,axiom,
    ! [B: $tType] :
      ( euclid3725896446679973847miring(B)
     => ! [B2: B,A3: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) = zero_zero(B) ) ) ) ).

% unit_imp_mod_eq_0
tff(fact_1411_is__unit__power__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,N: nat] :
          ( dvd_dvd(B,aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),N),one_one(B))
        <=> ( dvd_dvd(B,A3,one_one(B))
            | ( N = zero_zero(nat) ) ) ) ) ).

% is_unit_power_iff
tff(fact_1412_bezout__add__strong__nat,axiom,
    ! [A3: nat,B2: nat] :
      ( ( A3 != zero_zero(nat) )
     => ? [D2: nat,X3: nat,Y4: nat] :
          ( dvd_dvd(nat,D2,A3)
          & dvd_dvd(nat,D2,B2)
          & ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),X3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),B2),Y4)),D2) ) ) ) ).

% bezout_add_strong_nat
tff(fact_1413_take__bit__Suc__bit1,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [N: nat,K: num] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,suc,N)),aa(num,B,numeral_numeral(B),aa(num,num,bit1,K))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),aa(num,B,numeral_numeral(B),K))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),one_one(B)) ) ).

% take_bit_Suc_bit1
tff(fact_1414_numeral__code_I3_J,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [N: num] :
          aa(num,B,numeral_numeral(B),aa(num,num,bit1,N)) = $let(
            m: B,
            m:= aa(num,B,numeral_numeral(B),N),
            aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),m),m)),one_one(B)) ) ) ).

% numeral_code(3)
tff(fact_1415_stable__imp__take__bit__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B,N: nat] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = A3 )
         => ( aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),A3) = $ite(dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3),zero_zero(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)),one_one(B))) ) ) ) ).

% stable_imp_take_bit_eq
tff(fact_1416_is__unitE,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ~ ( ( A3 != zero_zero(B) )
             => ! [B3: B] :
                  ( ( B3 != zero_zero(B) )
                 => ( dvd_dvd(B,B3,one_one(B))
                   => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3) = B3 )
                     => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),B3) = A3 )
                       => ( ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),B3) = one_one(B) )
                         => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),C2),A3) != aa(B,B,aa(B,fun(B,B),times_times(B),C2),B3) ) ) ) ) ) ) ) ) ) ).

% is_unitE
tff(fact_1417_is__unit__div__mult__cancel__left,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( ( A3 != zero_zero(B) )
         => ( dvd_dvd(B,B2,one_one(B))
           => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),B2) ) ) ) ) ).

% is_unit_div_mult_cancel_left
tff(fact_1418_is__unit__div__mult__cancel__right,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( ( A3 != zero_zero(B) )
         => ( dvd_dvd(B,B2,one_one(B))
           => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),B2),A3)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),B2) ) ) ) ) ).

% is_unit_div_mult_cancel_right
tff(fact_1419_odd__even__add,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B,B2: B] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),B2)
           => dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) ) ) ) ).

% odd_even_add
tff(fact_1420_odd__one,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),one_one(B)) ) ).

% odd_one
tff(fact_1421_dvd__power__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [X2: B,M: nat,N: nat] :
          ( ( X2 != zero_zero(B) )
         => ( dvd_dvd(B,aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),M),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N))
          <=> ( dvd_dvd(B,X2,one_one(B))
              | aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ) ) ) ).

% dvd_power_iff
tff(fact_1422_dvd__power,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [N: nat,X2: B] :
          ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
            | ( X2 = one_one(B) ) )
         => dvd_dvd(B,X2,aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)) ) ) ).

% dvd_power
tff(fact_1423_Suc3__eq__add__3,axiom,
    ! [N: nat] : aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,N))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),N) ).

% Suc3_eq_add_3
tff(fact_1424_dvd__mult__cancel2,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M)
     => ( dvd_dvd(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),M),M)
      <=> ( N = one_one(nat) ) ) ) ).

% dvd_mult_cancel2
tff(fact_1425_dvd__mult__cancel1,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M)
     => ( dvd_dvd(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),N),M)
      <=> ( N = one_one(nat) ) ) ) ).

% dvd_mult_cancel1
tff(fact_1426_dvd__minus__add,axiom,
    ! [Q3: nat,N: nat,R: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Q3),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Q3),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),R),M))
       => ( dvd_dvd(nat,M,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),Q3))
        <=> dvd_dvd(nat,M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),R),M)),Q3))) ) ) ) ).

% dvd_minus_add
tff(fact_1427_power__dvd__imp__le,axiom,
    ! [I: nat,M: nat,N: nat] :
      ( dvd_dvd(nat,aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),I),M),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),I),N))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),I)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ) ).

% power_dvd_imp_le
tff(fact_1428_aset_I10_J,axiom,
    ! [D3: int,D4: int,A4: set(int),T2: int] :
      ( dvd_dvd(int,D3,D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,A4)
                 => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
         => ( ~ dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),T2))
           => ~ dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)),T2)) ) ) ) ).

% aset(10)
tff(fact_1429_aset_I9_J,axiom,
    ! [D3: int,D4: int,A4: set(int),T2: int] :
      ( dvd_dvd(int,D3,D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,A4)
                 => ( X != aa(int,int,aa(int,fun(int,int),minus_minus(int),Xb3),Xa4) ) ) )
         => ( dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),T2))
           => dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),X),D4)),T2)) ) ) ) ).

% aset(9)
tff(fact_1430_bset_I10_J,axiom,
    ! [D3: int,D4: int,B5: set(int),T2: int] :
      ( dvd_dvd(int,D3,D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,B5)
                 => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
         => ( ~ dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),T2))
           => ~ dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)),T2)) ) ) ) ).

% bset(10)
tff(fact_1431_bset_I9_J,axiom,
    ! [D3: int,D4: int,B5: set(int),T2: int] :
      ( dvd_dvd(int,D3,D4)
     => ! [X: int] :
          ( ! [Xa4: int] :
              ( member(int,Xa4,set_or1337092689740270186AtMost(int,one_one(int),D4))
             => ! [Xb3: int] :
                  ( member(int,Xb3,B5)
                 => ( X != aa(int,int,aa(int,fun(int,int),plus_plus(int),Xb3),Xa4) ) ) )
         => ( dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),X),T2))
           => dvd_dvd(int,D3,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),X),D4)),T2)) ) ) ) ).

% bset(9)
tff(fact_1432_num_Osize__gen_I3_J,axiom,
    ! [X32: num] : size_num(aa(num,num,bit1,X32)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),size_num(X32)),aa(nat,nat,suc,zero_zero(nat))) ).

% num.size_gen(3)
tff(fact_1433_num_Osize_I6_J,axiom,
    ! [X32: num] : aa(num,nat,size_size(num),aa(num,num,bit1,X32)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,size_size(num),X32)),aa(nat,nat,suc,zero_zero(nat))) ).

% num.size(6)
tff(fact_1434_odd__iff__mod__2__eq__one,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
        <=> ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = one_one(B) ) ) ) ).

% odd_iff_mod_2_eq_one
tff(fact_1435_Suc__mod__eq__add3__mod,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,M)))),N) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),M)),N) ).

% Suc_mod_eq_add3_mod
tff(fact_1436_Suc__div__eq__add3__div,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,suc,aa(nat,nat,suc,aa(nat,nat,suc,M)))),N) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),M)),N) ).

% Suc_div_eq_add3_div
tff(fact_1437_even__diff__iff,axiom,
    ! [K: int,L: int] :
      ( dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),aa(int,int,aa(int,fun(int,int),minus_minus(int),K),L))
    <=> dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)) ) ).

% even_diff_iff
tff(fact_1438_even__abs__add__iff,axiom,
    ! [K: int,L: int] :
      ( dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,abs_abs(int),K)),L))
    <=> dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)) ) ).

% even_abs_add_iff
tff(fact_1439_even__add__abs__iff,axiom,
    ! [K: int,L: int] :
      ( dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),aa(int,int,abs_abs(int),L)))
    <=> dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)) ) ).

% even_add_abs_iff
tff(fact_1440_signed__take__bit__eq__take__bit__shift,axiom,
    ! [N: nat,K: int] : bit_ri4674362597316999326ke_bit(int,N,K) = aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),aa(nat,nat,suc,N)),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N)))),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N)) ).

% signed_take_bit_eq_take_bit_shift
tff(fact_1441_take__bit__incr__eq,axiom,
    ! [N: nat,K: int] :
      ( ( aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K) != aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N)),one_one(int)) )
     => ( aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),one_one(int))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K)) ) ) ).

% take_bit_incr_eq
tff(fact_1442_oddE,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ~ ! [B3: B] : A3 != aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),B3)),one_one(B)) ) ) ).

% oddE
tff(fact_1443_parity__cases,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          ( ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
           => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) != zero_zero(B) ) )
         => ~ ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
             => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) != one_one(B) ) ) ) ) ).

% parity_cases
tff(fact_1444_mod2__eq__if,axiom,
    ! [B: $tType] :
      ( semiring_parity(B)
     => ! [A3: B] :
          aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = $ite(dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3),zero_zero(B),one_one(B)) ) ).

% mod2_eq_if
tff(fact_1445_minus__one__power__iff,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [N: nat] :
          aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N) = $ite(dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N),one_one(B),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% minus_one_power_iff
tff(fact_1446_take__bit__int__greater__eq,axiom,
    ! [K: int,N: nat] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),K),zero_zero(int))
     => aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N))),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K)) ) ).

% take_bit_int_greater_eq
tff(fact_1447_take__bit__Suc__minus__1__eq,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,suc,N)),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,suc,N))),one_one(B)) ) ).

% take_bit_Suc_minus_1_eq
tff(fact_1448_take__bit__Suc,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,suc,N)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))) ) ).

% take_bit_Suc
tff(fact_1449_take__bit__numeral__minus__1__eq,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [K: num] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(num,nat,numeral_numeral(nat),K)),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(num,nat,numeral_numeral(nat),K))),one_one(B)) ) ).

% take_bit_numeral_minus_1_eq
tff(fact_1450_even__mask__div__iff_H,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [M: nat,N: nat] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)),one_one(B))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)))
        <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ) ).

% even_mask_div_iff'
tff(fact_1451_even__mask__div__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [M: nat,N: nat] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)),one_one(B))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)))
        <=> ( ( aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N) = zero_zero(B) )
            | aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ) ) ).

% even_mask_div_iff
tff(fact_1452_Code__Numeral_Onegative__def,axiom,
    code_negative = aa(fun(num,code_integer),fun(num,code_integer),aa(fun(code_integer,code_integer),fun(fun(num,code_integer),fun(num,code_integer)),comp(code_integer,code_integer,num),uminus_uminus(code_integer)),numeral_numeral(code_integer)) ).

% Code_Numeral.negative_def
tff(fact_1453_take__bit__numeral__minus__numeral__int,axiom,
    ! [M: num,N: num] : aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),aa(num,nat,numeral_numeral(nat),M)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N))) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),aTP_Lamp_dj(num,fun(num,int),M)),bit_take_bit_num(aa(num,nat,numeral_numeral(nat),M),N)) ).

% take_bit_numeral_minus_numeral_int
tff(fact_1454_signed__take__bit__numeral__minus__bit1,axiom,
    ! [L: num,K: num] : bit_ri4674362597316999326ke_bit(int,aa(num,nat,numeral_numeral(nat),L),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,K)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),bit_ri4674362597316999326ke_bit(int,pred_numeral(L),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),K))),one_one(int)))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),one_one(int)) ).

% signed_take_bit_numeral_minus_bit1
tff(fact_1455_execute__change,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [F: fun(B,B),R: ref(B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),ref_change(B,F,R)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(B,B,F,ref_get(B,Ha,R))),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),ref_set(B,R,aa(B,B,F,ref_get(B,Ha,R)),Ha)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))))) ) ).

% execute_change
tff(fact_1456_signed__take__bit__numeral__bit1,axiom,
    ! [L: num,K: num] : bit_ri4674362597316999326ke_bit(int,aa(num,nat,numeral_numeral(nat),L),aa(num,int,numeral_numeral(int),aa(num,num,bit1,K))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),bit_ri4674362597316999326ke_bit(int,pred_numeral(L),aa(num,int,numeral_numeral(int),K))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),one_one(int)) ).

% signed_take_bit_numeral_bit1
tff(fact_1457_take__bit__Suc__minus__bit1,axiom,
    ! [N: nat,K: num] : aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),aa(nat,nat,suc,N)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,K)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),inc(K))))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),one_one(int)) ).

% take_bit_Suc_minus_bit1
tff(fact_1458_divmod__BitM__2__eq,axiom,
    ! [M: num] : unique8689654367752047608divmod(int,bitM(M),aa(num,num,bit0,one2)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(num,int,numeral_numeral(int),M)),one_one(int))),one_one(int)) ).

% divmod_BitM_2_eq
tff(fact_1459_flip__bit__0,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se8732182000553998342ip_bit(B),zero_zero(nat)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa($o,B,zero_neq_one_of_bool(B),dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))) ) ).

% flip_bit_0
tff(fact_1460_of__bool__eq_I2_J,axiom,
    ! [B: $tType] :
      ( zero_neq_one(B)
     => ( aa($o,B,zero_neq_one_of_bool(B),$true) = one_one(B) ) ) ).

% of_bool_eq(2)
tff(fact_1461_of__bool__eq__1__iff,axiom,
    ! [B: $tType] :
      ( zero_neq_one(B)
     => ! [P: $o] :
          ( ( aa($o,B,zero_neq_one_of_bool(B),(P)) = one_one(B) )
        <=> (P) ) ) ).

% of_bool_eq_1_iff
tff(fact_1462_of__bool__less__one__iff,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [P: $o] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa($o,B,zero_neq_one_of_bool(B),(P))),one_one(B))
        <=> ~ (P) ) ) ).

% of_bool_less_one_iff
tff(fact_1463_of__bool__not__iff,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [P: $o] : aa($o,B,zero_neq_one_of_bool(B),~ (P)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa($o,B,zero_neq_one_of_bool(B),(P))) ) ).

% of_bool_not_iff
tff(fact_1464_take__bit__num__simps_I3_J,axiom,
    ! [N: nat,M: num] : bit_take_bit_num(aa(nat,nat,suc,N),aa(num,num,bit0,M)) = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),none(num)),aTP_Lamp_dk(num,option(num))),bit_take_bit_num(N,M)) ).

% take_bit_num_simps(3)
tff(fact_1465_take__bit__num__simps_I4_J,axiom,
    ! [N: nat,M: num] : bit_take_bit_num(aa(nat,nat,suc,N),aa(num,num,bit1,M)) = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_take_bit_num(N,M))) ).

% take_bit_num_simps(4)
tff(fact_1466_take__bit__num__simps_I6_J,axiom,
    ! [R: num,M: num] : bit_take_bit_num(aa(num,nat,numeral_numeral(nat),R),aa(num,num,bit0,M)) = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),none(num)),aTP_Lamp_dk(num,option(num))),bit_take_bit_num(pred_numeral(R),M)) ).

% take_bit_num_simps(6)
tff(fact_1467_take__bit__of__1,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),one_one(B)) = aa($o,B,zero_neq_one_of_bool(B),aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)) ) ).

% take_bit_of_1
tff(fact_1468_add__neg__numeral__special_I6_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),inc(M))) ) ).

% add_neg_numeral_special(6)
tff(fact_1469_add__neg__numeral__special_I5_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N))) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),inc(N))) ) ).

% add_neg_numeral_special(5)
tff(fact_1470_diff__numeral__special_I5_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),N)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),inc(N))) ) ).

% diff_numeral_special(5)
tff(fact_1471_diff__numeral__special_I6_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(num,B,numeral_numeral(B),M)),aa(B,B,uminus_uminus(B),one_one(B))) = aa(num,B,numeral_numeral(B),inc(M)) ) ).

% diff_numeral_special(6)
tff(fact_1472_take__bit__num__simps_I7_J,axiom,
    ! [R: num,M: num] : bit_take_bit_num(aa(num,nat,numeral_numeral(nat),R),aa(num,num,bit1,M)) = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_take_bit_num(pred_numeral(R),M))) ).

% take_bit_num_simps(7)
tff(fact_1473_take__bit__numeral__numeral,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [M: num,N: num] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(num,nat,numeral_numeral(nat),M)),aa(num,B,numeral_numeral(B),N)) = aa(option(num),B,aa(fun(num,B),fun(option(num),B),aa(B,fun(fun(num,B),fun(option(num),B)),case_option(B,num),zero_zero(B)),numeral_numeral(B)),bit_take_bit_num(aa(num,nat,numeral_numeral(nat),M),N)) ) ).

% take_bit_numeral_numeral
tff(fact_1474_bits__1__div__exp,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) = aa($o,B,zero_neq_one_of_bool(B),N = zero_zero(nat)) ) ).

% bits_1_div_exp
tff(fact_1475_one__div__2__pow__eq,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) = aa($o,B,zero_neq_one_of_bool(B),N = zero_zero(nat)) ) ).

% one_div_2_pow_eq
tff(fact_1476_one__mod__2__pow__eq,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [N: nat] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)) = aa($o,B,zero_neq_one_of_bool(B),aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)) ) ).

% one_mod_2_pow_eq
tff(fact_1477_mult__inc,axiom,
    ! [X2: num,Y: num] : aa(num,num,aa(num,fun(num,num),times_times(num),X2),inc(Y)) = aa(num,num,aa(num,fun(num,num),plus_plus(num),aa(num,num,aa(num,fun(num,num),times_times(num),X2),Y)),X2) ).

% mult_inc
tff(fact_1478_add__inc,axiom,
    ! [X2: num,Y: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),inc(Y)) = inc(aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),Y)) ).

% add_inc
tff(fact_1479_of__bool__less__eq__one,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [P: $o] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa($o,B,zero_neq_one_of_bool(B),(P))),one_one(B)) ) ).

% of_bool_less_eq_one
tff(fact_1480_of__bool__def,axiom,
    ! [B: $tType] :
      ( zero_neq_one(B)
     => ! [P3: $o] :
          aa($o,B,zero_neq_one_of_bool(B),(P3)) = $ite((P3),one_one(B),zero_zero(B)) ) ).

% of_bool_def
tff(fact_1481_split__of__bool,axiom,
    ! [B: $tType] :
      ( zero_neq_one(B)
     => ! [P: fun(B,$o),P3: $o] :
          ( aa(B,$o,P,aa($o,B,zero_neq_one_of_bool(B),(P3)))
        <=> ( ( (P3)
             => aa(B,$o,P,one_one(B)) )
            & ( ~ (P3)
             => aa(B,$o,P,zero_zero(B)) ) ) ) ) ).

% split_of_bool
tff(fact_1482_split__of__bool__asm,axiom,
    ! [B: $tType] :
      ( zero_neq_one(B)
     => ! [P: fun(B,$o),P3: $o] :
          ( aa(B,$o,P,aa($o,B,zero_neq_one_of_bool(B),(P3)))
        <=> ~ ( ( (P3)
                & ~ aa(B,$o,P,one_one(B)) )
              | ( ~ (P3)
                & ~ aa(B,$o,P,zero_zero(B)) ) ) ) ) ).

% split_of_bool_asm
tff(fact_1483_add__One,axiom,
    ! [X2: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),one2) = inc(X2) ).

% add_One
tff(fact_1484_effect__updateI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [H2: heap_ext(product_unit),R: ref(B),V: B,Ha: heap_ext(product_unit),N: nat,X2: product_unit] :
          ( ( H2 = ref_set(B,R,V,Ha) )
         => ( ( N = one_one(nat) )
           => heap_Time_effect(product_unit,ref_update(B,R,V),Ha,H2,X2,N) ) ) ) ).

% effect_updateI
tff(fact_1485_effect__updateE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R3: ref(B),V: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: product_unit,N: nat] :
          ( heap_Time_effect(product_unit,ref_update(B,R3,V),Ha,H2,R,N)
         => ~ ( ( H2 = ref_set(B,R3,V,Ha) )
             => ( N != one_one(nat) ) ) ) ) ).

% effect_updateE
tff(fact_1486_pred__numeral__def,axiom,
    ! [K: num] : pred_numeral(K) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(num,nat,numeral_numeral(nat),K)),one_one(nat)) ).

% pred_numeral_def
tff(fact_1487_BitM__plus__one,axiom,
    ! [N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),bitM(N)),one2) = aa(num,num,bit0,N) ).

% BitM_plus_one
tff(fact_1488_one__plus__BitM,axiom,
    ! [N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),bitM(N)) = aa(num,num,bit0,N) ).

% one_plus_BitM
tff(fact_1489_numeral__inc,axiom,
    ! [B: $tType] :
      ( numeral(B)
     => ! [X2: num] : aa(num,B,numeral_numeral(B),inc(X2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),X2)),one_one(B)) ) ).

% numeral_inc
tff(fact_1490_numeral__BitM,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(num,B,numeral_numeral(B),bitM(N)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,N))),one_one(B)) ) ).

% numeral_BitM
tff(fact_1491_take__bit__numeral__minus__bit1,axiom,
    ! [L: num,K: num] : aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),aa(num,nat,numeral_numeral(nat),L)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,K)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),pred_numeral(L)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),inc(K))))),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),one_one(int)) ).

% take_bit_numeral_minus_bit1
tff(fact_1492_bits__induct,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [P: fun(B,$o),A3: B] :
          ( ! [A5: B] :
              ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A5),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = A5 )
             => aa(B,$o,P,A5) )
         => ( ! [A5: B,B3: $o] :
                ( aa(B,$o,P,A5)
               => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa($o,B,zero_neq_one_of_bool(B),(B3))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),A5))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) = A5 )
                 => aa(B,$o,P,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa($o,B,zero_neq_one_of_bool(B),(B3))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),A5))) ) )
           => aa(B,$o,P,A3) ) ) ) ).

% bits_induct
tff(fact_1493_effect__changeE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [F: fun(B,B),R3: ref(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
          ( heap_Time_effect(B,ref_change(B,F,R3),Ha,H2,R,N)
         => ~ ( ( H2 = ref_set(B,R3,aa(B,B,F,ref_get(B,Ha,R3)),Ha) )
             => ( ( R = aa(B,B,F,ref_get(B,Ha,R3)) )
               => ( N != aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2)) ) ) ) ) ) ).

% effect_changeE
tff(fact_1494_effect__changeI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [H2: heap_ext(product_unit),R: ref(B),F: fun(B,B),Ha: heap_ext(product_unit),X2: B,N: nat] :
          ( ( H2 = ref_set(B,R,aa(B,B,F,ref_get(B,Ha,R)),Ha) )
         => ( ( X2 = aa(B,B,F,ref_get(B,Ha,R)) )
           => ( ( N = aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2)) )
             => heap_Time_effect(B,ref_change(B,F,R),Ha,H2,X2,N) ) ) ) ) ).

% effect_changeI
tff(fact_1495_divide__int__unfold,axiom,
    ! [K: int,M: nat,L: int,N: nat] :
      aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,sgn_sgn(int),K)),aa(nat,int,semiring_1_of_nat(int),M))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,sgn_sgn(int),L)),aa(nat,int,semiring_1_of_nat(int),N))) = $ite(
        ( ( aa(int,int,sgn_sgn(int),L) = zero_zero(int) )
        | ( aa(int,int,sgn_sgn(int),K) = zero_zero(int) )
        | ( N = zero_zero(nat) ) ),
        zero_zero(int),
        $ite(aa(int,int,sgn_sgn(int),K) = aa(int,int,sgn_sgn(int),L),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)),aa(int,int,uminus_uminus(int),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),N)),aa($o,nat,zero_neq_one_of_bool(nat),~ dvd_dvd(nat,N,M)))))) ) ).

% divide_int_unfold
tff(fact_1496_take__bit__numeral__bit1,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [L: num,K: num] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(num,nat,numeral_numeral(nat),L)),aa(num,B,numeral_numeral(B),aa(num,num,bit1,K))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),pred_numeral(L)),aa(num,B,numeral_numeral(B),K))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),one_one(B)) ) ).

% take_bit_numeral_bit1
tff(fact_1497_Divides_Oadjust__div__eq,axiom,
    ! [Q3: int,R: int] : adjust_div(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Q3),R)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),Q3),aa($o,int,zero_neq_one_of_bool(int),R != zero_zero(int))) ).

% Divides.adjust_div_eq
tff(fact_1498_mask__numeral,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: num] : aa(nat,B,bit_se2239418461657761734s_mask(B),aa(num,nat,numeral_numeral(nat),N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,B,bit_se2239418461657761734s_mask(B),pred_numeral(N)))) ) ).

% mask_numeral
tff(fact_1499_and__int__unfold,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),K),L) = $ite(
        ( ( K = zero_zero(int) )
        | ( L = zero_zero(int) ) ),
        zero_zero(int),
        $ite(
          K = aa(int,int,uminus_uminus(int),one_one(int)),
          L,
          $ite(L = aa(int,int,uminus_uminus(int),one_one(int)),K,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))))) ) ) ).

% and_int_unfold
tff(fact_1500_the__res__def,axiom,
    ! [B: $tType,M: heap_Time_Heap(B),Ha: heap_ext(product_unit)] : time_the_res(B,M,Ha) = aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),B,aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),B),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),B),aa(B,fun(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),B),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),B)),case_option(B,product_prod(B,product_prod(heap_ext(product_unit),nat))),undefined(B)),aa(fun(B,fun(product_prod(heap_ext(product_unit),nat),B)),fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),B),product_case_prod(B,product_prod(heap_ext(product_unit),nat),B),aTP_Lamp_dm(B,fun(product_prod(heap_ext(product_unit),nat),B)))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),M),Ha)) ).

% the_res_def
tff(fact_1501_take__bit__eq__mask__iff__exp__dvd,axiom,
    ! [N: nat,K: int] :
      ( ( aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K) = aa(nat,int,bit_se2239418461657761734s_mask(int),N) )
    <=> dvd_dvd(int,aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),one_one(int))) ) ).

% take_bit_eq_mask_iff_exp_dvd
tff(fact_1502_Code__Numeral_Opositive__def,axiom,
    code_positive = numeral_numeral(code_integer) ).

% Code_Numeral.positive_def
tff(fact_1503_divide__int__def,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),divide_divide(int),K),L) = $ite(
        L = zero_zero(int),
        zero_zero(int),
        $ite(aa(int,int,sgn_sgn(int),K) = aa(int,int,sgn_sgn(int),L),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(int,nat,nat2,aa(int,int,abs_abs(int),K))),aa(int,nat,nat2,aa(int,int,abs_abs(int),L)))),aa(int,int,uminus_uminus(int),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(int,nat,nat2,aa(int,int,abs_abs(int),K))),aa(int,nat,nat2,aa(int,int,abs_abs(int),L)))),aa($o,nat,zero_neq_one_of_bool(nat),~ dvd_dvd(int,L,K)))))) ) ).

% divide_int_def
tff(fact_1504_sum__gp0,axiom,
    ! [B: $tType] :
      ( ( division_ring(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_atMost(nat),N)) = $ite(X2 = one_one(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(nat,nat,suc,N)))),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2))) ) ).

% sum_gp0
tff(fact_1505_atMost__eq__iff,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,set(B),set_ord_atMost(B),X2) = aa(B,set(B),set_ord_atMost(B),Y) )
        <=> ( X2 = Y ) ) ) ).

% atMost_eq_iff
tff(fact_1506_atMost__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,K: B] :
          ( member(B,I,aa(B,set(B),set_ord_atMost(B),K))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),K) ) ) ).

% atMost_iff
tff(fact_1507_atMost__subset__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B,Y: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atMost(B),X2)),aa(B,set(B),set_ord_atMost(B),Y))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y) ) ) ).

% atMost_subset_iff
tff(fact_1508_bit_Oconj__one__right,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),X2),aa(B,B,uminus_uminus(B),one_one(B))) = X2 ) ).

% bit.conj_one_right
tff(fact_1509_and_Oright__neutral,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),aa(B,B,uminus_uminus(B),one_one(B))) = A3 ) ).

% and.right_neutral
tff(fact_1510_and_Oleft__neutral,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(B,B,uminus_uminus(B),one_one(B))),A3) = A3 ) ).

% and.left_neutral
tff(fact_1511_and__numerals_I2_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = one_one(B) ) ).

% and_numerals(2)
tff(fact_1512_and__numerals_I8_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),one_one(B)) = one_one(B) ) ).

% and_numerals(8)
tff(fact_1513_Icc__subset__Iic__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [L: B,Ha: B,H2: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or1337092689740270186AtMost(B,L,Ha)),aa(B,set(B),set_ord_atMost(B),H2))
        <=> ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),Ha)
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Ha),H2) ) ) ) ).

% Icc_subset_Iic_iff
tff(fact_1514_mask__Suc__0,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ( aa(nat,B,bit_se2239418461657761734s_mask(B),aa(nat,nat,suc,zero_zero(nat))) = one_one(B) ) ) ).

% mask_Suc_0
tff(fact_1515_sum_OatMost__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),N))),aa(nat,B,G,aa(nat,nat,suc,N))) ) ).

% sum.atMost_Suc
tff(fact_1516_take__bit__minus__one__eq__mask,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),aa(B,B,uminus_uminus(B),one_one(B))) = aa(nat,B,bit_se2239418461657761734s_mask(B),N) ) ).

% take_bit_minus_one_eq_mask
tff(fact_1517_and__numerals_I1_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,Y))) = zero_zero(B) ) ).

% and_numerals(1)
tff(fact_1518_and__numerals_I5_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,X2))),one_one(B)) = zero_zero(B) ) ).

% and_numerals(5)
tff(fact_1519_nat__numeral__diff__1,axiom,
    ! [V: num] : aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(num,nat,numeral_numeral(nat),V)),one_one(nat)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(num,int,numeral_numeral(int),V)),one_one(int))) ).

% nat_numeral_diff_1
tff(fact_1520_and__numerals_I7_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num,Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(num,B,numeral_numeral(B),X2)),aa(num,B,numeral_numeral(B),Y)))) ) ).

% and_numerals(7)
tff(fact_1521_mask__integer_Oabs__eq,axiom,
    ! [X2: nat] : aa(nat,code_integer,bit_se2239418461657761734s_mask(code_integer),X2) = aa(int,code_integer,code_integer_of_int,aa(nat,int,bit_se2239418461657761734s_mask(int),X2)) ).

% mask_integer.abs_eq
tff(fact_1522_not__Iic__eq__Icc,axiom,
    ! [B: $tType] :
      ( no_bot(B)
     => ! [H2: B,L: B,Ha: B] : aa(B,set(B),set_ord_atMost(B),H2) != set_or1337092689740270186AtMost(B,L,Ha) ) ).

% not_Iic_eq_Icc
tff(fact_1523_atMost__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [U: B] : aa(B,set(B),set_ord_atMost(B),U) = aa(fun(B,$o),set(B),collect(B),aTP_Lamp_dn(B,fun(B,$o),U)) ) ).

% atMost_def
tff(fact_1524_and__eq__minus__1__iff,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),B2) = aa(B,B,uminus_uminus(B),one_one(B)) )
        <=> ( ( A3 = aa(B,B,uminus_uminus(B),one_one(B)) )
            & ( B2 = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ) ) ).

% and_eq_minus_1_iff
tff(fact_1525_atMost__atLeast0,axiom,
    ! [N: nat] : aa(nat,set(nat),set_ord_atMost(nat),N) = set_or1337092689740270186AtMost(nat,zero_zero(nat),N) ).

% atMost_atLeast0
tff(fact_1526_nat__one__as__int,axiom,
    one_one(nat) = aa(int,nat,nat2,one_one(int)) ).

% nat_one_as_int
tff(fact_1527_not__Iic__le__Icc,axiom,
    ! [B: $tType] :
      ( no_bot(B)
     => ! [Ha: B,L4: B,H2: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atMost(B),Ha)),set_or1337092689740270186AtMost(B,L4,H2)) ) ).

% not_Iic_le_Icc
tff(fact_1528_nat__int__add,axiom,
    ! [A3: nat,B2: nat] : aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),A3)),aa(nat,int,semiring_1_of_nat(int),B2))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2) ).

% nat_int_add
tff(fact_1529_option_Othe__def,axiom,
    ! [B: $tType,Option: option(B)] : aa(option(B),B,the2(B),Option) = aa(option(B),B,aa(fun(B,B),fun(option(B),B),aa(B,fun(fun(B,B),fun(option(B),B)),case_option(B,B),undefined(B)),aTP_Lamp_ay(B,B)),Option) ).

% option.the_def
tff(fact_1530_nat__plus__as__int,axiom,
    ! [X: nat,Xa3: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X),Xa3) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),X)),aa(nat,int,semiring_1_of_nat(int),Xa3))) ).

% nat_plus_as_int
tff(fact_1531_nat__add__distrib,axiom,
    ! [Z2: int,Z6: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),Z2)
     => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),Z6)
       => ( aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),Z2),Z6)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(int,nat,nat2,Z2)),aa(int,nat,nat2,Z6)) ) ) ) ).

% nat_add_distrib
tff(fact_1532_Suc__as__int,axiom,
    ! [X: nat] : aa(nat,nat,suc,X) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(nat,int,semiring_1_of_nat(int),X)),one_one(int))) ).

% Suc_as_int
tff(fact_1533_nat__abs__triangle__ineq,axiom,
    ! [K: int,L: int] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(int,nat,nat2,aa(int,int,abs_abs(int),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),L)))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(int,nat,nat2,aa(int,int,abs_abs(int),K))),aa(int,nat,nat2,aa(int,int,abs_abs(int),L)))) ).

% nat_abs_triangle_ineq
tff(fact_1534_sum_OatMost__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N))) ) ).

% sum.atMost_Suc_shift
tff(fact_1535_sum__telescope,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [F: fun(nat,B),I: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_do(fun(nat,B),fun(nat,B),F)),aa(nat,set(nat),set_ord_atMost(nat),I)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,zero_zero(nat))),aa(nat,B,F,aa(nat,nat,suc,I))) ) ).

% sum_telescope
tff(fact_1536_the__heap__def,axiom,
    ! [B: $tType,M: heap_Time_Heap(B),Ha: heap_ext(product_unit)] : time_the_heap(B,M,Ha) = aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),heap_ext(product_unit)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),aa(heap_ext(product_unit),fun(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),heap_ext(product_unit)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit))),case_option(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),undefined(heap_ext(product_unit))),aa(fun(B,fun(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit))),fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),heap_ext(product_unit)),product_case_prod(B,product_prod(heap_ext(product_unit),nat),heap_ext(product_unit)),aTP_Lamp_dq(B,fun(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit))))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),M),Ha)) ).

% the_heap_def
tff(fact_1537_and__one__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),one_one(B)) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ).

% and_one_eq
tff(fact_1538_one__and__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),one_one(B)),A3) = aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ).

% one_and_eq
tff(fact_1539_take__bit__eq__mask__iff,axiom,
    ! [N: nat,K: int] :
      ( ( aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K) = aa(nat,int,bit_se2239418461657761734s_mask(int),N) )
    <=> ( aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),aa(int,int,aa(int,fun(int,int),plus_plus(int),K),one_one(int))) = zero_zero(int) ) ) ).

% take_bit_eq_mask_iff
tff(fact_1540_Suc__nat__eq__nat__zadd1,axiom,
    ! [Z2: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),Z2)
     => ( aa(nat,nat,suc,aa(int,nat,nat2,Z2)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),Z2)) ) ) ).

% Suc_nat_eq_nat_zadd1
tff(fact_1541_Divides_Oadjust__div__def,axiom,
    ! [Qr: product_prod(int,int)] : adjust_div(Qr) = aa(product_prod(int,int),int,aa(fun(int,fun(int,int)),fun(product_prod(int,int),int),product_case_prod(int,int,int),aTP_Lamp_dr(int,fun(int,int))),Qr) ).

% Divides.adjust_div_def
tff(fact_1542_sum__gp__basic,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_atMost(nat),N))) = aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(nat,nat,suc,N))) ) ).

% sum_gp_basic
tff(fact_1543_sum__power__shift,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [M: nat,N: nat,X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M)))) ) ) ) ).

% sum_power_shift
tff(fact_1544_sum_Otriangle__reindex__eq,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,fun(nat,B)),N: nat] : aa(set(product_prod(nat,nat)),B,aa(fun(product_prod(nat,nat),B),fun(set(product_prod(nat,nat)),B),groups7311177749621191930dd_sum(product_prod(nat,nat),B),aa(fun(nat,fun(nat,B)),fun(product_prod(nat,nat),B),product_case_prod(nat,nat,B),G)),aa(fun(product_prod(nat,nat),$o),set(product_prod(nat,nat)),collect(product_prod(nat,nat)),aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aTP_Lamp_ds(nat,fun(nat,fun(nat,$o)),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_du(fun(nat,fun(nat,B)),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ).

% sum.triangle_reindex_eq
tff(fact_1545_and__int__rec,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),K),L) = aa(int,int,
        aa(int,fun(int,int),plus_plus(int),
          aa($o,int,zero_neq_one_of_bool(int),
            ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K)
            & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L) ))),
        aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ).

% and_int_rec
tff(fact_1546_mask__half__int,axiom,
    ! [N: nat] : aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(nat,int,bit_se2239418461657761734s_mask(int),N)),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))) = aa(nat,int,bit_se2239418461657761734s_mask(int),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ).

% mask_half_int
tff(fact_1547_sum_Oin__pairs__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),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),aa(num,num,bit0,one2))),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_cx(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ).

% sum.in_pairs_0
tff(fact_1548_mask__nat__def,axiom,
    ! [N: nat] : aa(nat,nat,bit_se2239418461657761734s_mask(nat),N) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)),one_one(nat)) ).

% mask_nat_def
tff(fact_1549_mask__eq__exp__minus__1,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat] : aa(nat,B,bit_se2239418461657761734s_mask(B),N) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)),one_one(B)) ) ).

% mask_eq_exp_minus_1
tff(fact_1550_sum_Ozero__middle,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [P3: nat,K: nat,G: fun(nat,B),Ha: fun(nat,B)] :
          ( 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),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_dv(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),K),G),Ha)),aa(nat,set(nat),set_ord_atMost(nat),P3)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_dw(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),K),G),Ha)),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),P3),aa(nat,nat,suc,zero_zero(nat))))) ) ) ) ) ).

% sum.zero_middle
tff(fact_1551_and__minus__numerals_I3_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,N)))) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),numeral_numeral(int)),bit_and_not_num(M,bitM(N))) ).

% and_minus_numerals(3)
tff(fact_1552_and__minus__numerals_I7_J,axiom,
    ! [N: num,M: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,N)))),aa(num,int,numeral_numeral(int),M)) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),numeral_numeral(int)),bit_and_not_num(M,bitM(N))) ).

% and_minus_numerals(7)
tff(fact_1553_and__minus__numerals_I4_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,N)))) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),numeral_numeral(int)),bit_and_not_num(M,aa(num,num,bit0,N))) ).

% and_minus_numerals(4)
tff(fact_1554_and__minus__numerals_I8_J,axiom,
    ! [N: num,M: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,N)))),aa(num,int,numeral_numeral(int),M)) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),numeral_numeral(int)),bit_and_not_num(M,aa(num,num,bit0,N))) ).

% and_minus_numerals(8)
tff(fact_1555_gbinomial__partial__row__sum,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_dx(B,fun(nat,B),A3)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),M)),one_one(B))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(nat,B,gbinomial(B,A3),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),one_one(nat)))) ) ).

% gbinomial_partial_row_sum
tff(fact_1556_gbinomial__r__part__sum,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,B,semiring_1_of_nat(B),M))),one_one(B)))),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),M)) ) ).

% gbinomial_r_part_sum
tff(fact_1557_and__num_Oelims,axiom,
    ! [X2: num,Xa: num,Y: option(num)] :
      ( ( bit_un7362597486090784418nd_num(X2,Xa) = Y )
     => ( ( ( X2 = one2 )
         => ( ( Xa = one2 )
           => ( Y != aa(num,option(num),some(num),one2) ) ) )
       => ( ( ( X2 = one2 )
           => ( ? [N3: num] : Xa = aa(num,num,bit0,N3)
             => ( Y != none(num) ) ) )
         => ( ( ( X2 = one2 )
             => ( ? [N3: num] : Xa = aa(num,num,bit1,N3)
               => ( Y != aa(num,option(num),some(num),one2) ) ) )
           => ( ( ? [M4: num] : X2 = aa(num,num,bit0,M4)
               => ( ( Xa = one2 )
                 => ( Y != none(num) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ! [N3: num] :
                        ( ( Xa = aa(num,num,bit0,N3) )
                       => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un7362597486090784418nd_num(M4,N3)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit1,N3) )
                         => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un7362597486090784418nd_num(M4,N3)) ) ) )
                 => ( ( ? [M4: num] : X2 = aa(num,num,bit1,M4)
                     => ( ( Xa = one2 )
                       => ( Y != aa(num,option(num),some(num),one2) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ! [N3: num] :
                              ( ( Xa = aa(num,num,bit0,N3) )
                             => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un7362597486090784418nd_num(M4,N3)) ) ) )
                     => ~ ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit1,N3) )
                               => ( Y != aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),aa(num,option(num),some(num),one2)),aTP_Lamp_dy(num,option(num))),bit_un7362597486090784418nd_num(M4,N3)) ) ) ) ) ) ) ) ) ) ) ) ) ).

% and_num.elims
tff(fact_1558_take__bit__Suc__from__most,axiom,
    ! [N: nat,K: int] : aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),aa(nat,nat,suc,N)),K) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N)),aa($o,int,zero_neq_one_of_bool(int),aa(nat,$o,aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),K),N)))),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K)) ).

% take_bit_Suc_from_most
tff(fact_1559_gbinomial__1,axiom,
    ! [B: $tType] :
      ( ( semiring_char_0(B)
        & semidom_divide(B) )
     => ! [A3: B] : aa(nat,B,gbinomial(B,A3),one_one(nat)) = A3 ) ).

% gbinomial_1
tff(fact_1560_gbinomial__0_I1_J,axiom,
    ! [B: $tType] :
      ( ( semiring_char_0(B)
        & semidom_divide(B) )
     => ! [A3: B] : aa(nat,B,gbinomial(B,A3),zero_zero(nat)) = one_one(B) ) ).

% gbinomial_0(1)
tff(fact_1561_and__nat__numerals_I2_J,axiom,
    ! [Y: num] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),aa(nat,nat,suc,zero_zero(nat))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,Y))) = one_one(nat) ).

% and_nat_numerals(2)
tff(fact_1562_and__nat__numerals_I4_J,axiom,
    ! [X2: num] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,X2))),aa(nat,nat,suc,zero_zero(nat))) = one_one(nat) ).

% and_nat_numerals(4)
tff(fact_1563_bit__disjunctive__add__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,B2: B,N: nat] :
          ( ! [N3: nat] :
              ( ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N3)
              | ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),B2),N3) )
         => ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),N)
          <=> ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N)
              | aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),B2),N) ) ) ) ) ).

% bit_disjunctive_add_iff
tff(fact_1564_bit__1__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),one_one(B)),N)
        <=> ( N = zero_zero(nat) ) ) ) ).

% bit_1_iff
tff(fact_1565_not__bit__1__Suc,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat] : ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),one_one(B)),aa(nat,nat,suc,N)) ) ).

% not_bit_1_Suc
tff(fact_1566_bit__numeral__simps_I1_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [N: num] : ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),one_one(B)),aa(num,nat,numeral_numeral(nat),N)) ) ).

% bit_numeral_simps(1)
tff(fact_1567_gbinomial__Suc__Suc,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,nat,suc,K)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,gbinomial(B,A3),K)),aa(nat,B,gbinomial(B,A3),aa(nat,nat,suc,K))) ) ).

% gbinomial_Suc_Suc
tff(fact_1568_and__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),bit_se5824344872417868541ns_and(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),Xa),X2)) ).

% and_integer.abs_eq
tff(fact_1569_gbinomial__addition__formula,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,A3),aa(nat,nat,suc,K)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),aa(nat,nat,suc,K))),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),K)) ) ).

% gbinomial_addition_formula
tff(fact_1570_gbinomial__absorb__comp,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(nat,B,semiring_1_of_nat(B),K))),aa(nat,B,gbinomial(B,A3),K)) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),K)) ) ).

% gbinomial_absorb_comp
tff(fact_1571_gbinomial__mult__1_H,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,A3),K)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),K)),aa(nat,B,gbinomial(B,A3),K))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,K))),aa(nat,B,gbinomial(B,A3),aa(nat,nat,suc,K)))) ) ).

% gbinomial_mult_1'
tff(fact_1572_gbinomial__mult__1,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(nat,B,gbinomial(B,A3),K)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),K)),aa(nat,B,gbinomial(B,A3),K))),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,K))),aa(nat,B,gbinomial(B,A3),aa(nat,nat,suc,K)))) ) ).

% gbinomial_mult_1
tff(fact_1573_Suc__times__gbinomial,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [K: nat,A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,K))),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,nat,suc,K))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,B,gbinomial(B,A3),K)) ) ).

% Suc_times_gbinomial
tff(fact_1574_gbinomial__absorption,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [K: nat,A3: B] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,K))),aa(nat,B,gbinomial(B,A3),aa(nat,nat,suc,K))) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),K)) ) ).

% gbinomial_absorption
tff(fact_1575_gbinomial__parallel__sum,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_dz(B,fun(nat,B),A3)),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(nat,B,semiring_1_of_nat(B),N))),one_one(B))),N) ) ).

% gbinomial_parallel_sum
tff(fact_1576_gbinomial__rec,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,nat,suc,K)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,A3),K)),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,K)))) ) ).

% gbinomial_rec
tff(fact_1577_gbinomial__factors,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,nat,suc,K)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,suc,K)))),aa(nat,B,gbinomial(B,A3),K)) ) ).

% gbinomial_factors
tff(fact_1578_gbinomial__negated__upper,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,A3),K) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),K)),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,semiring_1_of_nat(B),K)),A3)),one_one(B))),K)) ) ).

% gbinomial_negated_upper
tff(fact_1579_gbinomial__index__swap,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [K: nat,N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),K)),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(nat,B,semiring_1_of_nat(B),N))),one_one(B))),K)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(nat,B,semiring_1_of_nat(B),K))),one_one(B))),N)) ) ).

% gbinomial_index_swap
tff(fact_1580_int__bit__bound,axiom,
    ! [K: int] :
      ~ ! [N3: nat] :
          ( ! [M5: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N3),M5)
             => ( aa(nat,$o,aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),K),M5)
              <=> aa(nat,$o,aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),K),N3) ) )
         => ~ ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N3)
             => ( aa(nat,$o,aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),K),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N3),one_one(nat)))
              <=> ~ aa(nat,$o,aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),K),N3) ) ) ) ).

% int_bit_bound
tff(fact_1581_gbinomial__minus,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,aa(B,B,uminus_uminus(B),A3)),K) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),K)),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(nat,B,semiring_1_of_nat(B),K))),one_one(B))),K)) ) ).

% gbinomial_minus
tff(fact_1582_gbinomial__reduce__nat,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [K: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
         => ( aa(nat,B,gbinomial(B,A3),K) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),one_one(nat)))),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),K)) ) ) ) ).

% gbinomial_reduce_nat
tff(fact_1583_gbinomial__sum__lower__neg,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_ea(B,fun(nat,B),A3)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),M)),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),M)) ) ).

% gbinomial_sum_lower_neg
tff(fact_1584_numeral__and__num,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(num,B,numeral_numeral(B),M)),aa(num,B,numeral_numeral(B),N)) = aa(option(num),B,aa(fun(num,B),fun(option(num),B),aa(B,fun(fun(num,B),fun(option(num),B)),case_option(B,num),zero_zero(B)),numeral_numeral(B)),bit_un7362597486090784418nd_num(M,N)) ) ).

% numeral_and_num
tff(fact_1585_gbinomial__sum__up__index,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_eb(nat,fun(nat,B),K)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),N)),one_one(B))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),one_one(nat))) ) ).

% gbinomial_sum_up_index
tff(fact_1586_gbinomial__partial__sum__poly,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [M: nat,A3: B,X2: B,Y: B] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ec(nat,fun(B,fun(B,fun(B,fun(nat,B)))),M),A3),X2),Y)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ed(nat,fun(B,fun(B,fun(B,fun(nat,B)))),M),A3),X2),Y)),aa(nat,set(nat),set_ord_atMost(nat),M)) ) ).

% gbinomial_partial_sum_poly
tff(fact_1587_even__bit__succ__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat] :
          ( dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),A3)),N)
          <=> ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N)
              | ( N = zero_zero(nat) ) ) ) ) ) ).

% even_bit_succ_iff
tff(fact_1588_odd__bit__iff__bit__pred,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat] :
          ( ~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)
         => ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N)
          <=> ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),N)
              | ( N = zero_zero(nat) ) ) ) ) ) ).

% odd_bit_iff_bit_pred
tff(fact_1589_and__num_Osimps_I9_J,axiom,
    ! [M: num,N: num] : bit_un7362597486090784418nd_num(aa(num,num,bit1,M),aa(num,num,bit1,N)) = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),aa(num,option(num),some(num),one2)),aTP_Lamp_dy(num,option(num))),bit_un7362597486090784418nd_num(M,N)) ).

% and_num.simps(9)
tff(fact_1590_gbinomial__absorption_H,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [K: nat,A3: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
         => ( aa(nat,B,gbinomial(B,A3),K) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(nat,B,semiring_1_of_nat(B),K))),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),one_one(nat)))) ) ) ) ).

% gbinomial_absorption'
tff(fact_1591_gbinomial__partial__sum__poly__xpos,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [M: nat,A3: B,X2: B,Y: B] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ec(nat,fun(B,fun(B,fun(B,fun(nat,B)))),M),A3),X2),Y)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ee(nat,fun(B,fun(B,fun(B,fun(nat,B)))),M),A3),X2),Y)),aa(nat,set(nat),set_ord_atMost(nat),M)) ) ).

% gbinomial_partial_sum_poly_xpos
tff(fact_1592_gbinomial__sum__nat__pow2,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_ef(nat,fun(nat,B),M)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M) ) ).

% gbinomial_sum_nat_pow2
tff(fact_1593_bit__sum__mult__2__cases,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B,B2: B,N: nat] :
          ( ! [J3: nat] : ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),aa(nat,nat,suc,J3))
         => ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),B2))),N)
          <=> $ite(N = zero_zero(nat),~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),B2)),N)) ) ) ) ).

% bit_sum_mult_2_cases
tff(fact_1594_and__not__num_Osimps_I8_J,axiom,
    ! [M: num,N: num] : bit_and_not_num(aa(num,num,bit1,M),aa(num,num,bit0,N)) = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),aa(num,option(num),some(num),one2)),aTP_Lamp_dy(num,option(num))),bit_and_not_num(M,N)) ).

% and_not_num.simps(8)
tff(fact_1595_bit__rec,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N)
        <=> $ite(N = zero_zero(nat),~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))) ) ) ).

% bit_rec
tff(fact_1596_and__nat__unfold,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),M),N) = $ite(
        ( ( M = zero_zero(nat) )
        | ( N = zero_zero(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(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))))) ) ).

% and_nat_unfold
tff(fact_1597_and__nat__rec,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),M),N) = aa(nat,nat,
        aa(nat,fun(nat,nat),plus_plus(nat),
          aa($o,nat,zero_neq_one_of_bool(nat),
            ( ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),M)
            & ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N) ))),
        aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))))) ).

% and_nat_rec
tff(fact_1598_set__bit__eq,axiom,
    ! [N: nat,K: int] : aa(int,int,aa(nat,fun(int,int),bit_se5668285175392031749et_bit(int),N),K) = aa(int,int,aa(int,fun(int,int),plus_plus(int),K),aa(int,int,aa(int,fun(int,int),times_times(int),aa($o,int,zero_neq_one_of_bool(int),~ aa(nat,$o,aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),K),N))),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),N))) ).

% set_bit_eq
tff(fact_1599_and__not__num_Oelims,axiom,
    ! [X2: num,Xa: num,Y: option(num)] :
      ( ( bit_and_not_num(X2,Xa) = Y )
     => ( ( ( X2 = one2 )
         => ( ( Xa = one2 )
           => ( Y != none(num) ) ) )
       => ( ( ( X2 = one2 )
           => ( ? [N3: num] : Xa = aa(num,num,bit0,N3)
             => ( Y != aa(num,option(num),some(num),one2) ) ) )
         => ( ( ( X2 = one2 )
             => ( ? [N3: num] : Xa = aa(num,num,bit1,N3)
               => ( Y != none(num) ) ) )
           => ( ! [M4: num] :
                  ( ( X2 = aa(num,num,bit0,M4) )
                 => ( ( Xa = one2 )
                   => ( Y != aa(num,option(num),some(num),aa(num,num,bit0,M4)) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ! [N3: num] :
                        ( ( Xa = aa(num,num,bit0,N3) )
                       => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_and_not_num(M4,N3)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit1,N3) )
                         => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_and_not_num(M4,N3)) ) ) )
                 => ( ! [M4: num] :
                        ( ( X2 = aa(num,num,bit1,M4) )
                       => ( ( Xa = one2 )
                         => ( Y != aa(num,option(num),some(num),aa(num,num,bit0,M4)) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ! [N3: num] :
                              ( ( Xa = aa(num,num,bit0,N3) )
                             => ( Y != aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),aa(num,option(num),some(num),one2)),aTP_Lamp_dy(num,option(num))),bit_and_not_num(M4,N3)) ) ) )
                     => ~ ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit1,N3) )
                               => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_and_not_num(M4,N3)) ) ) ) ) ) ) ) ) ) ) ) ) ).

% and_not_num.elims
tff(fact_1600_and__not__num_Opelims,axiom,
    ! [X2: num,Xa: num,Y: option(num)] :
      ( ( bit_and_not_num(X2,Xa) = Y )
     => ( aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),X2),Xa))
       => ( ( ( X2 = one2 )
           => ( ( Xa = one2 )
             => ( ( Y = none(num) )
               => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),one2)) ) ) )
         => ( ( ( X2 = one2 )
             => ! [N3: num] :
                  ( ( Xa = aa(num,num,bit0,N3) )
                 => ( ( Y = aa(num,option(num),some(num),one2) )
                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit0,N3))) ) ) )
           => ( ( ( X2 = one2 )
               => ! [N3: num] :
                    ( ( Xa = aa(num,num,bit1,N3) )
                   => ( ( Y = none(num) )
                     => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit1,N3))) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ( ( Xa = one2 )
                     => ( ( Y = aa(num,option(num),some(num),aa(num,num,bit0,M4)) )
                       => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),one2)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit0,N3) )
                         => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_and_not_num(M4,N3)) )
                           => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit0,N3))) ) ) )
                 => ( ! [M4: num] :
                        ( ( X2 = aa(num,num,bit0,M4) )
                       => ! [N3: num] :
                            ( ( Xa = aa(num,num,bit1,N3) )
                           => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_and_not_num(M4,N3)) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit1,N3))) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ( ( Xa = one2 )
                           => ( ( Y = aa(num,option(num),some(num),aa(num,num,bit0,M4)) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),one2)) ) ) )
                     => ( ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit0,N3) )
                               => ( ( Y = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),aa(num,option(num),some(num),one2)),aTP_Lamp_dy(num,option(num))),bit_and_not_num(M4,N3)) )
                                 => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit0,N3))) ) ) )
                       => ~ ! [M4: num] :
                              ( ( X2 = aa(num,num,bit1,M4) )
                             => ! [N3: num] :
                                  ( ( Xa = aa(num,num,bit1,N3) )
                                 => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_and_not_num(M4,N3)) )
                                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_and_not_num_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit1,N3))) ) ) ) ) ) ) ) ) ) ) ) ) ) ).

% and_not_num.pelims
tff(fact_1601_and__num_Opelims,axiom,
    ! [X2: num,Xa: num,Y: option(num)] :
      ( ( bit_un7362597486090784418nd_num(X2,Xa) = Y )
     => ( aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),X2),Xa))
       => ( ( ( X2 = one2 )
           => ( ( Xa = one2 )
             => ( ( Y = aa(num,option(num),some(num),one2) )
               => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),one2)) ) ) )
         => ( ( ( X2 = one2 )
             => ! [N3: num] :
                  ( ( Xa = aa(num,num,bit0,N3) )
                 => ( ( Y = none(num) )
                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit0,N3))) ) ) )
           => ( ( ( X2 = one2 )
               => ! [N3: num] :
                    ( ( Xa = aa(num,num,bit1,N3) )
                   => ( ( Y = aa(num,option(num),some(num),one2) )
                     => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit1,N3))) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ( ( Xa = one2 )
                     => ( ( Y = none(num) )
                       => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),one2)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit0,N3) )
                         => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un7362597486090784418nd_num(M4,N3)) )
                           => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit0,N3))) ) ) )
                 => ( ! [M4: num] :
                        ( ( X2 = aa(num,num,bit0,M4) )
                       => ! [N3: num] :
                            ( ( Xa = aa(num,num,bit1,N3) )
                           => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un7362597486090784418nd_num(M4,N3)) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit1,N3))) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ( ( Xa = one2 )
                           => ( ( Y = aa(num,option(num),some(num),one2) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),one2)) ) ) )
                     => ( ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit0,N3) )
                               => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un7362597486090784418nd_num(M4,N3)) )
                                 => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit0,N3))) ) ) )
                       => ~ ! [M4: num] :
                              ( ( X2 = aa(num,num,bit1,M4) )
                             => ! [N3: num] :
                                  ( ( Xa = aa(num,num,bit1,N3) )
                                 => ( ( Y = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),aa(num,option(num),some(num),one2)),aTP_Lamp_dy(num,option(num))),bit_un7362597486090784418nd_num(M4,N3)) )
                                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4731106466462545111um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit1,N3))) ) ) ) ) ) ) ) ) ) ) ) ) ) ).

% and_num.pelims
tff(fact_1602_gbinomial__code,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] :
          aa(nat,B,gbinomial(B,A3),K) = $ite(K = zero_zero(nat),one_one(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),set_fo6178422350223883121st_nat(B,aTP_Lamp_eg(B,fun(nat,fun(B,B)),A3),zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),one_one(nat)),one_one(B))),semiring_char_0_fact(B,K))) ) ).

% gbinomial_code
tff(fact_1603_xor__num_Oelims,axiom,
    ! [X2: num,Xa: num,Y: option(num)] :
      ( ( bit_un2480387367778600638or_num(X2,Xa) = Y )
     => ( ( ( X2 = one2 )
         => ( ( Xa = one2 )
           => ( Y != none(num) ) ) )
       => ( ( ( X2 = one2 )
           => ! [N3: num] :
                ( ( Xa = aa(num,num,bit0,N3) )
               => ( Y != aa(num,option(num),some(num),aa(num,num,bit1,N3)) ) ) )
         => ( ( ( X2 = one2 )
             => ! [N3: num] :
                  ( ( Xa = aa(num,num,bit1,N3) )
                 => ( Y != aa(num,option(num),some(num),aa(num,num,bit0,N3)) ) ) )
           => ( ! [M4: num] :
                  ( ( X2 = aa(num,num,bit0,M4) )
                 => ( ( Xa = one2 )
                   => ( Y != aa(num,option(num),some(num),aa(num,num,bit1,M4)) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ! [N3: num] :
                        ( ( Xa = aa(num,num,bit0,N3) )
                       => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un2480387367778600638or_num(M4,N3)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit1,N3) )
                         => ( Y != aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_un2480387367778600638or_num(M4,N3))) ) ) )
                 => ( ! [M4: num] :
                        ( ( X2 = aa(num,num,bit1,M4) )
                       => ( ( Xa = one2 )
                         => ( Y != aa(num,option(num),some(num),aa(num,num,bit0,M4)) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ! [N3: num] :
                              ( ( Xa = aa(num,num,bit0,N3) )
                             => ( Y != aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_un2480387367778600638or_num(M4,N3))) ) ) )
                     => ~ ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit1,N3) )
                               => ( Y != aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un2480387367778600638or_num(M4,N3)) ) ) ) ) ) ) ) ) ) ) ) ) ).

% xor_num.elims
tff(fact_1604_choose__alternating__sum,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_eh(nat,fun(nat,B),N)),aa(nat,set(nat),set_ord_atMost(nat),N)) = zero_zero(B) ) ) ) ).

% choose_alternating_sum
tff(fact_1605_choose__linear__sum,axiom,
    ! [N: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_ei(nat,fun(nat,nat),N)),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))) ).

% choose_linear_sum
tff(fact_1606_binomial__r__part__sum,axiom,
    ! [M: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),binomial(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),aa(num,num,bit0,one2))),M)),one_one(nat)))),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),M)) ).

% binomial_r_part_sum
tff(fact_1607_sum_Otriangle__reindex,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,fun(nat,B)),N: nat] : aa(set(product_prod(nat,nat)),B,aa(fun(product_prod(nat,nat),B),fun(set(product_prod(nat,nat)),B),groups7311177749621191930dd_sum(product_prod(nat,nat),B),aa(fun(nat,fun(nat,B)),fun(product_prod(nat,nat),B),product_case_prod(nat,nat,B),G)),aa(fun(product_prod(nat,nat),$o),set(product_prod(nat,nat)),collect(product_prod(nat,nat)),aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aTP_Lamp_ej(nat,fun(nat,fun(nat,$o)),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_du(fun(nat,fun(nat,B)),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% sum.triangle_reindex
tff(fact_1608_lessThan__eq__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,set(B),set_ord_lessThan(B),X2) = aa(B,set(B),set_ord_lessThan(B),Y) )
        <=> ( X2 = Y ) ) ) ).

% lessThan_eq_iff
tff(fact_1609_lessThan__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,K: B] :
          ( member(B,I,aa(B,set(B),set_ord_lessThan(B),K))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),I),K) ) ) ).

% lessThan_iff
tff(fact_1610_binomial__n__n,axiom,
    ! [N: nat] : aa(nat,nat,binomial(N),N) = one_one(nat) ).

% binomial_n_n
tff(fact_1611_lessThan__subset__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: B,Y: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_lessThan(B),X2)),aa(B,set(B),set_ord_lessThan(B),Y))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y) ) ) ).

% lessThan_subset_iff
tff(fact_1612_binomial__Suc__Suc,axiom,
    ! [N: nat,K: nat] : aa(nat,nat,binomial(aa(nat,nat,suc,N)),aa(nat,nat,suc,K)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,binomial(N),K)),aa(nat,nat,binomial(N),aa(nat,nat,suc,K))) ).

% binomial_Suc_Suc
tff(fact_1613_binomial__n__0,axiom,
    ! [N: nat] : aa(nat,nat,binomial(N),zero_zero(nat)) = one_one(nat) ).

% binomial_n_0
tff(fact_1614_sum_OlessThan__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),N))),aa(nat,B,G,N)) ) ).

% sum.lessThan_Suc
tff(fact_1615_choose__one,axiom,
    ! [N: nat] : aa(nat,nat,binomial(N),one_one(nat)) = N ).

% choose_one
tff(fact_1616_lessThan__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [U: B] : aa(B,set(B),set_ord_lessThan(B),U) = aa(fun(B,$o),set(B),collect(B),aTP_Lamp_ek(B,fun(B,$o),U)) ) ).

% lessThan_def
tff(fact_1617_choose__mult__lemma,axiom,
    ! [M: nat,R: nat,K: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),R)),K)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K))),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K)),K)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),R)),K)),K)),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),R)),M)) ).

% choose_mult_lemma
tff(fact_1618_lessThan__Suc__atMost,axiom,
    ! [K: nat] : aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,K)) = aa(nat,set(nat),set_ord_atMost(nat),K) ).

% lessThan_Suc_atMost
tff(fact_1619_bit__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,fun(nat,$o),bit_se5641148757651400278ts_bit(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),X2) ).

% bit_integer.abs_eq
tff(fact_1620_lessThan__strict__subset__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [M: B,N: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),aa(B,set(B),set_ord_lessThan(B),M)),aa(B,set(B),set_ord_lessThan(B),N))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),N) ) ) ).

% lessThan_strict_subset_iff
tff(fact_1621_Suc__times__binomial__add,axiom,
    ! [A3: nat,B2: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,suc,A3)),aa(nat,nat,binomial(aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2))),aa(nat,nat,suc,A3))) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,suc,B2)),aa(nat,nat,binomial(aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2))),A3)) ).

% Suc_times_binomial_add
tff(fact_1622_binomial__absorb__comp,axiom,
    ! [N: nat,K: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),K)),aa(nat,nat,binomial(N),K)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),K)) ).

% binomial_absorb_comp
tff(fact_1623_fact__fact__dvd__fact,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [K: nat,N: nat] : dvd_dvd(B,aa(B,B,aa(B,fun(B,B),times_times(B),semiring_char_0_fact(B,K)),semiring_char_0_fact(B,N)),semiring_char_0_fact(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),N))) ) ).

% fact_fact_dvd_fact
tff(fact_1624_sum_Onat__diff__reindex,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_el(fun(nat,B),fun(nat,fun(nat,B)),G),N)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% sum.nat_diff_reindex
tff(fact_1625_Iic__subset__Iio__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atMost(B),A3)),aa(B,set(B),set_ord_lessThan(B),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% Iic_subset_Iio_iff
tff(fact_1626_binomial__absorption,axiom,
    ! [K: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,suc,K)),aa(nat,nat,binomial(N),aa(nat,nat,suc,K))) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),K)) ).

% binomial_absorption
tff(fact_1627_sum__diff__distrib,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [Q: fun(B,nat),P: fun(B,nat),N: B] :
          ( ! [X3: B] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,Q,X3)),aa(B,nat,P,X3))
         => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),P),aa(B,set(B),set_ord_lessThan(B),N))),aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),Q),aa(B,set(B),set_ord_lessThan(B),N))) = aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),aa(fun(B,nat),fun(B,nat),aTP_Lamp_em(fun(B,nat),fun(fun(B,nat),fun(B,nat)),Q),P)),aa(B,set(B),set_ord_lessThan(B),N)) ) ) ) ).

% sum_diff_distrib
tff(fact_1628_sum_OlessThan__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% sum.lessThan_Suc_shift
tff(fact_1629_sum__lessThan__telescope,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [F: fun(nat,B),M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bt(fun(nat,B),fun(nat,B),F)),aa(nat,set(nat),set_ord_lessThan(nat),M)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,M)),aa(nat,B,F,zero_zero(nat))) ) ).

% sum_lessThan_telescope
tff(fact_1630_sum__lessThan__telescope_H,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [F: fun(nat,B),M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_do(fun(nat,B),fun(nat,B),F)),aa(nat,set(nat),set_ord_lessThan(nat),M)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,zero_zero(nat))),aa(nat,B,F,M)) ) ).

% sum_lessThan_telescope'
tff(fact_1631_sum_OatLeast1__atMost__eq,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% sum.atLeast1_atMost_eq
tff(fact_1632_sum__bounds__lt__plus1,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [F: fun(nat,B),Mm: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),F)),aa(nat,set(nat),set_ord_lessThan(nat),Mm)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or1337092689740270186AtMost(nat,one_one(nat),Mm)) ) ).

% sum_bounds_lt_plus1
tff(fact_1633_sum_Onested__swap_H,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [A3: fun(nat,fun(nat,B)),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_en(fun(nat,fun(nat,B)),fun(nat,B),A3)),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_ep(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),A3),N)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% sum.nested_swap'
tff(fact_1634_sum__choose__lower,axiom,
    ! [R: nat,N: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_eq(nat,fun(nat,nat),R)),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(nat,nat,binomial(aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),R),N))),N) ).

% sum_choose_lower
tff(fact_1635_choose__rising__sum_I2_J,axiom,
    ! [N: nat,M: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_er(nat,fun(nat,nat),N)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)),one_one(nat))),M) ).

% choose_rising_sum(2)
tff(fact_1636_choose__rising__sum_I1_J,axiom,
    ! [N: nat,M: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_er(nat,fun(nat,nat),N)),aa(nat,set(nat),set_ord_atMost(nat),M)) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)),one_one(nat))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))) ).

% choose_rising_sum(1)
tff(fact_1637_binomial__code,axiom,
    ! [N: nat,K: nat] :
      aa(nat,nat,binomial(N),K) = $ite(
        aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),K),
        zero_zero(nat),
        $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),K)),aa(nat,nat,binomial(N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),K)),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),set_fo6178422350223883121st_nat(nat,times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),K)),one_one(nat)),N,one_one(nat))),semiring_char_0_fact(nat,K))) ) ).

% binomial_code
tff(fact_1638_choose__reduce__nat,axiom,
    ! [N: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
       => ( aa(nat,nat,binomial(N),K) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),one_one(nat)))),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),K)) ) ) ) ).

% choose_reduce_nat
tff(fact_1639_times__binomial__minus1__eq,axiom,
    ! [K: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),K)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),K),aa(nat,nat,binomial(N),K)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),one_one(nat)))) ) ) ).

% times_binomial_minus1_eq
tff(fact_1640_one__diff__power__eq,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat] : aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% one_diff_power_eq
tff(fact_1641_power__diff__1__eq,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)),one_one(B)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),one_one(B))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% power_diff_1_eq
tff(fact_1642_geometric__sum,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [X2: B,N: nat] :
          ( ( X2 != one_one(B) )
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)),one_one(B))),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),one_one(B))) ) ) ) ).

% geometric_sum
tff(fact_1643_sum_OatMost__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% sum.atMost_shift
tff(fact_1644_vandermonde,axiom,
    ! [M: nat,N: nat,R: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aa(nat,fun(nat,nat),aa(nat,fun(nat,fun(nat,nat)),aTP_Lamp_es(nat,fun(nat,fun(nat,fun(nat,nat))),M),N),R)),aa(nat,set(nat),set_ord_atMost(nat),R)) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),R) ).

% vandermonde
tff(fact_1645_binomial__addition__formula,axiom,
    ! [N: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,nat,binomial(N),aa(nat,nat,suc,K)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),aa(nat,nat,suc,K))),aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),K)) ) ) ).

% binomial_addition_formula
tff(fact_1646_power__diff__sumr2,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat,Y: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Y)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aa(nat,fun(B,fun(nat,B)),aTP_Lamp_et(B,fun(nat,fun(B,fun(nat,B))),X2),N),Y)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% power_diff_sumr2
tff(fact_1647_diff__power__eq__sum,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat,Y: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),aa(nat,nat,suc,N))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Y),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Y)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),aa(nat,fun(B,fun(nat,B)),aTP_Lamp_eu(B,fun(nat,fun(B,fun(nat,B))),X2),N),Y)),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N)))) ) ).

% diff_power_eq_sum
tff(fact_1648_sum__gp__strict,axiom,
    ! [B: $tType] :
      ( ( division_ring(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(B,fun(nat,B),power_power(B),X2)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = $ite(X2 = one_one(B),aa(nat,B,semiring_1_of_nat(B),N),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N))),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2))) ) ).

% sum_gp_strict
tff(fact_1649_binomial,axiom,
    ! [A3: nat,B2: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),B2)),N) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aa(nat,fun(nat,nat),aa(nat,fun(nat,fun(nat,nat)),aTP_Lamp_ev(nat,fun(nat,fun(nat,fun(nat,nat))),A3),B2),N)),aa(nat,set(nat),set_ord_atMost(nat),N)) ).

% binomial
tff(fact_1650_choose__two,axiom,
    ! [N: nat] : aa(nat,nat,binomial(N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) ).

% choose_two
tff(fact_1651_one__diff__power__eq_H,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [X2: B,N: nat] : aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(nat,B,aa(B,fun(nat,B),power_power(B),X2),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),X2)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_ew(B,fun(nat,fun(nat,B)),X2),N)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% one_diff_power_eq'
tff(fact_1652_binomial__ring,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,B2: B,N: nat] : aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),N) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aa(B,fun(nat,fun(nat,B)),aTP_Lamp_ex(B,fun(B,fun(nat,fun(nat,B))),A3),B2),N)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ).

% binomial_ring
tff(fact_1653_xor__num_Osimps_I6_J,axiom,
    ! [M: num,N: num] : bit_un2480387367778600638or_num(aa(num,num,bit0,M),aa(num,num,bit1,N)) = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_un2480387367778600638or_num(M,N))) ).

% xor_num.simps(6)
tff(fact_1654_xor__num_Osimps_I8_J,axiom,
    ! [M: num,N: num] : bit_un2480387367778600638or_num(aa(num,num,bit1,M),aa(num,num,bit0,N)) = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_un2480387367778600638or_num(M,N))) ).

% xor_num.simps(8)
tff(fact_1655_choose__alternating__linear__sum,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [N: nat] :
          ( ( N != one_one(nat) )
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_ey(nat,fun(nat,B),N)),aa(nat,set(nat),set_ord_atMost(nat),N)) = zero_zero(B) ) ) ) ).

% choose_alternating_linear_sum
tff(fact_1656_fact__Suc__0,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ( semiring_char_0_fact(B,aa(nat,nat,suc,zero_zero(nat))) = one_one(B) ) ) ).

% fact_Suc_0
tff(fact_1657_fact__1,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ( semiring_char_0_fact(B,one_one(nat)) = one_one(B) ) ) ).

% fact_1
tff(fact_1658_fact__0,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ( semiring_char_0_fact(B,zero_zero(nat)) = one_one(B) ) ) ).

% fact_0
tff(fact_1659_fact__code,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: nat] : semiring_char_0_fact(B,N) = aa(nat,B,semiring_1_of_nat(B),set_fo6178422350223883121st_nat(nat,times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N,one_one(nat))) ) ).

% fact_code
tff(fact_1660_fact__reduce,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
         => ( semiring_char_0_fact(B,N) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),N)),semiring_char_0_fact(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))) ) ) ) ).

% fact_reduce
tff(fact_1661_fact__num__eq__if,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [M: nat] :
          semiring_char_0_fact(B,M) = $ite(M = zero_zero(nat),one_one(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),M)),semiring_char_0_fact(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))))) ) ).

% fact_num_eq_if
tff(fact_1662_xor__num_Opelims,axiom,
    ! [X2: num,Xa: num,Y: option(num)] :
      ( ( bit_un2480387367778600638or_num(X2,Xa) = Y )
     => ( aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),X2),Xa))
       => ( ( ( X2 = one2 )
           => ( ( Xa = one2 )
             => ( ( Y = none(num) )
               => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),one2)) ) ) )
         => ( ( ( X2 = one2 )
             => ! [N3: num] :
                  ( ( Xa = aa(num,num,bit0,N3) )
                 => ( ( Y = aa(num,option(num),some(num),aa(num,num,bit1,N3)) )
                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit0,N3))) ) ) )
           => ( ( ( X2 = one2 )
               => ! [N3: num] :
                    ( ( Xa = aa(num,num,bit1,N3) )
                   => ( ( Y = aa(num,option(num),some(num),aa(num,num,bit0,N3)) )
                     => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit1,N3))) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ( ( Xa = one2 )
                     => ( ( Y = aa(num,option(num),some(num),aa(num,num,bit1,M4)) )
                       => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),one2)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit0,N3) )
                         => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un2480387367778600638or_num(M4,N3)) )
                           => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit0,N3))) ) ) )
                 => ( ! [M4: num] :
                        ( ( X2 = aa(num,num,bit0,M4) )
                       => ! [N3: num] :
                            ( ( Xa = aa(num,num,bit1,N3) )
                           => ( ( Y = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_un2480387367778600638or_num(M4,N3))) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit1,N3))) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ( ( Xa = one2 )
                           => ( ( Y = aa(num,option(num),some(num),aa(num,num,bit0,M4)) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),one2)) ) ) )
                     => ( ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit0,N3) )
                               => ( ( Y = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_un2480387367778600638or_num(M4,N3))) )
                                 => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit0,N3))) ) ) )
                       => ~ ! [M4: num] :
                              ( ( X2 = aa(num,num,bit1,M4) )
                             => ! [N3: num] :
                                  ( ( Xa = aa(num,num,bit1,N3) )
                                 => ( ( Y = aa(option(num),option(num),aa(fun(num,num),fun(option(num),option(num)),map_option(num,num),bit0),bit_un2480387367778600638or_num(M4,N3)) )
                                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un2901131394128224187um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit1,N3))) ) ) ) ) ) ) ) ) ) ) ) ) ) ).

% xor_num.pelims
tff(fact_1663_dvd__fact,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),M)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => dvd_dvd(nat,M,semiring_char_0_fact(nat,N)) ) ) ).

% dvd_fact
tff(fact_1664_fact__ge__1,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [N: nat] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),semiring_char_0_fact(B,N)) ) ).

% fact_ge_1
tff(fact_1665_pochhammer__double,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Z2: B,N: nat] : comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Z2),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)))),comm_s3205402744901411588hammer(B,Z2,N))),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),N)) ) ).

% pochhammer_double
tff(fact_1666_fact__double,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [N: nat] : semiring_char_0_fact(B,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N))),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N))),semiring_char_0_fact(B,N)) ) ).

% fact_double
tff(fact_1667_pochhammer__code,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] :
          comm_s3205402744901411588hammer(B,A3,N) = $ite(N = zero_zero(nat),one_one(B),set_fo6178422350223883121st_nat(B,aTP_Lamp_ez(B,fun(nat,fun(B,B)),A3),zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),one_one(B))) ) ).

% pochhammer_code
tff(fact_1668_xor__Suc__0__eq,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),N),aa(nat,nat,suc,zero_zero(nat))) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa($o,nat,zero_neq_one_of_bool(nat),dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N)))),aa($o,nat,zero_neq_one_of_bool(nat),~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N))) ).

% xor_Suc_0_eq
tff(fact_1669_Suc__0__xor__eq,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),aa(nat,nat,suc,zero_zero(nat))),N) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa($o,nat,zero_neq_one_of_bool(nat),dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N)))),aa($o,nat,zero_neq_one_of_bool(nat),~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N))) ).

% Suc_0_xor_eq
tff(fact_1670_push__bit__numeral__minus__1,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: num] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),aa(num,nat,numeral_numeral(nat),N)),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(num,nat,numeral_numeral(nat),N))) ) ).

% push_bit_numeral_minus_1
tff(fact_1671_num__of__integer__code,axiom,
    ! [K: code_integer] :
      aa(code_integer,num,code_num_of_integer,K) = $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),K),one_one(code_integer)),one2,aa(product_prod(code_integer,code_integer),num,aa(fun(code_integer,fun(code_integer,num)),fun(product_prod(code_integer,code_integer),num),product_case_prod(code_integer,code_integer,num),aTP_Lamp_fa(code_integer,fun(code_integer,num))),code_divmod_integer(K,aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))))) ).

% num_of_integer_code
tff(fact_1672_Sum__Ico__nat,axiom,
    ! [M: nat,N: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_bz(nat,nat)),set_or7035219750837199246ssThan(nat,M,N)) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),one_one(nat))))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))) ).

% Sum_Ico_nat
tff(fact_1673_ivl__diff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [I: B,N: B,M: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),N)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),set_or7035219750837199246ssThan(B,I,M)),set_or7035219750837199246ssThan(B,I,N)) = set_or7035219750837199246ssThan(B,N,M) ) ) ) ).

% ivl_diff
tff(fact_1674_push__bit__push__bit,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [M: nat,N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),M),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),A3)) = aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),A3) ) ).

% push_bit_push_bit
tff(fact_1675_lessThan__minus__lessThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [N: B,M: B] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),aa(B,set(B),set_ord_lessThan(B),N)),aa(B,set(B),set_ord_lessThan(B),M)) = set_or7035219750837199246ssThan(B,M,N) ) ).

% lessThan_minus_lessThan
tff(fact_1676_pochhammer__1,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B] : comm_s3205402744901411588hammer(B,A3,one_one(nat)) = A3 ) ).

% pochhammer_1
tff(fact_1677_atLeastLessThan__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,L: B,U: B] :
          ( member(B,I,set_or7035219750837199246ssThan(B,L,U))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),I)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),I),U) ) ) ) ).

% atLeastLessThan_iff
tff(fact_1678_ivl__subset,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [I: B,J: B,M: B,N: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or7035219750837199246ssThan(B,I,J)),set_or7035219750837199246ssThan(B,M,N))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),J),I)
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),I)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),J),N) ) ) ) ) ).

% ivl_subset
tff(fact_1679_pochhammer__0,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B] : comm_s3205402744901411588hammer(B,A3,zero_zero(nat)) = one_one(B) ) ).

% pochhammer_0
tff(fact_1680_xor__numerals_I1_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,Y))) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y)) ) ).

% xor_numerals(1)
tff(fact_1681_xor__numerals_I2_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = aa(num,B,numeral_numeral(B),aa(num,num,bit0,Y)) ) ).

% xor_numerals(2)
tff(fact_1682_xor__numerals_I5_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,X2))),one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2)) ) ).

% xor_numerals(5)
tff(fact_1683_xor__numerals_I8_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit0,X2)) ) ).

% xor_numerals(8)
tff(fact_1684_push__bit__of__1,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),one_one(B)) = aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N) ) ).

% push_bit_of_1
tff(fact_1685_sum_Oop__ivl__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),zero_zero(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))),aa(nat,B,G,N))) ) ).

% sum.op_ivl_Suc
tff(fact_1686_xor__numerals_I4_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num,Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,X2))),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),X2)),aa(num,B,numeral_numeral(B),Y)))) ) ).

% xor_numerals(4)
tff(fact_1687_xor__numerals_I6_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num,Y: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,Y))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),X2)),aa(num,B,numeral_numeral(B),Y)))) ) ).

% xor_numerals(6)
tff(fact_1688_flip__bit__nat__def,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se8732182000553998342ip_bit(nat),M),N) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),bit_se4730199178511100633sh_bit(nat),M),one_one(nat))) ).

% flip_bit_nat_def
tff(fact_1689_push__bit__integer_Oabs__eq,axiom,
    ! [Xa: nat,X2: int] : aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se4730199178511100633sh_bit(code_integer),Xa),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(nat,fun(int,int),bit_se4730199178511100633sh_bit(int),Xa),X2)) ).

% push_bit_integer.abs_eq
tff(fact_1690_atLeastLessThan__inj_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( set_or7035219750837199246ssThan(B,A3,B2) = set_or7035219750837199246ssThan(B,C2,D3) )
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),D3)
             => ( B2 = D3 ) ) ) ) ) ).

% atLeastLessThan_inj(2)
tff(fact_1691_atLeastLessThan__inj_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( set_or7035219750837199246ssThan(B,A3,B2) = set_or7035219750837199246ssThan(B,C2,D3) )
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),D3)
             => ( A3 = C2 ) ) ) ) ) ).

% atLeastLessThan_inj(1)
tff(fact_1692_atLeastLessThan__eq__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),C2),D3)
           => ( ( set_or7035219750837199246ssThan(B,A3,B2) = set_or7035219750837199246ssThan(B,C2,D3) )
            <=> ( ( A3 = C2 )
                & ( B2 = D3 ) ) ) ) ) ) ).

% atLeastLessThan_eq_iff
tff(fact_1693_flip__bit__eq__xor,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se8732182000553998342ip_bit(B),N),A3) = aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),A3),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),one_one(B))) ) ).

% flip_bit_eq_xor
tff(fact_1694_push__bit__add,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B,B2: B] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),A3)),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),B2)) ) ).

% push_bit_add
tff(fact_1695_atLeastLessThan__subset__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or7035219750837199246ssThan(B,A3,B2)),set_or7035219750837199246ssThan(B,C2,D3))
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% atLeastLessThan_subset_iff
tff(fact_1696_atLeastLessThanSuc__atLeastAtMost,axiom,
    ! [L: nat,U: nat] : set_or7035219750837199246ssThan(nat,L,aa(nat,nat,suc,U)) = set_or1337092689740270186AtMost(nat,L,U) ).

% atLeastLessThanSuc_atLeastAtMost
tff(fact_1697_lessThan__atLeast0,axiom,
    ! [N: nat] : aa(nat,set(nat),set_ord_lessThan(nat),N) = set_or7035219750837199246ssThan(nat,zero_zero(nat),N) ).

% lessThan_atLeast0
tff(fact_1698_push__bit__take__bit,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [M: nat,N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),M),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),A3)) = aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),M),A3)) ) ).

% push_bit_take_bit
tff(fact_1699_pochhammer__fact,axiom,
    ! [B: $tType] :
      ( ( semiring_char_0(B)
        & comm_semiring_1(B) )
     => ! [N: nat] : semiring_char_0_fact(B,N) = comm_s3205402744901411588hammer(B,one_one(B),N) ) ).

% pochhammer_fact
tff(fact_1700_sum_Oshift__bounds__Suc__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bp(fun(nat,B),fun(nat,B),G)),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% sum.shift_bounds_Suc_ivl
tff(fact_1701_sum_Oshift__bounds__nat__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_bq(fun(nat,B),fun(nat,fun(nat,B)),G),K)),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% sum.shift_bounds_nat_ivl
tff(fact_1702_sum_Oivl__cong,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & comm_monoid_add(C) )
     => ! [A3: B,C2: B,B2: B,D3: B,G: fun(B,C),Ha: fun(B,C)] :
          ( ( A3 = C2 )
         => ( ( B2 = D3 )
           => ( ! [X3: B] :
                  ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),X3)
                 => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X3),D3)
                   => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),set_or7035219750837199246ssThan(B,A3,B2)) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),Ha),set_or7035219750837199246ssThan(B,C2,D3)) ) ) ) ) ) ).

% sum.ivl_cong
tff(fact_1703_sum_OatLeastLessThan__concat,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,P3: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),P3)
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,N,P3))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,P3)) ) ) ) ) ).

% sum.atLeastLessThan_concat
tff(fact_1704_sum__diff__nat__ivl,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [M: nat,N: nat,P3: nat,F: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),P3)
           => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or7035219750837199246ssThan(nat,M,P3))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or7035219750837199246ssThan(nat,M,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or7035219750837199246ssThan(nat,N,P3)) ) ) ) ) ).

% sum_diff_nat_ivl
tff(fact_1705_pochhammer__0__left,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [N: nat] :
          comm_s3205402744901411588hammer(B,zero_zero(B),N) = $ite(N = zero_zero(nat),one_one(B),zero_zero(B)) ) ).

% pochhammer_0_left
tff(fact_1706_sum_OatLeast__Suc__lessThan__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% sum.atLeast_Suc_lessThan_Suc_shift
tff(fact_1707_sum_OatLeastLessThan__shift__bounds,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),K))),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% sum.atLeastLessThan_shift_bounds
tff(fact_1708_concat__bit__eq,axiom,
    ! [N: nat,K: int,L: int] : bit_concat_bit(N,K,L) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),N),K)),aa(int,int,aa(nat,fun(int,int),bit_se4730199178511100633sh_bit(int),N),L)) ).

% concat_bit_eq
tff(fact_1709_atLeastAtMost__subseteq__atLeastLessThan__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or1337092689740270186AtMost(B,A3,B2)),set_or7035219750837199246ssThan(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),D3) ) ) ) ) ).

% atLeastAtMost_subseteq_atLeastLessThan_iff
tff(fact_1710_atLeastLessThan__subseteq__atLeastAtMost__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or7035219750837199246ssThan(B,A3,B2)),set_or1337092689740270186AtMost(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% atLeastLessThan_subseteq_atLeastAtMost_iff
tff(fact_1711_sum__shift__lb__Suc0__0__upt,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [F: fun(nat,B),K: nat] :
          ( ( aa(nat,B,F,zero_zero(nat)) = zero_zero(B) )
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,zero_zero(nat)),K)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),F),set_or7035219750837199246ssThan(nat,zero_zero(nat),K)) ) ) ) ).

% sum_shift_lb_Suc0_0_upt
tff(fact_1712_sum_OatLeast0__lessThan__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))),aa(nat,B,G,N)) ) ).

% sum.atLeast0_lessThan_Suc
tff(fact_1713_sum_OatLeast__Suc__lessThan,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),N))) ) ) ) ).

% sum.atLeast_Suc_lessThan
tff(fact_1714_sum_OatLeastLessThan__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [A3: nat,B2: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),B2)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,A3,aa(nat,nat,suc,B2))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,A3,B2))),aa(nat,B,G,B2)) ) ) ) ).

% sum.atLeastLessThan_Suc
tff(fact_1715_sum_Olast__plus,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,N)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))) ) ) ) ).

% sum.last_plus
tff(fact_1716_pochhammer__rec,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] : comm_s3205402744901411588hammer(B,A3,aa(nat,nat,suc,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B)),N)) ) ).

% pochhammer_rec
tff(fact_1717_pochhammer__Suc,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] : comm_s3205402744901411588hammer(B,A3,aa(nat,nat,suc,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),comm_s3205402744901411588hammer(B,A3,N)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa(nat,B,semiring_1_of_nat(B),N))) ) ).

% pochhammer_Suc
tff(fact_1718_pochhammer__rec_H,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Z2: B,N: nat] : comm_s3205402744901411588hammer(B,Z2,aa(nat,nat,suc,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),aa(nat,B,semiring_1_of_nat(B),N))),comm_s3205402744901411588hammer(B,Z2,N)) ) ).

% pochhammer_rec'
tff(fact_1719_pochhammer__product_H,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Z2: B,N: nat,M: nat] : comm_s3205402744901411588hammer(B,Z2,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)) = aa(B,B,aa(B,fun(B,B),times_times(B),comm_s3205402744901411588hammer(B,Z2,N)),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),aa(nat,B,semiring_1_of_nat(B),N)),M)) ) ).

% pochhammer_product'
tff(fact_1720_bit__iff__and__push__bit__not__eq__0,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B,N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N)
        <=> ( aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),one_one(B))) != zero_zero(B) ) ) ) ).

% bit_iff_and_push_bit_not_eq_0
tff(fact_1721_sum__Suc__diff_H,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [M: nat,N: nat,F: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_bt(fun(nat,B),fun(nat,B),F)),set_or7035219750837199246ssThan(nat,M,N)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,F,N)),aa(nat,B,F,M)) ) ) ) ).

% sum_Suc_diff'
tff(fact_1722_sum_OatLeastLessThan__rev,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fb(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or7035219750837199246ssThan(nat,N,M)) ) ).

% sum.atLeastLessThan_rev
tff(fact_1723_sum_Onested__swap,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [A3: fun(nat,fun(nat,B)),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aTP_Lamp_fc(fun(nat,fun(nat,B)),fun(nat,B),A3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_ep(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),A3),N)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N)) ) ).

% sum.nested_swap
tff(fact_1724_sum_Onat__group,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fd(fun(nat,B),fun(nat,fun(nat,B)),G),K)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),K))) ) ).

% sum.nat_group
tff(fact_1725_numeral__xor__num,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(num,B,numeral_numeral(B),M)),aa(num,B,numeral_numeral(B),N)) = aa(option(num),B,aa(fun(num,B),fun(option(num),B),aa(B,fun(fun(num,B),fun(option(num),B)),case_option(B,num),zero_zero(B)),numeral_numeral(B)),bit_un2480387367778600638or_num(M,N)) ) ).

% numeral_xor_num
tff(fact_1726_sum_Ohead__if,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),zero_zero(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))),aa(nat,B,G,N))) ) ).

% sum.head_if
tff(fact_1727_sum_OatLeast0__lessThan__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))) ) ).

% sum.atLeast0_lessThan_Suc_shift
tff(fact_1728_sum_OatLeastLessThan__shift__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),M))),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ).

% sum.atLeastLessThan_shift_0
tff(fact_1729_pochhammer__product,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [M: nat,N: nat,Z2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( comm_s3205402744901411588hammer(B,Z2,N) = aa(B,B,aa(B,fun(B,B),times_times(B),comm_s3205402744901411588hammer(B,Z2,M)),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),aa(nat,B,semiring_1_of_nat(B),M)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ) ) ).

% pochhammer_product
tff(fact_1730_sum_OatLeastLessThan__rev__at__least__Suc__atMost,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),N: nat,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_bs(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,N),M)) ) ).

% sum.atLeastLessThan_rev_at_least_Suc_atMost
tff(fact_1731_sum_OatLeast__lessThan__pred__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aTP_Lamp_bv(nat,nat))),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% sum.atLeast_lessThan_pred_shift
tff(fact_1732_pochhammer__absorb__comp,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [R: B,K: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),R),aa(nat,B,semiring_1_of_nat(B),K))),comm_s3205402744901411588hammer(B,aa(B,B,uminus_uminus(B),R),K)) = aa(B,B,aa(B,fun(B,B),times_times(B),R),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),R)),one_one(B)),K)) ) ).

% pochhammer_absorb_comp
tff(fact_1733_pochhammer__same,axiom,
    ! [B: $tType] :
      ( ( semiring_char_0(B)
        & comm_ring_1(B)
        & semiri3467727345109120633visors(B) )
     => ! [N: nat] : comm_s3205402744901411588hammer(B,aa(B,B,uminus_uminus(B),aa(nat,B,semiring_1_of_nat(B),N)),N) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),N)),semiring_char_0_fact(B,N)) ) ).

% pochhammer_same
tff(fact_1734_pochhammer__minus,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [B2: B,K: nat] : comm_s3205402744901411588hammer(B,aa(B,B,uminus_uminus(B),B2),K) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),K)),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),aa(nat,B,semiring_1_of_nat(B),K))),one_one(B)),K)) ) ).

% pochhammer_minus
tff(fact_1735_pochhammer__minus_H,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [B2: B,K: nat] : comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),aa(nat,B,semiring_1_of_nat(B),K))),one_one(B)),K) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),K)),comm_s3205402744901411588hammer(B,aa(B,B,uminus_uminus(B),B2),K)) ) ).

% pochhammer_minus'
tff(fact_1736_gbinomial__pochhammer_H,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,A3),K) = aa(B,B,aa(B,fun(B,B),divide_divide(B),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),aa(nat,B,semiring_1_of_nat(B),K))),one_one(B)),K)),semiring_char_0_fact(B,K)) ) ).

% gbinomial_pochhammer'
tff(fact_1737_gbinomial__pochhammer,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: B,K: nat] : aa(nat,B,gbinomial(B,A3),K) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),K)),comm_s3205402744901411588hammer(B,aa(B,B,uminus_uminus(B),A3),K))),semiring_char_0_fact(B,K)) ) ).

% gbinomial_pochhammer
tff(fact_1738_xor__nat__unfold,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),M),N) = $ite(
        M = zero_zero(nat),
        N,
        $ite(N = zero_zero(nat),M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))))) ) ).

% xor_nat_unfold
tff(fact_1739_num__of__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,num,code_num_of_integer,aa(int,code_integer,code_integer_of_int,X2)) = aa(nat,num,num_of_nat,aa(int,nat,nat2,X2)) ).

% num_of_integer.abs_eq
tff(fact_1740_signed__take__bit__code,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat,A3: B] :
          bit_ri4674362597316999326ke_bit(B,N,A3) = $let(
            l: B,
            l:= aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,suc,N)),A3),
            $ite(aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),l),N),aa(B,B,aa(B,fun(B,B),plus_plus(B),l),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),aa(nat,nat,suc,N)),aa(B,B,uminus_uminus(B),one_one(B)))),l) ) ) ).

% signed_take_bit_code
tff(fact_1741_xor__nat__rec,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),M),N) = aa(nat,nat,
        aa(nat,fun(nat,nat),plus_plus(nat),
          aa($o,nat,zero_neq_one_of_bool(nat),
            ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),M) != ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N))),
        aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))))) ).

% xor_nat_rec
tff(fact_1742_xor__one__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),A3),one_one(B)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa($o,B,zero_neq_one_of_bool(B),dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)))),aa($o,B,zero_neq_one_of_bool(B),~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3))) ) ).

% xor_one_eq
tff(fact_1743_one__xor__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),one_one(B)),A3) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa($o,B,zero_neq_one_of_bool(B),dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3)))),aa($o,B,zero_neq_one_of_bool(B),~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3))) ) ).

% one_xor_eq
tff(fact_1744_pochhammer__binomial__sum,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [A3: B,B2: B,N: nat] : comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2),N) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aa(B,fun(nat,fun(nat,B)),aTP_Lamp_fe(B,fun(B,fun(nat,fun(nat,B))),A3),B2),N)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ).

% pochhammer_binomial_sum
tff(fact_1745_divmod__integer__def,axiom,
    ! [K: code_integer,L: code_integer] : code_divmod_integer(K,L) = aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),K),L)),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),K),L)) ).

% divmod_integer_def
tff(fact_1746_sum__power2,axiom,
    ! [K: nat] : aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),set_or7035219750837199246ssThan(nat,zero_zero(nat),K)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),K)),one_one(nat)) ).

% sum_power2
tff(fact_1747_nat__of__integer__code,axiom,
    ! [K: code_integer] :
      aa(code_integer,nat,code_nat_of_integer,K) = $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),K),zero_zero(code_integer)),zero_zero(nat),aa(product_prod(code_integer,code_integer),nat,aa(fun(code_integer,fun(code_integer,nat)),fun(product_prod(code_integer,code_integer),nat),product_case_prod(code_integer,code_integer,nat),aTP_Lamp_ff(code_integer,fun(code_integer,nat))),code_divmod_integer(K,aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))))) ).

% nat_of_integer_code
tff(fact_1748_pochhammer__times__pochhammer__half,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Z2: B,N: nat] : aa(B,B,aa(B,fun(B,B),times_times(B),comm_s3205402744901411588hammer(B,Z2,aa(nat,nat,suc,N))),comm_s3205402744901411588hammer(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),Z2),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fg(B,fun(nat,B),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),aa(num,num,bit0,one2))),N)),one_one(nat)))) ) ).

% pochhammer_times_pochhammer_half
tff(fact_1749_int__of__integer__code,axiom,
    ! [K: code_integer] :
      aa(code_integer,int,code_int_of_integer,K) = $ite(
        aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),K),zero_zero(code_integer)),
        aa(int,int,uminus_uminus(int),aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,uminus_uminus(code_integer),K))),
        $ite(K = zero_zero(code_integer),zero_zero(int),aa(product_prod(code_integer,code_integer),int,aa(fun(code_integer,fun(code_integer,int)),fun(product_prod(code_integer,code_integer),int),product_case_prod(code_integer,code_integer,int),aTP_Lamp_fh(code_integer,fun(code_integer,int))),code_divmod_integer(K,aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))))) ) ).

% int_of_integer_code
tff(fact_1750_divmod__integer__eq__cases,axiom,
    ! [K: code_integer,L: code_integer] :
      code_divmod_integer(K,L) = $ite(
        K = zero_zero(code_integer),
        aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),zero_zero(code_integer)),zero_zero(code_integer)),
        $ite(
          L = zero_zero(code_integer),
          aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),zero_zero(code_integer)),K),
          aa(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer),aa(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),aa(fun(code_integer,code_integer),fun(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer))),aa(fun(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer))),fun(fun(code_integer,code_integer),fun(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)))),comp(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),code_integer),aa(fun(code_integer,fun(code_integer,code_integer)),fun(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer))),aa(fun(fun(code_integer,code_integer),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer))),fun(fun(code_integer,fun(code_integer,code_integer)),fun(code_integer,fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)))),comp(fun(code_integer,code_integer),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),code_integer),product_apsnd(code_integer,code_integer,code_integer)),times_times(code_integer))),sgn_sgn(code_integer)),L),
            $ite(aa(code_integer,code_integer,sgn_sgn(code_integer),K) = aa(code_integer,code_integer,sgn_sgn(code_integer),L),code_divmod_abs(K,L),aa(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer),aa(fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),product_case_prod(code_integer,code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_fi(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),L)),code_divmod_abs(K,L)))) ) ) ).

% divmod_integer_eq_cases
tff(fact_1751_time__def,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),Ha: heap_ext(product_unit)] : time_time(B,C2,Ha) = aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),nat,aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),nat),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),nat),aa(nat,fun(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),nat),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),nat)),case_option(nat,product_prod(B,product_prod(heap_ext(product_unit),nat))),zero_zero(nat)),aa(fun(B,fun(product_prod(heap_ext(product_unit),nat),nat)),fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),nat),product_case_prod(B,product_prod(heap_ext(product_unit),nat),nat),aTP_Lamp_fk(B,fun(product_prod(heap_ext(product_unit),nat),nat)))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha)) ).

% time_def
tff(fact_1752_bit__cut__integer__def,axiom,
    ! [K: code_integer] : code_bit_cut_integer(K) = aa($o,product_prod(code_integer,$o),aa(code_integer,fun($o,product_prod(code_integer,$o)),product_Pair(code_integer,$o),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),K),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),~ dvd_dvd(code_integer,aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)),K)) ).

% bit_cut_integer_def
tff(fact_1753_integer__of__num_I3_J,axiom,
    ! [N: num] :
      aa(num,code_integer,code_integer_of_num,aa(num,num,bit1,N)) = $let(
        k: code_integer,
        k:= aa(num,code_integer,code_integer_of_num,N),
        aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),k),k)),one_one(code_integer)) ) ).

% integer_of_num(3)
tff(fact_1754_less__eq__int_Orep__eq,axiom,
    ! [X2: int,Xa: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X2),Xa)
    <=> aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o)))),aa(int,product_prod(nat,nat),rep_Integ,X2)),aa(int,product_prod(nat,nat),rep_Integ,Xa)) ) ).

% less_eq_int.rep_eq
tff(fact_1755_nat__of__integer__of__nat,axiom,
    ! [N: nat] : aa(code_integer,nat,code_nat_of_integer,aa(nat,code_integer,semiring_1_of_nat(code_integer),N)) = N ).

% nat_of_integer_of_nat
tff(fact_1756_int__of__integer__of__nat,axiom,
    ! [N: nat] : aa(code_integer,int,code_int_of_integer,aa(nat,code_integer,semiring_1_of_nat(code_integer),N)) = aa(nat,int,semiring_1_of_nat(int),N) ).

% int_of_integer_of_nat
tff(fact_1757_integer__of__int__int__of__integer,axiom,
    ! [K: code_integer] : aa(int,code_integer,code_integer_of_int,aa(code_integer,int,code_int_of_integer,K)) = K ).

% integer_of_int_int_of_integer
tff(fact_1758_int__of__integer__integer__of__int,axiom,
    ! [K: int] : aa(code_integer,int,code_int_of_integer,aa(int,code_integer,code_integer_of_int,K)) = K ).

% int_of_integer_integer_of_int
tff(fact_1759_int__of__integer__inverse,axiom,
    ! [X2: code_integer] : aa(int,code_integer,code_integer_of_int,aa(code_integer,int,code_int_of_integer,X2)) = X2 ).

% int_of_integer_inverse
tff(fact_1760_apsnd__conv,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,C),X2: B,Y: D] : aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),F),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),X2),Y)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),aa(D,C,F,Y)) ).

% apsnd_conv
tff(fact_1761_prod_Oneutral__const,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A4: set(C)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),aTP_Lamp_fl(C,B)),A4) = one_one(B) ) ).

% prod.neutral_const
tff(fact_1762_of__int__integer__of,axiom,
    ! [K: code_integer] : aa(int,code_integer,ring_1_of_int(code_integer),aa(code_integer,int,code_int_of_integer,K)) = K ).

% of_int_integer_of
tff(fact_1763_int__of__integer__of__int,axiom,
    ! [K: int] : aa(code_integer,int,code_int_of_integer,aa(int,code_integer,ring_1_of_int(code_integer),K)) = K ).

% int_of_integer_of_int
tff(fact_1764_zero__integer_Orep__eq,axiom,
    aa(code_integer,int,code_int_of_integer,zero_zero(code_integer)) = zero_zero(int) ).

% zero_integer.rep_eq
tff(fact_1765_int__of__integer__numeral,axiom,
    ! [K: num] : aa(code_integer,int,code_int_of_integer,aa(num,code_integer,numeral_numeral(code_integer),K)) = aa(num,int,numeral_numeral(int),K) ).

% int_of_integer_numeral
tff(fact_1766_plus__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% plus_integer.rep_eq
tff(fact_1767_one__integer_Orep__eq,axiom,
    aa(code_integer,int,code_int_of_integer,one_one(code_integer)) = one_one(int) ).

% one_integer.rep_eq
tff(fact_1768_uminus__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,uminus_uminus(code_integer),X2)) = aa(int,int,uminus_uminus(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% uminus_integer.rep_eq
tff(fact_1769_times__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),times_times(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% times_integer.rep_eq
tff(fact_1770_minus__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% minus_integer.rep_eq
tff(fact_1771_abs__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,abs_abs(code_integer),X2)) = aa(int,int,abs_abs(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% abs_integer.rep_eq
tff(fact_1772_divide__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% divide_integer.rep_eq
tff(fact_1773_modulo__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),modulo_modulo(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% modulo_integer.rep_eq
tff(fact_1774_sgn__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,sgn_sgn(code_integer),X2)) = aa(int,int,sgn_sgn(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% sgn_integer.rep_eq
tff(fact_1775_prod_OatMost__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),N))),aa(nat,B,G,aa(nat,nat,suc,N))) ) ).

% prod.atMost_Suc
tff(fact_1776_prod_OlessThan__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),N))),aa(nat,B,G,N)) ) ).

% prod.lessThan_Suc
tff(fact_1777_nat__of__integer__non__positive,axiom,
    ! [K: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),K),zero_zero(code_integer))
     => ( aa(code_integer,nat,code_nat_of_integer,K) = zero_zero(nat) ) ) ).

% nat_of_integer_non_positive
tff(fact_1778_prod_Ocl__ivl__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,N)),M),one_one(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))),aa(nat,B,G,aa(nat,nat,suc,N)))) ) ).

% prod.cl_ivl_Suc
tff(fact_1779_prod_Oop__ivl__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),one_one(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))),aa(nat,B,G,N))) ) ).

% prod.op_ivl_Suc
tff(fact_1780_xor__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),bit_se5824344971392196577ns_xor(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),bit_se5824344971392196577ns_xor(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% xor_integer.rep_eq
tff(fact_1781_push__bit__integer_Orep__eq,axiom,
    ! [X2: nat,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se4730199178511100633sh_bit(code_integer),X2),Xa)) = aa(int,int,aa(nat,fun(int,int),bit_se4730199178511100633sh_bit(int),X2),aa(code_integer,int,code_int_of_integer,Xa)) ).

% push_bit_integer.rep_eq
tff(fact_1782_xor__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),bit_se5824344971392196577ns_xor(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),bit_se5824344971392196577ns_xor(int),Xa),X2)) ).

% xor_integer.abs_eq
tff(fact_1783_nat__of__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,nat,code_nat_of_integer,X2) = aa(int,nat,nat2,aa(code_integer,int,code_int_of_integer,X2)) ).

% nat_of_integer.rep_eq
tff(fact_1784_integer__eq__iff,axiom,
    ! [K: code_integer,L: code_integer] :
      ( ( K = L )
    <=> ( aa(code_integer,int,code_int_of_integer,K) = aa(code_integer,int,code_int_of_integer,L) ) ) ).

% integer_eq_iff
tff(fact_1785_integer__eqI,axiom,
    ! [K: code_integer,L: code_integer] :
      ( ( aa(code_integer,int,code_int_of_integer,K) = aa(code_integer,int,code_int_of_integer,L) )
     => ( K = L ) ) ).

% integer_eqI
tff(fact_1786_int__of__integer__inject,axiom,
    ! [X2: code_integer,Y: code_integer] :
      ( ( aa(code_integer,int,code_int_of_integer,X2) = aa(code_integer,int,code_int_of_integer,Y) )
    <=> ( X2 = Y ) ) ).

% int_of_integer_inject
tff(fact_1787_prod_Onot__neutral__contains__not__neutral,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(C,B),A4: set(C)] :
          ( ( aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),G),A4) != one_one(B) )
         => ~ ! [A5: C] :
                ( member(C,A5,A4)
               => ( aa(C,B,G,A5) = one_one(B) ) ) ) ) ).

% prod.not_neutral_contains_not_neutral
tff(fact_1788_prod_Oneutral,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(B),G: fun(B,C)] :
          ( ! [X3: B] :
              ( member(B,X3,A4)
             => ( aa(B,C,G,X3) = one_one(C) ) )
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),A4) = one_one(C) ) ) ) ).

% prod.neutral
tff(fact_1789_apsnd__compose,axiom,
    ! [D: $tType,C: $tType,E: $tType,B: $tType,F: fun(D,C),G: fun(E,D),X2: product_prod(B,E)] : aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),F),aa(product_prod(B,E),product_prod(B,D),aa(fun(E,D),fun(product_prod(B,E),product_prod(B,D)),product_apsnd(E,D,B),G),X2)) = aa(product_prod(B,E),product_prod(B,C),aa(fun(E,C),fun(product_prod(B,E),product_prod(B,C)),product_apsnd(E,C,B),aa(fun(E,D),fun(E,C),aa(fun(D,C),fun(fun(E,D),fun(E,C)),comp(D,C,E),F),G)),X2) ).

% apsnd_compose
tff(fact_1790_prod__ge__1,axiom,
    ! [C: $tType,B: $tType] :
      ( linord181362715937106298miring(C)
     => ! [A4: set(B),F: fun(B,C)] :
          ( ! [X3: B] :
              ( member(B,X3,A4)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(B,C,F,X3)) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),A4)) ) ) ).

% prod_ge_1
tff(fact_1791_int__of__integer__less__iff,axiom,
    ! [X2: code_integer,Y: code_integer] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Y))
    <=> aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),X2),Y) ) ).

% int_of_integer_less_iff
tff(fact_1792_integer__less__iff,axiom,
    ! [K: code_integer,L: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),K),L)
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(code_integer,int,code_int_of_integer,K)),aa(code_integer,int,code_int_of_integer,L)) ) ).

% integer_less_iff
tff(fact_1793_less__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),X2),Xa)
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ) ).

% less_integer.rep_eq
tff(fact_1794_less__eq__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),X2),Xa)
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ) ).

% less_eq_integer.rep_eq
tff(fact_1795_integer__less__eq__iff,axiom,
    ! [K: code_integer,L: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),K),L)
    <=> aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(code_integer,int,code_int_of_integer,K)),aa(code_integer,int,code_int_of_integer,L)) ) ).

% integer_less_eq_iff
tff(fact_1796_prod_Oshift__bounds__cl__Suc__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.shift_bounds_cl_Suc_ivl
tff(fact_1797_prod_Oshift__bounds__Suc__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% prod.shift_bounds_Suc_ivl
tff(fact_1798_prod_Oshift__bounds__cl__nat__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fn(fun(nat,B),fun(nat,fun(nat,B)),G),K)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.shift_bounds_cl_nat_ivl
tff(fact_1799_prod_Oshift__bounds__nat__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fn(fun(nat,B),fun(nat,fun(nat,B)),G),K)),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% prod.shift_bounds_nat_ivl
tff(fact_1800_atLeastLessThanPlusOne__atLeastAtMost__integer,axiom,
    ! [L: code_integer,U: code_integer] : set_or7035219750837199246ssThan(code_integer,L,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),U),one_one(code_integer))) = set_or1337092689740270186AtMost(code_integer,L,U) ).

% atLeastLessThanPlusOne_atLeastAtMost_integer
tff(fact_1801_prod__le__1,axiom,
    ! [B: $tType,C: $tType] :
      ( linord181362715937106298miring(C)
     => ! [A4: set(B),F: fun(B,C)] :
          ( ! [X3: B] :
              ( member(B,X3,A4)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(B,C,F,X3))
                & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,F,X3)),one_one(C)) ) )
         => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),A4)),one_one(C)) ) ) ).

% prod_le_1
tff(fact_1802_prod_Oivl__cong,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & comm_monoid_mult(C) )
     => ! [A3: B,C2: B,B2: B,D3: B,G: fun(B,C),Ha: fun(B,C)] :
          ( ( A3 = C2 )
         => ( ( B2 = D3 )
           => ( ! [X3: B] :
                  ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),X3)
                 => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X3),D3)
                   => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),set_or7035219750837199246ssThan(B,A3,B2)) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),set_or7035219750837199246ssThan(B,C2,D3)) ) ) ) ) ) ).

% prod.ivl_cong
tff(fact_1803_take__bit__integer_Orep__eq,axiom,
    ! [X2: nat,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se2584673776208193580ke_bit(code_integer),X2),Xa)) = aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),X2),aa(code_integer,int,code_int_of_integer,Xa)) ).

% take_bit_integer.rep_eq
tff(fact_1804_and__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),bit_se5824344872417868541ns_and(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% and_integer.rep_eq
tff(fact_1805_bit__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,fun(nat,$o),bit_se5641148757651400278ts_bit(code_integer),X2) = aa(int,fun(nat,$o),bit_se5641148757651400278ts_bit(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% bit_integer.rep_eq
tff(fact_1806_prod_OatLeastLessThan__concat,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,P3: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),P3)
           => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,N,P3))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,P3)) ) ) ) ) ).

% prod.atLeastLessThan_concat
tff(fact_1807_mask__integer_Orep__eq,axiom,
    ! [X2: nat] : aa(code_integer,int,code_int_of_integer,aa(nat,code_integer,bit_se2239418461657761734s_mask(code_integer),X2)) = aa(nat,int,bit_se2239418461657761734s_mask(int),X2) ).

% mask_integer.rep_eq
tff(fact_1808_integer__of__num__def,axiom,
    code_integer_of_num = numeral_numeral(code_integer) ).

% integer_of_num_def
tff(fact_1809_unset__bit__integer_Orep__eq,axiom,
    ! [X2: nat,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se2638667681897837118et_bit(code_integer),X2),Xa)) = aa(int,int,aa(nat,fun(int,int),bit_se2638667681897837118et_bit(int),X2),aa(code_integer,int,code_int_of_integer,Xa)) ).

% unset_bit_integer.rep_eq
tff(fact_1810_set__bit__integer_Orep__eq,axiom,
    ! [X2: nat,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se5668285175392031749et_bit(code_integer),X2),Xa)) = aa(int,int,aa(nat,fun(int,int),bit_se5668285175392031749et_bit(int),X2),aa(code_integer,int,code_int_of_integer,Xa)) ).

% set_bit_integer.rep_eq
tff(fact_1811_flip__bit__integer_Orep__eq,axiom,
    ! [X2: nat,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se8732182000553998342ip_bit(code_integer),X2),Xa)) = aa(int,int,aa(nat,fun(int,int),bit_se8732182000553998342ip_bit(int),X2),aa(code_integer,int,code_int_of_integer,Xa)) ).

% flip_bit_integer.rep_eq
tff(fact_1812_prod_OatLeast__Suc__atMost__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.atLeast_Suc_atMost_Suc_shift
tff(fact_1813_prod_OatLeast__Suc__lessThan__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% prod.atLeast_Suc_lessThan_Suc_shift
tff(fact_1814_atLeastLessThanPlusOne__atLeastAtMost__int,axiom,
    ! [L: int,U: int] : set_or7035219750837199246ssThan(int,L,aa(int,int,aa(int,fun(int,int),plus_plus(int),U),one_one(int))) = set_or1337092689740270186AtMost(int,L,U) ).

% atLeastLessThanPlusOne_atLeastAtMost_int
tff(fact_1815_prod_OatLeastAtMost__shift__bounds,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),K))),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.atLeastAtMost_shift_bounds
tff(fact_1816_prod_OatLeastLessThan__shift__bounds,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),K))),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% prod.atLeastLessThan_shift_bounds
tff(fact_1817_prod_OatLeastAtMost__rev,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fo(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or1337092689740270186AtMost(nat,N,M)) ) ).

% prod.atLeastAtMost_rev
tff(fact_1818_prod_Onat__diff__reindex,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fp(fun(nat,B),fun(nat,fun(nat,B)),G),N)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% prod.nat_diff_reindex
tff(fact_1819_nat__of__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,nat,code_nat_of_integer,aa(int,code_integer,code_integer_of_int,X2)) = aa(int,nat,nat2,X2) ).

% nat_of_integer.abs_eq
tff(fact_1820_num__of__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,num,code_num_of_integer,X2) = aa(nat,num,num_of_nat,aa(int,nat,nat2,aa(code_integer,int,code_int_of_integer,X2))) ).

% num_of_integer.rep_eq
tff(fact_1821_prod_OatLeast0__atMost__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))),aa(nat,B,G,aa(nat,nat,suc,N))) ) ).

% prod.atLeast0_atMost_Suc
tff(fact_1822_prod_OatLeast0__lessThan__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))),aa(nat,B,G,N)) ) ).

% prod.atLeast0_lessThan_Suc
tff(fact_1823_prod_OatLeast__Suc__lessThan,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),N))) ) ) ) ).

% prod.atLeast_Suc_lessThan
tff(fact_1824_prod_Onat__ivl__Suc_H,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,suc,N))
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,aa(nat,nat,suc,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))) ) ) ) ).

% prod.nat_ivl_Suc'
tff(fact_1825_prod_OatLeast__Suc__atMost,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),N))) ) ) ) ).

% prod.atLeast_Suc_atMost
tff(fact_1826_prod_OatLeastLessThan__Suc,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A3: nat,B2: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),B2)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,A3,aa(nat,nat,suc,B2))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,A3,B2))),aa(nat,B,G,B2)) ) ) ) ).

% prod.atLeastLessThan_Suc
tff(fact_1827_divmod__abs__code_I6_J,axiom,
    ! [J: code_integer] : code_divmod_abs(zero_zero(code_integer),J) = aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),zero_zero(code_integer)),zero_zero(code_integer)) ).

% divmod_abs_code(6)
tff(fact_1828_prod_Olast__plus,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,N)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))) ) ) ) ).

% prod.last_plus
tff(fact_1829_prod_OSuc__reindex__ivl,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))),aa(nat,B,G,aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N))) ) ) ) ).

% prod.Suc_reindex_ivl
tff(fact_1830_prod_OatMost__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N))) ) ).

% prod.atMost_Suc_shift
tff(fact_1831_prod_OlessThan__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% prod.lessThan_Suc_shift
tff(fact_1832_prod_OatLeastLessThan__rev,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fq(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or7035219750837199246ssThan(nat,N,M)) ) ).

% prod.atLeastLessThan_rev
tff(fact_1833_prod_Onested__swap,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A3: fun(nat,fun(nat,B)),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fr(fun(nat,fun(nat,B)),fun(nat,B),A3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_ft(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),A3),N)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N)) ) ).

% prod.nested_swap
tff(fact_1834_prod_OatLeast1__atMost__eq,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% prod.atLeast1_atMost_eq
tff(fact_1835_prod_Onat__group,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),K: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fu(fun(nat,B),fun(nat,fun(nat,B)),G),K)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),K))) ) ).

% prod.nat_group
tff(fact_1836_fact__prod,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N: nat] : semiring_char_0_fact(B,N) = aa(nat,B,semiring_1_of_nat(B),aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),aTP_Lamp_bz(nat,nat)),set_or1337092689740270186AtMost(nat,one_one(nat),N))) ) ).

% fact_prod
tff(fact_1837_prod_Onested__swap_H,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A3: fun(nat,fun(nat,B)),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fv(fun(nat,fun(nat,B)),fun(nat,B),A3)),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_ft(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),A3),N)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% prod.nested_swap'
tff(fact_1838_prod__atLeastAtMost__code,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [F: fun(nat,B),A3: nat,B2: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),F),set_or1337092689740270186AtMost(nat,A3,B2)) = set_fo6178422350223883121st_nat(B,aTP_Lamp_fw(fun(nat,B),fun(nat,fun(B,B)),F),A3,B2,one_one(B)) ) ).

% prod_atLeastAtMost_code
tff(fact_1839_prod_Ohead__if,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] :
          aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),one_one(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N))),aa(nat,B,G,N))) ) ).

% prod.head_if
tff(fact_1840_prod_Oub__add__nat,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B),P3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)))
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),P3))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),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_1841_prod_OatLeast0__atMost__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) ) ).

% prod.atLeast0_atMost_Suc_shift
tff(fact_1842_prod_OatLeast0__lessThan__Suc__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))) ) ).

% prod.atLeast0_lessThan_Suc_shift
tff(fact_1843_prod_OatLeastLessThan__shift__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),M))),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ).

% prod.atLeastLessThan_shift_0
tff(fact_1844_integer__of__num__triv_I1_J,axiom,
    aa(num,code_integer,code_integer_of_num,one2) = one_one(code_integer) ).

% integer_of_num_triv(1)
tff(fact_1845_prod_OatLeastLessThan__rev__at__least__Suc__atMost,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat,M: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fo(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,N),M)) ) ).

% prod.atLeastLessThan_rev_at_least_Suc_atMost
tff(fact_1846_prod_OatMost__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fm(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ).

% prod.atMost_shift
tff(fact_1847_pochhammer__prod,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] : comm_s3205402744901411588hammer(B,A3,N) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fx(B,fun(nat,B),A3)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N)) ) ).

% pochhammer_prod
tff(fact_1848_prod_OatLeast__atMost__pred__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aTP_Lamp_bv(nat,nat))),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.atLeast_atMost_pred_shift
tff(fact_1849_prod_OatLeast__lessThan__pred__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aTP_Lamp_bv(nat,nat))),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% prod.atLeast_lessThan_pred_shift
tff(fact_1850_integer__of__num_I2_J,axiom,
    ! [N: num] :
      aa(num,code_integer,code_integer_of_num,aa(num,num,bit0,N)) = $let(
        k: code_integer,
        k:= aa(num,code_integer,code_integer_of_num,N),
        aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),k),k) ) ).

% integer_of_num(2)
tff(fact_1851_divmod__abs__code_I5_J,axiom,
    ! [J: code_integer] : code_divmod_abs(J,zero_zero(code_integer)) = aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),zero_zero(code_integer)),aa(code_integer,code_integer,abs_abs(code_integer),J)) ).

% divmod_abs_code(5)
tff(fact_1852_prod_OatLeastAtMost__shift__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),M))),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ) ) ).

% prod.atLeastAtMost_shift_0
tff(fact_1853_sum_OatLeast__int__lessThan__int__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(int,B),M: nat,N: nat] : aa(set(int),B,aa(fun(int,B),fun(set(int),B),groups7311177749621191930dd_sum(int,B),G),set_or7035219750837199246ssThan(int,aa(nat,int,semiring_1_of_nat(int),M),aa(nat,int,semiring_1_of_nat(int),N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(fun(nat,int),fun(nat,B),aa(fun(int,B),fun(fun(nat,int),fun(nat,B)),comp(int,B,nat),G),semiring_1_of_nat(int))),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% sum.atLeast_int_lessThan_int_shift
tff(fact_1854_pochhammer__Suc__prod,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] : comm_s3205402744901411588hammer(B,A3,aa(nat,nat,suc,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fx(B,fun(nat,B),A3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) ) ).

% pochhammer_Suc_prod
tff(fact_1855_pochhammer__prod__rev,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] : comm_s3205402744901411588hammer(B,A3,N) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fy(B,fun(nat,fun(nat,B)),A3),N)),set_or1337092689740270186AtMost(nat,one_one(nat),N)) ) ).

% pochhammer_prod_rev
tff(fact_1856_fact__div__fact,axiom,
    ! [N: nat,M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),M)
     => ( aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),semiring_char_0_fact(nat,M)),semiring_char_0_fact(nat,N)) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),aTP_Lamp_bz(nat,nat)),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)),M)) ) ) ).

% fact_div_fact
tff(fact_1857_integer__of__num__triv_I2_J,axiom,
    aa(num,code_integer,code_integer_of_num,aa(num,num,bit0,one2)) = aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)) ).

% integer_of_num_triv(2)
tff(fact_1858_prod_Oin__pairs,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),M: nat,N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),M),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fz(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.in_pairs
tff(fact_1859_prod_Oin__pairs__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,B),N: nat] : aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),aa(nat,set(nat),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),aa(num,num,bit0,one2))),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_fz(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ).

% prod.in_pairs_0
tff(fact_1860_nat__of__integer__less__iff,axiom,
    ! [X2: code_integer,Y: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),zero_zero(code_integer)),X2)
     => ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),zero_zero(code_integer)),Y)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(code_integer,nat,code_nat_of_integer,X2)),aa(code_integer,nat,code_nat_of_integer,Y))
        <=> aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),X2),Y) ) ) ) ).

% nat_of_integer_less_iff
tff(fact_1861_pochhammer__Suc__prod__rev,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [A3: B,N: nat] : comm_s3205402744901411588hammer(B,A3,aa(nat,nat,suc,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fy(B,fun(nat,fun(nat,B)),A3),N)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) ) ).

% pochhammer_Suc_prod_rev
tff(fact_1862_divmod__integer__code,axiom,
    ! [K: code_integer,L: code_integer] :
      code_divmod_integer(K,L) = $ite(
        K = zero_zero(code_integer),
        aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),zero_zero(code_integer)),zero_zero(code_integer)),
        $ite(
          aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),zero_zero(code_integer)),L),
          $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),zero_zero(code_integer)),K),code_divmod_abs(K,L),aa(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer),aa(fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),product_case_prod(code_integer,code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_ga(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),L)),code_divmod_abs(K,L))),
          $ite(
            L = zero_zero(code_integer),
            aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),zero_zero(code_integer)),K),
            aa(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer),aa(fun(code_integer,code_integer),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),product_apsnd(code_integer,code_integer,code_integer),uminus_uminus(code_integer)),
              $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),K),zero_zero(code_integer)),code_divmod_abs(K,L),aa(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer),aa(fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),fun(product_prod(code_integer,code_integer),product_prod(code_integer,code_integer)),product_case_prod(code_integer,code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_gb(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),L)),code_divmod_abs(K,L)))) ) ) ) ).

% divmod_integer_code
tff(fact_1863_bit__cut__integer__code,axiom,
    ! [K: code_integer] :
      code_bit_cut_integer(K) = $ite(K = zero_zero(code_integer),aa($o,product_prod(code_integer,$o),aa(code_integer,fun($o,product_prod(code_integer,$o)),product_Pair(code_integer,$o),zero_zero(code_integer)),$false),aa(product_prod(code_integer,code_integer),product_prod(code_integer,$o),aa(fun(code_integer,fun(code_integer,product_prod(code_integer,$o))),fun(product_prod(code_integer,code_integer),product_prod(code_integer,$o)),product_case_prod(code_integer,code_integer,product_prod(code_integer,$o)),aTP_Lamp_gc(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,$o))),K)),code_divmod_abs(K,aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))))) ).

% bit_cut_integer_code
tff(fact_1864_prod_Ozero__middle,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [P3: nat,K: nat,G: fun(nat,B),Ha: fun(nat,B)] :
          ( 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),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_gd(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),K),G),Ha)),aa(nat,set(nat),set_ord_atMost(nat),P3)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_ge(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),K),G),Ha)),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),P3),aa(nat,nat,suc,zero_zero(nat))))) ) ) ) ) ).

% prod.zero_middle
tff(fact_1865_xor__int__rec,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se5824344971392196577ns_xor(int),K),L) = aa(int,int,
        aa(int,fun(int,int),plus_plus(int),
          aa($o,int,zero_neq_one_of_bool(int),
            ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K) != ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L))),
        aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344971392196577ns_xor(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ).

% xor_int_rec
tff(fact_1866_divmod__abs__def,axiom,
    ! [K: code_integer,L: code_integer] : code_divmod_abs(K,L) = aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),aa(code_integer,code_integer,abs_abs(code_integer),K)),aa(code_integer,code_integer,abs_abs(code_integer),L))),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),aa(code_integer,code_integer,abs_abs(code_integer),K)),aa(code_integer,code_integer,abs_abs(code_integer),L))) ).

% divmod_abs_def
tff(fact_1867_less__int_Orep__eq,axiom,
    ! [X2: int,Xa: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),X2),Xa)
    <=> aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o)))),aa(int,product_prod(nat,nat),rep_Integ,X2)),aa(int,product_prod(nat,nat),rep_Integ,Xa)) ) ).

% less_int.rep_eq
tff(fact_1868_make_H__def,axiom,
    ! [B: $tType,C: $tType] :
      ( ( semiring_1(C)
        & heap(B) )
     => ! [I: code_integer,F: fun(C,B)] : array_make2(C,B,I,F) = array_make(B,aa(code_integer,nat,code_nat_of_integer,I),aa(fun(nat,C),fun(nat,B),aa(fun(C,B),fun(fun(nat,C),fun(nat,B)),comp(C,B,nat),F),semiring_1_of_nat(C))) ) ).

% make'_def
tff(fact_1869_new_H__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ( array_new2(B) = aa(fun(code_integer,nat),fun(code_integer,fun(B,heap_Time_Heap(array(B)))),aa(fun(nat,fun(B,heap_Time_Heap(array(B)))),fun(fun(code_integer,nat),fun(code_integer,fun(B,heap_Time_Heap(array(B))))),comp(nat,fun(B,heap_Time_Heap(array(B))),code_integer),array_new(B)),code_nat_of_integer) ) ) ).

% new'_def
tff(fact_1870_xor__int__unfold,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se5824344971392196577ns_xor(int),K),L) = $ite(
        K = aa(int,int,uminus_uminus(int),one_one(int)),
        aa(int,int,bit_ri4277139882892585799ns_not(int),L),
        $ite(
          L = aa(int,int,uminus_uminus(int),one_one(int)),
          aa(int,int,bit_ri4277139882892585799ns_not(int),K),
          $ite(
            K = zero_zero(int),
            L,
            $ite(L = zero_zero(int),K,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,abs_abs(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344971392196577ns_xor(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))))) ) ) ) ).

% xor_int_unfold
tff(fact_1871_take__bit__num__code,axiom,
    ! [N: nat,M: num] : bit_take_bit_num(N,M) = aa(product_prod(nat,num),option(num),aa(fun(nat,fun(num,option(num))),fun(product_prod(nat,num),option(num)),product_case_prod(nat,num,option(num)),aTP_Lamp_gi(nat,fun(num,option(num)))),aa(num,product_prod(nat,num),aa(nat,fun(num,product_prod(nat,num)),product_Pair(nat,num),N),M)) ).

% take_bit_num_code
tff(fact_1872_prod_Otriangle__reindex,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,fun(nat,B)),N: nat] : aa(set(product_prod(nat,nat)),B,aa(fun(product_prod(nat,nat),B),fun(set(product_prod(nat,nat)),B),groups7121269368397514597t_prod(product_prod(nat,nat),B),aa(fun(nat,fun(nat,B)),fun(product_prod(nat,nat),B),product_case_prod(nat,nat,B),G)),aa(fun(product_prod(nat,nat),$o),set(product_prod(nat,nat)),collect(product_prod(nat,nat)),aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aTP_Lamp_ej(nat,fun(nat,fun(nat,$o)),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_gk(fun(nat,fun(nat,B)),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ).

% prod.triangle_reindex
tff(fact_1873_case__nat__add__eq__if,axiom,
    ! [B: $tType,A3: B,F: fun(nat,B),V: num,N: nat] : case_nat(B,A3,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),V)),N)) = aa(nat,B,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),pred_numeral(V)),N)) ).

% case_nat_add_eq_if
tff(fact_1874_rec__nat__add__eq__if,axiom,
    ! [B: $tType,A3: B,F: fun(nat,fun(B,B)),V: num,N: nat] :
      rec_nat(B,A3,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(num,nat,numeral_numeral(nat),V)),N)) = $let(
        pv: nat,
        pv:= pred_numeral(V),
        aa(B,B,aa(nat,fun(B,B),F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),pv),N)),rec_nat(B,A3,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),pv),N))) ) ).

% rec_nat_add_eq_if
tff(fact_1875_bit_Ocompl__zero,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ( aa(B,B,bit_ri4277139882892585799ns_not(B),zero_zero(B)) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% bit.compl_zero
tff(fact_1876_bit_Ocompl__one,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ( aa(B,B,bit_ri4277139882892585799ns_not(B),aa(B,B,uminus_uminus(B),one_one(B))) = zero_zero(B) ) ) ).

% bit.compl_one
tff(fact_1877_bit_Oxor__cancel__right,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),X2),aa(B,B,bit_ri4277139882892585799ns_not(B),X2)) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% bit.xor_cancel_right
tff(fact_1878_bit_Oxor__cancel__left,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(B,B,bit_ri4277139882892585799ns_not(B),X2)),X2) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% bit.xor_cancel_left
tff(fact_1879_bit_Oxor__one__right,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),X2),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,bit_ri4277139882892585799ns_not(B),X2) ) ).

% bit.xor_one_right
tff(fact_1880_bit_Oxor__one__left,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se5824344971392196577ns_xor(B),aa(B,B,uminus_uminus(B),one_one(B))),X2) = aa(B,B,bit_ri4277139882892585799ns_not(B),X2) ) ).

% bit.xor_one_left
tff(fact_1881_push__bit__minus__one__eq__not__mask,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,bit_ri4277139882892585799ns_not(B),aa(nat,B,bit_se2239418461657761734s_mask(B),N)) ) ).

% push_bit_minus_one_eq_not_mask
tff(fact_1882_not__one__eq,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ( aa(B,B,bit_ri4277139882892585799ns_not(B),one_one(B)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))) ) ) ).

% not_one_eq
tff(fact_1883_not__add__distrib,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B,B2: B] : aa(B,B,bit_ri4277139882892585799ns_not(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,bit_ri4277139882892585799ns_not(B),A3)),B2) ) ).

% not_add_distrib
tff(fact_1884_not__diff__distrib,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B,B2: B] : aa(B,B,bit_ri4277139882892585799ns_not(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,bit_ri4277139882892585799ns_not(B),A3)),B2) ) ).

% not_diff_distrib
tff(fact_1885_minus__eq__not__plus__1,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B] : aa(B,B,uminus_uminus(B),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,bit_ri4277139882892585799ns_not(B),A3)),one_one(B)) ) ).

% minus_eq_not_plus_1
tff(fact_1886_minus__eq__not__minus__1,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B] : aa(B,B,uminus_uminus(B),A3) = aa(B,B,bit_ri4277139882892585799ns_not(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))) ) ).

% minus_eq_not_minus_1
tff(fact_1887_not__eq__complement,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B] : aa(B,B,bit_ri4277139882892585799ns_not(B),A3) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),A3)),one_one(B)) ) ).

% not_eq_complement
tff(fact_1888_prod__int__eq,axiom,
    ! [I: nat,J: nat] : aa(set(nat),int,aa(fun(nat,int),fun(set(nat),int),groups7121269368397514597t_prod(nat,int),semiring_1_of_nat(int)),set_or1337092689740270186AtMost(nat,I,J)) = aa(set(int),int,aa(fun(int,int),fun(set(int),int),groups7121269368397514597t_prod(int,int),aTP_Lamp_cm(int,int)),set_or1337092689740270186AtMost(int,aa(nat,int,semiring_1_of_nat(int),I),aa(nat,int,semiring_1_of_nat(int),J))) ).

% prod_int_eq
tff(fact_1889_prod__int__plus__eq,axiom,
    ! [I: nat,J: nat] : aa(set(nat),int,aa(fun(nat,int),fun(set(nat),int),groups7121269368397514597t_prod(nat,int),semiring_1_of_nat(int)),set_or1337092689740270186AtMost(nat,I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J))) = aa(set(int),int,aa(fun(int,int),fun(set(int),int),groups7121269368397514597t_prod(int,int),aTP_Lamp_cm(int,int)),set_or1337092689740270186AtMost(int,aa(nat,int,semiring_1_of_nat(int),I),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J)))) ).

% prod_int_plus_eq
tff(fact_1890_push__bit__mask__eq,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [M: nat,N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),M),aa(nat,B,bit_se2239418461657761734s_mask(B),N)) = aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(nat,B,bit_se2239418461657761734s_mask(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M))),aa(B,B,bit_ri4277139882892585799ns_not(B),aa(nat,B,bit_se2239418461657761734s_mask(B),M))) ) ).

% push_bit_mask_eq
tff(fact_1891_prod_OatLeast__int__lessThan__int__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(int,B),M: nat,N: nat] : aa(set(int),B,aa(fun(int,B),fun(set(int),B),groups7121269368397514597t_prod(int,B),G),set_or7035219750837199246ssThan(int,aa(nat,int,semiring_1_of_nat(int),M),aa(nat,int,semiring_1_of_nat(int),N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,int),fun(nat,B),aa(fun(int,B),fun(fun(nat,int),fun(nat,B)),comp(int,B,nat),G),semiring_1_of_nat(int))),set_or7035219750837199246ssThan(nat,M,N)) ) ).

% prod.atLeast_int_lessThan_int_shift
tff(fact_1892_unset__bit__eq__and__not,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se2638667681897837118et_bit(B),N),A3) = aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),aa(B,B,bit_ri4277139882892585799ns_not(B),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),one_one(B)))) ) ).

% unset_bit_eq_and_not
tff(fact_1893_prod_OatLeast__int__atMost__int__shift,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(int,B),M: nat,N: nat] : aa(set(int),B,aa(fun(int,B),fun(set(int),B),groups7121269368397514597t_prod(int,B),G),set_or1337092689740270186AtMost(int,aa(nat,int,semiring_1_of_nat(int),M),aa(nat,int,semiring_1_of_nat(int),N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(fun(nat,int),fun(nat,B),aa(fun(int,B),fun(fun(nat,int),fun(nat,B)),comp(int,B,nat),G),semiring_1_of_nat(int))),set_or1337092689740270186AtMost(nat,M,N)) ) ).

% prod.atLeast_int_atMost_int_shift
tff(fact_1894_int__numeral__not__and__num,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),M))),aa(num,int,numeral_numeral(int),N)) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),numeral_numeral(int)),bit_and_not_num(N,M)) ).

% int_numeral_not_and_num
tff(fact_1895_int__numeral__and__not__num,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),N))) = aa(option(num),int,aa(fun(num,int),fun(option(num),int),aa(int,fun(fun(num,int),fun(option(num),int)),case_option(int,num),zero_zero(int)),numeral_numeral(int)),bit_and_not_num(M,N)) ).

% int_numeral_and_not_num
tff(fact_1896_prod_Otriangle__reindex__eq,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(nat,fun(nat,B)),N: nat] : aa(set(product_prod(nat,nat)),B,aa(fun(product_prod(nat,nat),B),fun(set(product_prod(nat,nat)),B),groups7121269368397514597t_prod(product_prod(nat,nat),B),aa(fun(nat,fun(nat,B)),fun(product_prod(nat,nat),B),product_case_prod(nat,nat,B),G)),aa(fun(product_prod(nat,nat),$o),set(product_prod(nat,nat)),collect(product_prod(nat,nat)),aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aTP_Lamp_ds(nat,fun(nat,fun(nat,$o)),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aTP_Lamp_gk(fun(nat,fun(nat,B)),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ).

% prod.triangle_reindex_eq
tff(fact_1897_and__not__numerals_I8_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,M))),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,N)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),N))))) ).

% and_not_numerals(8)
tff(fact_1898_not__int__rec,axiom,
    ! [K: int] : aa(int,int,bit_ri4277139882892585799ns_not(int),K) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa($o,int,zero_neq_one_of_bool(int),dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ).

% not_int_rec
tff(fact_1899_Nitpick_Ocase__nat__unfold,axiom,
    ! [B: $tType,X2: B,F: fun(nat,B),N: nat] :
      case_nat(B,X2,F,N) = $ite(N = zero_zero(nat),X2,aa(nat,B,F,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))) ).

% Nitpick.case_nat_unfold
tff(fact_1900_or__int__rec,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),K),L) = aa(int,int,
        aa(int,fun(int,int),plus_plus(int),
          aa($o,int,zero_neq_one_of_bool(int),
            ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K)
            | ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L) ))),
        aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ).

% or_int_rec
tff(fact_1901_or__numerals_I4_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num,Y: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,X2))),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),X2)),aa(num,B,numeral_numeral(B),Y)))) ) ).

% or_numerals(4)
tff(fact_1902_or__numerals_I6_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num,Y: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),aa(num,B,numeral_numeral(B),aa(num,num,bit0,Y))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),X2)),aa(num,B,numeral_numeral(B),Y)))) ) ).

% or_numerals(6)
tff(fact_1903_or__numerals_I7_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num,Y: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),X2)),aa(num,B,numeral_numeral(B),Y)))) ) ).

% or_numerals(7)
tff(fact_1904_or__nat__rec,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),M),N) = aa(nat,nat,
        aa(nat,fun(nat,nat),plus_plus(nat),
          aa($o,nat,zero_neq_one_of_bool(nat),
            ( ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),M)
            | ~ dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N) ))),
        aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))))) ).

% or_nat_rec
tff(fact_1905_or__not__numerals_I9_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,M))),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,N)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),N))))) ).

% or_not_numerals(9)
tff(fact_1906_bit_Odisj__one__left,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(B,B,uminus_uminus(B),one_one(B))),X2) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% bit.disj_one_left
tff(fact_1907_bit_Odisj__one__right,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),X2),aa(B,B,uminus_uminus(B),one_one(B))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% bit.disj_one_right
tff(fact_1908_or__numerals_I8_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2))),one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2)) ) ).

% or_numerals(8)
tff(fact_1909_or__numerals_I2_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [Y: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y))) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y)) ) ).

% or_numerals(2)
tff(fact_1910_bit_Odisj__cancel__left,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(B,B,bit_ri4277139882892585799ns_not(B),X2)),X2) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% bit.disj_cancel_left
tff(fact_1911_bit_Odisj__cancel__right,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),X2),aa(B,B,bit_ri4277139882892585799ns_not(B),X2)) = aa(B,B,uminus_uminus(B),one_one(B)) ) ).

% bit.disj_cancel_right
tff(fact_1912_or__numerals_I5_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [X2: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,X2))),one_one(B)) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,X2)) ) ).

% or_numerals(5)
tff(fact_1913_or__numerals_I1_J,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [Y: num] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),one_one(B)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,Y))) = aa(num,B,numeral_numeral(B),aa(num,num,bit1,Y)) ) ).

% or_numerals(1)
tff(fact_1914_or__integer_Oabs__eq,axiom,
    ! [Xa: int,X2: int] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),bit_se1065995026697491101ons_or(code_integer),aa(int,code_integer,code_integer_of_int,Xa)),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),Xa),X2)) ).

% or_integer.abs_eq
tff(fact_1915_or__integer_Orep__eq,axiom,
    ! [X2: code_integer,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),bit_se1065995026697491101ons_or(code_integer),X2),Xa)) = aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,Xa)) ).

% or_integer.rep_eq
tff(fact_1916_disjunctive__add,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B,B2: B] :
          ( ! [N3: nat] :
              ( ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N3)
              | ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),B2),N3) )
         => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2) = aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),A3),B2) ) ) ) ).

% disjunctive_add
tff(fact_1917_plus__and__or,axiom,
    ! [X2: int,Y: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),X2),Y)),aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),X2),Y)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),Y) ).

% plus_and_or
tff(fact_1918_not__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,bit_ri4277139882892585799ns_not(code_integer),X2)) = aa(int,int,bit_ri4277139882892585799ns_not(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% not_integer.rep_eq
tff(fact_1919_set__bit__nat__def,axiom,
    ! [M: nat,N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se5668285175392031749et_bit(nat),M),N) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),N),aa(nat,nat,aa(nat,fun(nat,nat),bit_se4730199178511100633sh_bit(nat),M),one_one(nat))) ).

% set_bit_nat_def
tff(fact_1920_not__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_integer,bit_ri4277139882892585799ns_not(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,bit_ri4277139882892585799ns_not(int),X2)) ).

% not_integer.abs_eq
tff(fact_1921_set__bit__eq__or,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se5668285175392031749et_bit(B),N),A3) = aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),A3),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),one_one(B))) ) ).

% set_bit_eq_or
tff(fact_1922_bit_Ocomplement__unique,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B,X2: B,Y: B] :
          ( ( aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),X2) = zero_zero(B) )
         => ( ( aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),A3),X2) = aa(B,B,uminus_uminus(B),one_one(B)) )
           => ( ( aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),Y) = zero_zero(B) )
             => ( ( aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),A3),Y) = aa(B,B,uminus_uminus(B),one_one(B)) )
               => ( X2 = Y ) ) ) ) ) ) ).

% bit.complement_unique
tff(fact_1923_bit_Ocompl__unique,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),X2),Y) = zero_zero(B) )
         => ( ( aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),X2),Y) = aa(B,B,uminus_uminus(B),one_one(B)) )
           => ( aa(B,B,bit_ri4277139882892585799ns_not(B),X2) = Y ) ) ) ) ).

% bit.compl_unique
tff(fact_1924_or__one__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),A3),one_one(B)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa($o,B,zero_neq_one_of_bool(B),dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3))) ) ).

% or_one_eq
tff(fact_1925_one__or__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),one_one(B)),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),aa($o,B,zero_neq_one_of_bool(B),dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),A3))) ) ).

% one_or_eq
tff(fact_1926_mask__Suc__double,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat] : aa(nat,B,bit_se2239418461657761734s_mask(B),aa(nat,nat,suc,N)) = aa(B,B,aa(B,fun(B,B),bit_se1065995026697491101ons_or(B),one_one(B)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,B,bit_se2239418461657761734s_mask(B),N))) ) ).

% mask_Suc_double
tff(fact_1927_or__not__numerals_I5_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,M))),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,N)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),N))))) ).

% or_not_numerals(5)
tff(fact_1928_Suc__0__or__eq,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),aa(nat,nat,suc,zero_zero(nat))),N) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa($o,nat,zero_neq_one_of_bool(nat),dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N))) ).

% Suc_0_or_eq
tff(fact_1929_or__Suc__0__eq,axiom,
    ! [N: nat] : aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),N),aa(nat,nat,suc,zero_zero(nat))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa($o,nat,zero_neq_one_of_bool(nat),dvd_dvd(nat,aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)),N))) ).

% or_Suc_0_eq
tff(fact_1930_or__not__numerals_I8_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(num,int,numeral_numeral(int),aa(num,num,bit1,M))),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,N)))) = aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(num,int,numeral_numeral(int),M)),aa(int,int,bit_ri4277139882892585799ns_not(int),aa(num,int,numeral_numeral(int),N))))) ).

% or_not_numerals(8)
tff(fact_1931_or__int__unfold,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),K),L) = $ite(
        ( ( K = aa(int,int,uminus_uminus(int),one_one(int)) )
        | ( L = aa(int,int,uminus_uminus(int),one_one(int)) ) ),
        aa(int,int,uminus_uminus(int),one_one(int)),
        $ite(
          K = zero_zero(int),
          L,
          $ite(L = zero_zero(int),K,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,ord_max(int,aa(int,int,aa(int,fun(int,int),modulo_modulo(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),modulo_modulo(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se1065995026697491101ons_or(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))))))) ) ) ).

% or_int_unfold
tff(fact_1932_bit_Oabstract__boolean__algebra__sym__diff__axioms,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => boolea3799213064322606851m_diff(B,bit_se5824344872417868541ns_and(B),bit_se1065995026697491101ons_or(B),bit_ri4277139882892585799ns_not(B),zero_zero(B),aa(B,B,uminus_uminus(B),one_one(B)),bit_se5824344971392196577ns_xor(B)) ) ).

% bit.abstract_boolean_algebra_sym_diff_axioms
tff(fact_1933_or__nat__unfold,axiom,
    ! [M: nat,N: nat] :
      aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),M),N) = $ite(
        M = zero_zero(nat),
        N,
        $ite(N = zero_zero(nat),M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,ord_max(nat,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),M),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))))) ) ).

% or_nat_unfold
tff(fact_1934_drop__bit__rec,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] :
          aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3) = $ite(N = zero_zero(nat),A3,aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))))) ) ).

% drop_bit_rec
tff(fact_1935_image__atLeastZeroLessThan__integer,axiom,
    ! [U: code_integer] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),zero_zero(code_integer)),U)
     => ( set_or7035219750837199246ssThan(code_integer,zero_zero(code_integer),U) = aa(set(nat),set(code_integer),image2(nat,code_integer,semiring_1_of_nat(code_integer)),aa(nat,set(nat),set_ord_lessThan(nat),aa(code_integer,nat,code_nat_of_integer,U))) ) ) ).

% image_atLeastZeroLessThan_integer
tff(fact_1936_uminus__int__def,axiom,
    uminus_uminus(int) = aa(fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),map_fun(int,product_prod(nat,nat),product_prod(nat,nat),int,rep_Integ,abs_Integ),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_bo(nat,fun(nat,product_prod(nat,nat))))) ).

% uminus_int_def
tff(fact_1937_bit_Oabstract__boolean__algebra__axioms,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => boolea2506097494486148201lgebra(B,bit_se5824344872417868541ns_and(B),bit_se1065995026697491101ons_or(B),bit_ri4277139882892585799ns_not(B),zero_zero(B),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% bit.abstract_boolean_algebra_axioms
tff(fact_1938_map__fun__apply,axiom,
    ! [B: $tType,E: $tType,D: $tType,C: $tType,F: fun(C,D),G: fun(E,B),Ha: fun(D,E),X2: C] : aa(C,B,aa(fun(D,E),fun(C,B),map_fun(C,D,E,B,F,G),Ha),X2) = aa(E,B,G,aa(D,E,Ha,aa(C,D,F,X2))) ).

% map_fun_apply
tff(fact_1939_drop__bit__drop__bit,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [M: nat,N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),M),aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3)) = aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),A3) ) ).

% drop_bit_drop_bit
tff(fact_1940_image__add__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [K: B,I: B,J: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),K)),set_or1337092689740270186AtMost(B,I,J)) = set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),K)) ) ).

% image_add_atLeastAtMost
tff(fact_1941_image__diff__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [D3: B,A3: B,B2: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),minus_minus(B),D3)),set_or1337092689740270186AtMost(B,A3,B2)) = set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),D3),B2),aa(B,B,aa(B,fun(B,B),minus_minus(B),D3),A3)) ) ).

% image_diff_atLeastAtMost
tff(fact_1942_image__add__atLeastLessThan,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [K: B,I: B,J: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),K)),set_or7035219750837199246ssThan(B,I,J)) = set_or7035219750837199246ssThan(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),K)) ) ).

% image_add_atLeastLessThan
tff(fact_1943_max__0__1_I1_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ( aa(B,B,ord_max(B,zero_zero(B)),one_one(B)) = one_one(B) ) ) ).

% max_0_1(1)
tff(fact_1944_max__0__1_I2_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ( aa(B,B,ord_max(B,one_one(B)),zero_zero(B)) = one_one(B) ) ) ).

% max_0_1(2)
tff(fact_1945_image__uminus__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B,Y: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),set_or1337092689740270186AtMost(B,X2,Y)) = set_or1337092689740270186AtMost(B,aa(B,B,uminus_uminus(B),Y),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_atLeastAtMost
tff(fact_1946_max__0__1_I6_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [X2: num] : aa(B,B,ord_max(B,aa(num,B,numeral_numeral(B),X2)),one_one(B)) = aa(num,B,numeral_numeral(B),X2) ) ).

% max_0_1(6)
tff(fact_1947_max__0__1_I5_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [X2: num] : aa(B,B,ord_max(B,one_one(B)),aa(num,B,numeral_numeral(B),X2)) = aa(num,B,numeral_numeral(B),X2) ) ).

% max_0_1(5)
tff(fact_1948_image__add__atMost,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [C2: B,A3: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),C2)),aa(B,set(B),set_ord_atMost(B),A3)) = aa(B,set(B),set_ord_atMost(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3)) ) ).

% image_add_atMost
tff(fact_1949_image__add__atLeastAtMost_H,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [K: B,I: B,J: B] : aa(set(B),set(B),image2(B,B,aTP_Lamp_gl(B,fun(B,B),K)),set_or1337092689740270186AtMost(B,I,J)) = set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),K)) ) ).

% image_add_atLeastAtMost'
tff(fact_1950_image__minus__const__atLeastAtMost_H,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [D3: B,A3: B,B2: B] : aa(set(B),set(B),image2(B,B,aTP_Lamp_gm(B,fun(B,B),D3)),set_or1337092689740270186AtMost(B,A3,B2)) = set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),D3),aa(B,B,aa(B,fun(B,B),minus_minus(B),B2),D3)) ) ).

% image_minus_const_atLeastAtMost'
tff(fact_1951_image__add__atLeastLessThan_H,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [K: B,I: B,J: B] : aa(set(B),set(B),image2(B,B,aTP_Lamp_gl(B,fun(B,B),K)),set_or7035219750837199246ssThan(B,I,J)) = set_or7035219750837199246ssThan(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),I),K),aa(B,B,aa(B,fun(B,B),plus_plus(B),J),K)) ) ).

% image_add_atLeastLessThan'
tff(fact_1952_drop__bit__of__1,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat] : aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),one_one(B)) = aa($o,B,zero_neq_one_of_bool(B),N = zero_zero(nat)) ) ).

% drop_bit_of_1
tff(fact_1953_image__mult__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [D3: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),D3)
         => ( aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),times_times(B),D3)),set_or1337092689740270186AtMost(B,A3,B2)) = set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),times_times(B),D3),A3),aa(B,B,aa(B,fun(B,B),times_times(B),D3),B2)) ) ) ) ).

% image_mult_atLeastAtMost
tff(fact_1954_image__divide__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [D3: B,A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),D3)
         => ( aa(set(B),set(B),image2(B,B,aTP_Lamp_gn(B,fun(B,B),D3)),set_or1337092689740270186AtMost(B,A3,B2)) = set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),D3),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),D3)) ) ) ) ).

% image_divide_atLeastAtMost
tff(fact_1955_drop__bit__integer_Orep__eq,axiom,
    ! [X2: nat,Xa: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se4197421643247451524op_bit(code_integer),X2),Xa)) = aa(int,int,aa(nat,fun(int,int),bit_se4197421643247451524op_bit(int),X2),aa(code_integer,int,code_int_of_integer,Xa)) ).

% drop_bit_integer.rep_eq
tff(fact_1956_drop__bit__integer_Oabs__eq,axiom,
    ! [Xa: nat,X2: int] : aa(code_integer,code_integer,aa(nat,fun(code_integer,code_integer),bit_se4197421643247451524op_bit(code_integer),Xa),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(nat,fun(int,int),bit_se4197421643247451524op_bit(int),Xa),X2)) ).

% drop_bit_integer.abs_eq
tff(fact_1957_max__add__distrib__left,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [X2: B,Y: B,Z2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,ord_max(B,X2),Y)),Z2) = aa(B,B,ord_max(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Z2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),Y),Z2)) ) ).

% max_add_distrib_left
tff(fact_1958_max__add__distrib__right,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [X2: B,Y: B,Z2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,ord_max(B,Y),Z2)) = aa(B,B,ord_max(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Z2)) ) ).

% max_add_distrib_right
tff(fact_1959_max__diff__distrib__left,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B,Y: B,Z2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,ord_max(B,X2),Y)),Z2) = aa(B,B,ord_max(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Z2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),Y),Z2)) ) ).

% max_diff_distrib_left
tff(fact_1960_translation__Compl,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,T2: set(B)] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),aa(set(B),set(B),uminus_uminus(set(B)),T2)) = aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),T2)) ) ).

% translation_Compl
tff(fact_1961_nat__add__max__right,axiom,
    ! [M: nat,N: nat,Q3: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),aa(nat,nat,ord_max(nat,N),Q3)) = aa(nat,nat,ord_max(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),Q3)) ).

% nat_add_max_right
tff(fact_1962_nat__add__max__left,axiom,
    ! [M: nat,N: nat,Q3: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,ord_max(nat,M),N)),Q3) = aa(nat,nat,ord_max(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),Q3)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),Q3)) ).

% nat_add_max_left
tff(fact_1963_image__eq__imp__comp,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,F: fun(C,B),A4: set(C),G: fun(D,B),B5: set(D),Ha: fun(B,E)] :
      ( ( aa(set(C),set(B),image2(C,B,F),A4) = aa(set(D),set(B),image2(D,B,G),B5) )
     => ( aa(set(C),set(E),image2(C,E,aa(fun(C,B),fun(C,E),aa(fun(B,E),fun(fun(C,B),fun(C,E)),comp(B,E,C),Ha),F)),A4) = aa(set(D),set(E),image2(D,E,aa(fun(D,B),fun(D,E),aa(fun(B,E),fun(fun(D,B),fun(D,E)),comp(B,E,D),Ha),G)),B5) ) ) ).

% image_eq_imp_comp
tff(fact_1964_image__comp,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(D,C),R: set(D)] : aa(set(C),set(B),image2(C,B,F),aa(set(D),set(C),image2(D,C,G),R)) = aa(set(D),set(B),image2(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G)),R) ).

% image_comp
tff(fact_1965_map__fun__def,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,F: fun(B,D),G: fun(E,C),Ha: fun(D,E)] : aa(fun(D,E),fun(B,C),map_fun(B,D,E,C,F,G),Ha) = aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),aa(fun(D,E),fun(D,C),aa(fun(E,C),fun(fun(D,E),fun(D,C)),comp(E,C,D),G),Ha)),F) ).

% map_fun_def
tff(fact_1966_map__fun_Ocompositionality,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,G2: $tType,F4: $tType,F: fun(B,D),G: fun(E,C),Ha: fun(D,F4),I: fun(G2,E),Fun: fun(F4,G2)] : aa(fun(D,E),fun(B,C),map_fun(B,D,E,C,F,G),aa(fun(F4,G2),fun(D,E),map_fun(D,F4,G2,E,Ha,I),Fun)) = aa(fun(F4,G2),fun(B,C),map_fun(B,F4,G2,C,aa(fun(B,D),fun(B,F4),aa(fun(D,F4),fun(fun(B,D),fun(B,F4)),comp(D,F4,B),Ha),F),aa(fun(G2,E),fun(G2,C),aa(fun(E,C),fun(fun(G2,E),fun(G2,C)),comp(E,C,G2),G),I)),Fun) ).

% map_fun.compositionality
tff(fact_1967_map__fun_Ocomp,axiom,
    ! [D: $tType,F4: $tType,B: $tType,E: $tType,G2: $tType,C: $tType,F: fun(D,F4),G: fun(G2,E),Ha: fun(F4,B),I: fun(C,G2)] : aa(fun(fun(B,C),fun(F4,G2)),fun(fun(B,C),fun(D,E)),aa(fun(fun(F4,G2),fun(D,E)),fun(fun(fun(B,C),fun(F4,G2)),fun(fun(B,C),fun(D,E))),comp(fun(F4,G2),fun(D,E),fun(B,C)),map_fun(D,F4,G2,E,F,G)),map_fun(F4,B,C,G2,Ha,I)) = map_fun(D,B,C,E,aa(fun(D,F4),fun(D,B),aa(fun(F4,B),fun(fun(D,F4),fun(D,B)),comp(F4,B,D),Ha),F),aa(fun(C,G2),fun(C,E),aa(fun(G2,E),fun(fun(C,G2),fun(C,E)),comp(G2,E,C),G),I)) ).

% map_fun.comp
tff(fact_1968_translation__subtract__Compl,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,T2: set(B)] : aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),aa(set(B),set(B),uminus_uminus(set(B)),T2)) = aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),T2)) ) ).

% translation_subtract_Compl
tff(fact_1969_nat__minus__add__max,axiom,
    ! [N: nat,M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M)),M) = aa(nat,nat,ord_max(nat,N),M) ).

% nat_minus_add_max
tff(fact_1970_translation__diff,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,S: set(B),T2: set(B)] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S),T2)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),S)),aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),T2)) ) ).

% translation_diff
tff(fact_1971_translation__subtract__diff,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,S: set(B),T2: set(B)] : aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S),T2)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),S)),aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),T2)) ) ).

% translation_subtract_diff
tff(fact_1972_take__bit__drop__bit,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [M: nat,N: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),M),aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3)) = aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),A3)) ) ).

% take_bit_drop_bit
tff(fact_1973_bit__drop__bit__eq,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3)) = aa(fun(nat,nat),fun(nat,$o),aa(fun(nat,$o),fun(fun(nat,nat),fun(nat,$o)),comp(nat,$o,nat),aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3)),aa(nat,fun(nat,nat),plus_plus(nat),N)) ) ).

% bit_drop_bit_eq
tff(fact_1974_div__push__bit__of__1__eq__drop__bit,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B,N: nat] : aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),one_one(B))) = aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3) ) ).

% div_push_bit_of_1_eq_drop_bit
tff(fact_1975_bit__iff__and__drop__bit__eq__1,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [A3: B,N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),N)
        <=> ( aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3)),one_one(B)) = one_one(B) ) ) ) ).

% bit_iff_and_drop_bit_eq_1
tff(fact_1976_bits__ident,axiom,
    ! [B: $tType] :
      ( bit_se359711467146920520ations(B)
     => ! [N: nat,A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3))),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),N),A3)) = A3 ) ).

% bits_ident
tff(fact_1977_slice__eq__mask,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat,M: nat,A3: B] : aa(B,B,aa(nat,fun(B,B),bit_se4730199178511100633sh_bit(B),N),aa(B,B,aa(nat,fun(B,B),bit_se2584673776208193580ke_bit(B),M),aa(B,B,aa(nat,fun(B,B),bit_se4197421643247451524op_bit(B),N),A3))) = aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),A3),aa(B,B,aa(B,fun(B,B),bit_se5824344872417868541ns_and(B),aa(nat,B,bit_se2239418461657761734s_mask(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N))),aa(B,B,bit_ri4277139882892585799ns_not(B),aa(nat,B,bit_se2239418461657761734s_mask(B),N)))) ) ).

% slice_eq_mask
tff(fact_1978_image__add__0,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [S2: set(B)] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),zero_zero(B))),S2) = S2 ) ).

% image_add_0
tff(fact_1979_times__int__def,axiom,
    times_times(int) = aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(int,fun(int,int)),map_fun(int,product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),rep_Integ,map_fun(int,product_prod(nat,nat),product_prod(nat,nat),int,rep_Integ,abs_Integ)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cv(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))) ).

% times_int_def
tff(fact_1980_minus__int__def,axiom,
    minus_minus(int) = aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(int,fun(int,int)),map_fun(int,product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),rep_Integ,map_fun(int,product_prod(nat,nat),product_prod(nat,nat),int,rep_Integ,abs_Integ)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_ct(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))) ).

% minus_int_def
tff(fact_1981_plus__int__def,axiom,
    plus_plus(int) = aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(int,fun(int,int)),map_fun(int,product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),rep_Integ,map_fun(int,product_prod(nat,nat),product_prod(nat,nat),int,rep_Integ,abs_Integ)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cr(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))) ).

% plus_int_def
tff(fact_1982_mlex__prod__def,axiom,
    ! [B: $tType,F: fun(B,nat),R4: set(product_prod(B,B))] : mlex_prod(B,F,R4) = inv_image(product_prod(nat,B),B,lex_prod(nat,B,less_than,R4),aTP_Lamp_gp(fun(B,nat),fun(B,product_prod(nat,B)),F)) ).

% mlex_prod_def
tff(fact_1983_rat__minus__code,axiom,
    ! [P3: rat,Q3: rat] : quotient_of(aa(rat,rat,aa(rat,fun(rat,rat),minus_minus(rat),P3),Q3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_gr(rat,fun(int,fun(int,product_prod(int,int))),Q3)),quotient_of(P3)) ).

% rat_minus_code
tff(fact_1984_rat__plus__code,axiom,
    ! [P3: rat,Q3: rat] : quotient_of(aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),P3),Q3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_gt(rat,fun(int,fun(int,product_prod(int,int))),Q3)),quotient_of(P3)) ).

% rat_plus_code
tff(fact_1985_image__Suc__atLeastAtMost,axiom,
    ! [I: nat,J: nat] : aa(set(nat),set(nat),image2(nat,nat,suc),set_or1337092689740270186AtMost(nat,I,J)) = set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,I),aa(nat,nat,suc,J)) ).

% image_Suc_atLeastAtMost
tff(fact_1986_image__Suc__atLeastLessThan,axiom,
    ! [I: nat,J: nat] : aa(set(nat),set(nat),image2(nat,nat,suc),set_or7035219750837199246ssThan(nat,I,J)) = set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,I),aa(nat,nat,suc,J)) ).

% image_Suc_atLeastLessThan
tff(fact_1987_in__inv__image,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: B,R: set(product_prod(C,C)),F: fun(B,C)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),inv_image(C,B,R,F))
    <=> member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,F,X2)),aa(B,C,F,Y)),R) ) ).

% in_inv_image
tff(fact_1988_pair__imageI,axiom,
    ! [D: $tType,C: $tType,B: $tType,A3: B,B2: C,A4: set(product_prod(B,C)),F: fun(B,fun(C,D))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),A4)
     => member(D,aa(C,D,aa(B,fun(C,D),F,A3),B2),aa(set(product_prod(B,C)),set(D),image2(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F)),A4)) ) ).

% pair_imageI
tff(fact_1989_int__of__integer__max,axiom,
    ! [K: code_integer,L: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,ord_max(code_integer,K),L)) = aa(int,int,ord_max(int,aa(code_integer,int,code_int_of_integer,K)),aa(code_integer,int,code_int_of_integer,L)) ).

% int_of_integer_max
tff(fact_1990_rat__one__code,axiom,
    quotient_of(one_one(rat)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),one_one(int)) ).

% rat_one_code
tff(fact_1991_of__nat__of__integer,axiom,
    ! [K: code_integer] : aa(nat,code_integer,semiring_1_of_nat(code_integer),aa(code_integer,nat,code_nat_of_integer,K)) = aa(code_integer,code_integer,ord_max(code_integer,zero_zero(code_integer)),K) ).

% of_nat_of_integer
tff(fact_1992_rat__zero__code,axiom,
    quotient_of(zero_zero(rat)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)) ).

% rat_zero_code
tff(fact_1993_quotient__of__number_I3_J,axiom,
    ! [K: num] : quotient_of(aa(num,rat,numeral_numeral(rat),K)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(num,int,numeral_numeral(int),K)),one_one(int)) ).

% quotient_of_number(3)
tff(fact_1994_quotient__of__number_I4_J,axiom,
    quotient_of(aa(rat,rat,uminus_uminus(rat),one_one(rat))) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),one_one(int))),one_one(int)) ).

% quotient_of_number(4)
tff(fact_1995_quotient__of__number_I5_J,axiom,
    ! [K: num] : quotient_of(aa(rat,rat,uminus_uminus(rat),aa(num,rat,numeral_numeral(rat),K))) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),K))),one_one(int)) ).

% quotient_of_number(5)
tff(fact_1996_diff__rat__def,axiom,
    ! [Q3: rat,R: rat] : aa(rat,rat,aa(rat,fun(rat,rat),minus_minus(rat),Q3),R) = aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),Q3),aa(rat,rat,uminus_uminus(rat),R)) ).

% diff_rat_def
tff(fact_1997_quotient__of__div,axiom,
    ! [R: rat,N: int,D3: int] :
      ( ( quotient_of(R) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),N),D3) )
     => ( R = aa(rat,rat,aa(rat,fun(rat,rat),divide_divide(rat),aa(int,rat,ring_1_of_int(rat),N)),aa(int,rat,ring_1_of_int(rat),D3)) ) ) ).

% quotient_of_div
tff(fact_1998_zero__notin__Suc__image,axiom,
    ! [A4: set(nat)] : ~ member(nat,zero_zero(nat),aa(set(nat),set(nat),image2(nat,nat,suc),A4)) ).

% zero_notin_Suc_image
tff(fact_1999_None__notin__image__Some,axiom,
    ! [B: $tType,A4: set(B)] : ~ member(option(B),none(B),aa(set(B),set(option(B)),image2(B,option(B),some(B)),A4)) ).

% None_notin_image_Some
tff(fact_2000_plus__integer__def,axiom,
    plus_plus(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),plus_plus(int)) ).

% plus_integer_def
tff(fact_2001_times__integer__def,axiom,
    times_times(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),times_times(int)) ).

% times_integer_def
tff(fact_2002_minus__integer__def,axiom,
    minus_minus(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),minus_minus(int)) ).

% minus_integer_def
tff(fact_2003_divide__integer__def,axiom,
    divide_divide(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),divide_divide(int)) ).

% divide_integer_def
tff(fact_2004_modulo__integer__def,axiom,
    modulo_modulo(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),modulo_modulo(int)) ).

% modulo_integer_def
tff(fact_2005_and__integer__def,axiom,
    bit_se5824344872417868541ns_and(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se5824344872417868541ns_and(int)) ).

% and_integer_def
tff(fact_2006_or__integer__def,axiom,
    bit_se1065995026697491101ons_or(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se1065995026697491101ons_or(int)) ).

% or_integer_def
tff(fact_2007_xor__integer__def,axiom,
    bit_se5824344971392196577ns_xor(code_integer) = aa(fun(int,fun(int,int)),fun(code_integer,fun(code_integer,code_integer)),map_fun(code_integer,int,fun(int,int),fun(code_integer,code_integer),code_int_of_integer,map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se5824344971392196577ns_xor(int)) ).

% xor_integer_def
tff(fact_2008_image__int__atLeastAtMost,axiom,
    ! [A3: nat,B2: nat] : aa(set(nat),set(int),image2(nat,int,semiring_1_of_nat(int)),set_or1337092689740270186AtMost(nat,A3,B2)) = set_or1337092689740270186AtMost(int,aa(nat,int,semiring_1_of_nat(int),A3),aa(nat,int,semiring_1_of_nat(int),B2)) ).

% image_int_atLeastAtMost
tff(fact_2009_image__int__atLeastLessThan,axiom,
    ! [A3: nat,B2: nat] : aa(set(nat),set(int),image2(nat,int,semiring_1_of_nat(int)),set_or7035219750837199246ssThan(nat,A3,B2)) = set_or7035219750837199246ssThan(int,aa(nat,int,semiring_1_of_nat(int),A3),aa(nat,int,semiring_1_of_nat(int),B2)) ).

% image_int_atLeastLessThan
tff(fact_2010_quotient__of__denom__pos,axiom,
    ! [R: rat,P3: int,Q3: int] :
      ( ( quotient_of(R) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) )
     => aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),Q3) ) ).

% quotient_of_denom_pos
tff(fact_2011_image__Suc__atMost,axiom,
    ! [N: nat] : aa(set(nat),set(nat),image2(nat,nat,suc),aa(nat,set(nat),set_ord_atMost(nat),N)) = set_or1337092689740270186AtMost(nat,one_one(nat),aa(nat,nat,suc,N)) ).

% image_Suc_atMost
tff(fact_2012_image__Suc__lessThan,axiom,
    ! [N: nat] : aa(set(nat),set(nat),image2(nat,nat,suc),aa(nat,set(nat),set_ord_lessThan(nat),N)) = set_or1337092689740270186AtMost(nat,one_one(nat),N) ).

% image_Suc_lessThan
tff(fact_2013_inv__image__def,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(C,C)),F: fun(B,C)] : inv_image(C,B,R,F) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(fun(B,C),fun(B,fun(B,$o)),aTP_Lamp_gu(set(product_prod(C,C)),fun(fun(B,C),fun(B,fun(B,$o))),R),F))) ).

% inv_image_def
tff(fact_2014_rat__uminus__code,axiom,
    ! [P3: rat] : quotient_of(aa(rat,rat,uminus_uminus(rat),P3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_gv(int,fun(int,product_prod(int,int)))),quotient_of(P3)) ).

% rat_uminus_code
tff(fact_2015_rat__abs__code,axiom,
    ! [P3: rat] : quotient_of(aa(rat,rat,abs_abs(rat),P3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_gw(int,fun(int,product_prod(int,int)))),quotient_of(P3)) ).

% rat_abs_code
tff(fact_2016_uminus__integer__def,axiom,
    uminus_uminus(code_integer) = aa(fun(int,int),fun(code_integer,code_integer),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int),uminus_uminus(int)) ).

% uminus_integer_def
tff(fact_2017_abs__integer__def,axiom,
    abs_abs(code_integer) = aa(fun(int,int),fun(code_integer,code_integer),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int),abs_abs(int)) ).

% abs_integer_def
tff(fact_2018_image__add__int__atLeastLessThan,axiom,
    ! [L: int,U: int] : aa(set(int),set(int),image2(int,int,aTP_Lamp_gx(int,fun(int,int),L)),set_or7035219750837199246ssThan(int,zero_zero(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),U),L))) = set_or7035219750837199246ssThan(int,L,U) ).

% image_add_int_atLeastLessThan
tff(fact_2019_sgn__integer__def,axiom,
    sgn_sgn(code_integer) = aa(fun(int,int),fun(code_integer,code_integer),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int),sgn_sgn(int)) ).

% sgn_integer_def
tff(fact_2020_not__integer__def,axiom,
    bit_ri4277139882892585799ns_not(code_integer) = aa(fun(int,int),fun(code_integer,code_integer),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int),bit_ri4277139882892585799ns_not(int)) ).

% not_integer_def
tff(fact_2021_image__add__integer__atLeastLessThan,axiom,
    ! [L: code_integer,U: code_integer] : aa(set(code_integer),set(code_integer),image2(code_integer,code_integer,aTP_Lamp_gy(code_integer,fun(code_integer,code_integer),L)),set_or7035219750837199246ssThan(code_integer,zero_zero(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),U),L))) = set_or7035219750837199246ssThan(code_integer,L,U) ).

% image_add_integer_atLeastLessThan
tff(fact_2022_rat__times__code,axiom,
    ! [P3: rat,Q3: rat] : quotient_of(aa(rat,rat,aa(rat,fun(rat,rat),times_times(rat),P3),Q3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_ha(rat,fun(int,fun(int,product_prod(int,int))),Q3)),quotient_of(P3)) ).

% rat_times_code
tff(fact_2023_rat__divide__code,axiom,
    ! [P3: rat,Q3: rat] : quotient_of(aa(rat,rat,aa(rat,fun(rat,rat),divide_divide(rat),P3),Q3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_hc(rat,fun(int,fun(int,product_prod(int,int))),Q3)),quotient_of(P3)) ).

% rat_divide_code
tff(fact_2024_image__atLeastZeroLessThan__int,axiom,
    ! [U: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),U)
     => ( set_or7035219750837199246ssThan(int,zero_zero(int),U) = aa(set(nat),set(int),image2(nat,int,semiring_1_of_nat(int)),aa(nat,set(nat),set_ord_lessThan(nat),aa(int,nat,nat2,U))) ) ) ).

% image_atLeastZeroLessThan_int
tff(fact_2025_quotient__of__int,axiom,
    ! [A3: int] : quotient_of(of_int(A3)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),one_one(int)) ).

% quotient_of_int
tff(fact_2026_rp__inv__image__def,axiom,
    ! [C: $tType,B: $tType] : fun_rp_inv_image(B,C) = aa(fun(set(product_prod(B,B)),fun(set(product_prod(B,B)),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))))),fun(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C))))),product_case_prod(set(product_prod(B,B)),set(product_prod(B,B)),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C))))),aTP_Lamp_hd(set(product_prod(B,B)),fun(set(product_prod(B,B)),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C))))))) ).

% rp_inv_image_def
tff(fact_2027_rat__inverse__code,axiom,
    ! [P3: rat] : quotient_of(aa(rat,rat,inverse_inverse(rat),P3)) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aTP_Lamp_he(int,fun(int,product_prod(int,int)))),quotient_of(P3)) ).

% rat_inverse_code
tff(fact_2028_diff__numeral__special_I8_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(B,B,uminus_uminus(B),one_one(B))) = neg_numeral_sub(B,one2,M) ) ).

% diff_numeral_special(8)
tff(fact_2029_diff__numeral__special_I7_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N))) = neg_numeral_sub(B,N,one2) ) ).

% diff_numeral_special(7)
tff(fact_2030_minus__sub__one__diff__one,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,uminus_uminus(B),neg_numeral_sub(B,M,one2))),one_one(B)) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M)) ) ).

% minus_sub_one_diff_one
tff(fact_2031_add__neg__numeral__special_I4_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),one_one(B))),aa(num,B,numeral_numeral(B),N)) = neg_numeral_sub(B,N,one2) ) ).

% add_neg_numeral_special(4)
tff(fact_2032_int__of__integer__sub,axiom,
    ! [K: num,L: num] : aa(code_integer,int,code_int_of_integer,neg_numeral_sub(code_integer,K,L)) = neg_numeral_sub(int,K,L) ).

% int_of_integer_sub
tff(fact_2033_inverse__1,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ( aa(B,B,inverse_inverse(B),one_one(B)) = one_one(B) ) ) ).

% inverse_1
tff(fact_2034_inverse__eq__1__iff,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [X2: B] :
          ( ( aa(B,B,inverse_inverse(B),X2) = one_one(B) )
        <=> ( X2 = one_one(B) ) ) ) ).

% inverse_eq_1_iff
tff(fact_2035_right__inverse,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,inverse_inverse(B),A3)) = one_one(B) ) ) ) ).

% right_inverse
tff(fact_2036_left__inverse,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,inverse_inverse(B),A3)),A3) = one_one(B) ) ) ) ).

% left_inverse
tff(fact_2037_inverse__eq__divide__numeral,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [W: num] : aa(B,B,inverse_inverse(B),aa(num,B,numeral_numeral(B),W)) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),W)) ) ).

% inverse_eq_divide_numeral
tff(fact_2038_add__neg__numeral__simps_I2_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),aa(num,B,numeral_numeral(B),N)) = neg_numeral_sub(B,N,M) ) ).

% add_neg_numeral_simps(2)
tff(fact_2039_add__neg__numeral__simps_I1_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num,N: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),M)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),N))) = neg_numeral_sub(B,M,N) ) ).

% add_neg_numeral_simps(1)
tff(fact_2040_semiring__norm_I166_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [V: num,W: num,Y: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),V)),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),W))),Y)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),neg_numeral_sub(B,V,W)),Y) ) ).

% semiring_norm(166)
tff(fact_2041_semiring__norm_I167_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [V: num,W: num,Y: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),V))),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),W)),Y)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),neg_numeral_sub(B,W,V)),Y) ) ).

% semiring_norm(167)
tff(fact_2042_inverse__eq__divide__neg__numeral,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [W: num] : aa(B,B,inverse_inverse(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),W))) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),W))) ) ).

% inverse_eq_divide_neg_numeral
tff(fact_2043_diff__numeral__special_I2_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(num,B,numeral_numeral(B),M)),one_one(B)) = neg_numeral_sub(B,M,one2) ) ).

% diff_numeral_special(2)
tff(fact_2044_diff__numeral__special_I1_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),minus_minus(B),one_one(B)),aa(num,B,numeral_numeral(B),N)) = neg_numeral_sub(B,one2,N) ) ).

% diff_numeral_special(1)
tff(fact_2045_add__neg__numeral__special_I1_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),one_one(B)),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))) = neg_numeral_sub(B,one2,M) ) ).

% add_neg_numeral_special(1)
tff(fact_2046_add__neg__numeral__special_I2_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),M))),one_one(B)) = neg_numeral_sub(B,one2,M) ) ).

% add_neg_numeral_special(2)
tff(fact_2047_add__neg__numeral__special_I3_J,axiom,
    ! [B: $tType] :
      ( neg_numeral(B)
     => ! [M: num] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),M)),aa(B,B,uminus_uminus(B),one_one(B))) = neg_numeral_sub(B,M,one2) ) ).

% add_neg_numeral_special(3)
tff(fact_2048_inverse__unique,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2) = one_one(B) )
         => ( aa(B,B,inverse_inverse(B),A3) = B2 ) ) ) ).

% inverse_unique
tff(fact_2049_inverse__eq__divide,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B] : aa(B,B,inverse_inverse(B),A3) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3) ) ).

% inverse_eq_divide
tff(fact_2050_prod__inversef,axiom,
    ! [B: $tType,C: $tType] :
      ( field(B)
     => ! [F: fun(C,B),A4: set(C)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),aa(fun(C,B),fun(C,B),aa(fun(B,B),fun(fun(C,B),fun(C,B)),comp(B,B,C),inverse_inverse(B)),F)),A4) = aa(B,B,inverse_inverse(B),aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),F),A4)) ) ).

% prod_inversef
tff(fact_2051_inverse__le__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,inverse_inverse(B),X2)),one_one(B))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),zero_zero(B))
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),X2) ) ) ) ).

% inverse_le_1_iff
tff(fact_2052_one__less__inverse__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,inverse_inverse(B),X2))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),one_one(B)) ) ) ) ).

% one_less_inverse_iff
tff(fact_2053_one__less__inverse,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),aa(B,B,inverse_inverse(B),A3)) ) ) ) ).

% one_less_inverse
tff(fact_2054_division__ring__inverse__add,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B,B2: B] :
          ( ( A3 != zero_zero(B) )
         => ( ( B2 != zero_zero(B) )
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,inverse_inverse(B),A3)),aa(B,B,inverse_inverse(B),B2)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,inverse_inverse(B),A3)),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2))),aa(B,B,inverse_inverse(B),B2)) ) ) ) ) ).

% division_ring_inverse_add
tff(fact_2055_inverse__add,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [A3: B,B2: B] :
          ( ( A3 != zero_zero(B) )
         => ( ( B2 != zero_zero(B) )
           => ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,inverse_inverse(B),A3)),aa(B,B,inverse_inverse(B),B2)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),B2)),aa(B,B,inverse_inverse(B),A3))),aa(B,B,inverse_inverse(B),B2)) ) ) ) ) ).

% inverse_add
tff(fact_2056_field__class_Ofield__inverse,axiom,
    ! [B: $tType] :
      ( field(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,inverse_inverse(B),A3)),A3) = one_one(B) ) ) ) ).

% field_class.field_inverse
tff(fact_2057_nonzero__inverse__eq__divide,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,inverse_inverse(B),A3) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),A3) ) ) ) ).

% nonzero_inverse_eq_divide
tff(fact_2058_one__le__inverse__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,inverse_inverse(B),X2))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),X2)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),one_one(B)) ) ) ) ).

% one_le_inverse_iff
tff(fact_2059_inverse__less__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,inverse_inverse(B),X2)),one_one(B))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),zero_zero(B))
            | aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),X2) ) ) ) ).

% inverse_less_1_iff
tff(fact_2060_one__le__inverse,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B))
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),aa(B,B,inverse_inverse(B),A3)) ) ) ) ).

% one_le_inverse
tff(fact_2061_Frct__code__post_I5_J,axiom,
    ! [K: num] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),aa(num,int,numeral_numeral(int),K))) = aa(rat,rat,aa(rat,fun(rat,rat),divide_divide(rat),one_one(rat)),aa(num,rat,numeral_numeral(rat),K)) ).

% Frct_code_post(5)
tff(fact_2062_Code__Numeral_Odup__def,axiom,
    code_dup = aa(fun(int,int),fun(code_integer,code_integer),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int),aTP_Lamp_hf(int,int)) ).

% Code_Numeral.dup_def
tff(fact_2063_Frct__code__post_I6_J,axiom,
    ! [K: num,L: num] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(num,int,numeral_numeral(int),K)),aa(num,int,numeral_numeral(int),L))) = aa(rat,rat,aa(rat,fun(rat,rat),divide_divide(rat),aa(num,rat,numeral_numeral(rat),K)),aa(num,rat,numeral_numeral(rat),L)) ).

% Frct_code_post(6)
tff(fact_2064_Frct__code__post_I4_J,axiom,
    ! [K: num] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(num,int,numeral_numeral(int),K)),one_one(int))) = aa(num,rat,numeral_numeral(rat),K) ).

% Frct_code_post(4)
tff(fact_2065_eq__numeral__iff__iszero_I8_J,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [Y: num] :
          ( ( one_one(B) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),Y)) )
        <=> ring_1_iszero(B,aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),one2),Y))) ) ) ).

% eq_numeral_iff_iszero(8)
tff(fact_2066_eq__numeral__iff__iszero_I7_J,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [X2: num] :
          ( ( aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),X2)) = one_one(B) )
        <=> ring_1_iszero(B,aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),one2))) ) ) ).

% eq_numeral_iff_iszero(7)
tff(fact_2067_Inf_OINF__image,axiom,
    ! [C: $tType,B: $tType,D: $tType,Inf: fun(set(B),B),G: fun(C,B),F: fun(D,C),A4: set(D)] : aa(set(B),B,Inf,aa(set(C),set(B),image2(C,B,G),aa(set(D),set(C),image2(D,C,F),A4))) = aa(set(B),B,Inf,aa(set(D),set(B),image2(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),A4)) ).

% Inf.INF_image
tff(fact_2068_not__iszero__1,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ~ ring_1_iszero(B,one_one(B)) ) ).

% not_iszero_1
tff(fact_2069_Code__Numeral_Odup__code_I1_J,axiom,
    aa(code_integer,code_integer,code_dup,zero_zero(code_integer)) = zero_zero(code_integer) ).

% Code_Numeral.dup_code(1)
tff(fact_2070_not__iszero__neg__1,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ~ ring_1_iszero(B,aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% not_iszero_neg_1
tff(fact_2071_dup_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,code_dup,X2)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(code_integer,int,code_int_of_integer,X2)),aa(code_integer,int,code_int_of_integer,X2)) ).

% dup.rep_eq
tff(fact_2072_dup_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_integer,code_dup,aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),X2)) ).

% dup.abs_eq
tff(fact_2073_eq__numeral__iff__iszero_I2_J,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [X2: num,Y: num] :
          ( ( aa(num,B,numeral_numeral(B),X2) = aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),Y)) )
        <=> ring_1_iszero(B,aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),Y))) ) ) ).

% eq_numeral_iff_iszero(2)
tff(fact_2074_eq__numeral__iff__iszero_I3_J,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [X2: num,Y: num] :
          ( ( aa(B,B,uminus_uminus(B),aa(num,B,numeral_numeral(B),X2)) = aa(num,B,numeral_numeral(B),Y) )
        <=> ring_1_iszero(B,aa(num,B,numeral_numeral(B),aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),Y))) ) ) ).

% eq_numeral_iff_iszero(3)
tff(fact_2075_Frct__code__post_I2_J,axiom,
    ! [A3: int] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),zero_zero(int))) = zero_zero(rat) ).

% Frct_code_post(2)
tff(fact_2076_Frct__code__post_I1_J,axiom,
    ! [A3: int] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),A3)) = zero_zero(rat) ).

% Frct_code_post(1)
tff(fact_2077_Frct__code__post_I3_J,axiom,
    frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),one_one(int))) = one_one(rat) ).

% Frct_code_post(3)
tff(fact_2078_eq__numeral__iff__iszero_I6_J,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [Y: num] :
          ( ( one_one(B) = aa(num,B,numeral_numeral(B),Y) )
        <=> ring_1_iszero(B,neg_numeral_sub(B,one2,Y)) ) ) ).

% eq_numeral_iff_iszero(6)
tff(fact_2079_eq__numeral__iff__iszero_I5_J,axiom,
    ! [B: $tType] :
      ( ring_1(B)
     => ! [X2: num] :
          ( ( aa(num,B,numeral_numeral(B),X2) = one_one(B) )
        <=> ring_1_iszero(B,neg_numeral_sub(B,X2,one2)) ) ) ).

% eq_numeral_iff_iszero(5)
tff(fact_2080_Frct__code__post_I7_J,axiom,
    ! [A3: int,B2: int] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),A3)),B2)) = aa(rat,rat,uminus_uminus(rat),frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),B2))) ).

% Frct_code_post(7)
tff(fact_2081_Frct__code__post_I8_J,axiom,
    ! [A3: int,B2: int] : frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),aa(int,int,uminus_uminus(int),B2))) = aa(rat,rat,uminus_uminus(rat),frct(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),B2))) ).

% Frct_code_post(8)
tff(fact_2082_Sup_OSUP__image,axiom,
    ! [C: $tType,B: $tType,D: $tType,Sup: fun(set(B),B),G: fun(C,B),F: fun(D,C),A4: set(D)] : aa(set(B),B,Sup,aa(set(C),set(B),image2(C,B,G),aa(set(D),set(C),image2(D,C,F),A4))) = aa(set(B),B,Sup,aa(set(D),set(B),image2(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),A4)) ).

% Sup.SUP_image
tff(fact_2083_Code__Numeral_Osub__code_I9_J,axiom,
    ! [M: num,N: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,aa(num,num,bit0,M)),aa(num,num,bit1,N)) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,code_dup,aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,M),N))),one_one(code_integer)) ).

% Code_Numeral.sub_code(9)
tff(fact_2084_Code__Numeral_Osub__code_I8_J,axiom,
    ! [M: num,N: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,aa(num,num,bit1,M)),aa(num,num,bit0,N)) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,code_dup,aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,M),N))),one_one(code_integer)) ).

% Code_Numeral.sub_code(8)
tff(fact_2085_less__eq__int__def,axiom,
    ord_less_eq(int) = aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),fun(int,fun(int,$o)),map_fun(int,product_prod(nat,nat),fun(product_prod(nat,nat),$o),fun(int,$o),rep_Integ,map_fun(int,product_prod(nat,nat),$o,$o,rep_Integ,id($o))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o))))) ).

% less_eq_int_def
tff(fact_2086_less__int__def,axiom,
    ord_less(int) = aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),fun(int,fun(int,$o)),map_fun(int,product_prod(nat,nat),fun(product_prod(nat,nat),$o),fun(int,$o),rep_Integ,map_fun(int,product_prod(nat,nat),$o,$o,rep_Integ,id($o))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o))))) ).

% less_int_def
tff(fact_2087_image__affinity__atLeastAtMost__div__diff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [M: B,C2: B,A3: B,B2: B] :
          aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),aTP_Lamp_hg(B,fun(B,fun(B,B)),M),C2)),set_or1337092689740270186AtMost(B,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(B,A3,B2) = bot_bot(set(B)),
            bot_bot(set(B)),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),M),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),M)),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),M)),C2)),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),M)),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),M)),C2))) ) ) ).

% image_affinity_atLeastAtMost_div_diff
tff(fact_2088_image__affinity__atLeastAtMost__div,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [M: B,C2: B,A3: B,B2: B] :
          aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),aTP_Lamp_hh(B,fun(B,fun(B,B)),M),C2)),set_or1337092689740270186AtMost(B,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(B,A3,B2) = bot_bot(set(B)),
            bot_bot(set(B)),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),M),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),M)),C2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),M)),C2)),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),M)),C2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),M)),C2))) ) ) ).

% image_affinity_atLeastAtMost_div
tff(fact_2089_image__affinity__atLeastAtMost__diff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [M: B,C2: B,A3: B,B2: B] :
          aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),aTP_Lamp_hi(B,fun(B,fun(B,B)),M),C2)),set_or1337092689740270186AtMost(B,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(B,A3,B2) = bot_bot(set(B)),
            bot_bot(set(B)),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),M),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),A3)),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),B2)),C2)),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),B2)),C2),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),A3)),C2))) ) ) ).

% image_affinity_atLeastAtMost_diff
tff(fact_2090_id__apply,axiom,
    ! [B: $tType,X2: B] : aa(B,B,id(B),X2) = X2 ).

% id_apply
tff(fact_2091_bijective__Empty,axiom,
    ! [C: $tType,B: $tType] : bijective(B,C,bot_bot(set(product_prod(B,C)))) ).

% bijective_Empty
tff(fact_2092_image__id,axiom,
    ! [B: $tType] : image2(B,B,id(B)) = id(set(B)) ).

% image_id
tff(fact_2093_fun_Omap__id,axiom,
    ! [C: $tType,B: $tType,T2: fun(B,C)] : aa(fun(B,C),fun(B,C),aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),id(C)),T2) = T2 ).

% fun.map_id
tff(fact_2094_id__comp,axiom,
    ! [C: $tType,B: $tType,G: fun(B,C)] : aa(fun(B,C),fun(B,C),aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),id(C)),G) = G ).

% id_comp
tff(fact_2095_comp__id,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] : aa(fun(B,B),fun(B,C),aa(fun(B,C),fun(fun(B,B),fun(B,C)),comp(B,C,B),F),id(B)) = F ).

% comp_id
tff(fact_2096_lessThan__0,axiom,
    aa(nat,set(nat),set_ord_lessThan(nat),zero_zero(nat)) = bot_bot(set(nat)) ).

% lessThan_0
tff(fact_2097_apsnd__id,axiom,
    ! [C: $tType,B: $tType] : aa(fun(C,C),fun(product_prod(B,C),product_prod(B,C)),product_apsnd(C,C,B),id(C)) = id(product_prod(B,C)) ).

% apsnd_id
tff(fact_2098_map__mmupd__empty,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),V: C] : map_mmupd(B,C,M,bot_bot(set(B)),V) = M ).

% map_mmupd_empty
tff(fact_2099_set__to__map__empty,axiom,
    ! [B: $tType,C: $tType,X: B] : aa(B,option(C),set_to_map(B,C,bot_bot(set(product_prod(B,C)))),X) = none(C) ).

% set_to_map_empty
tff(fact_2100_atLeastatMost__empty__iff2,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B] :
          ( ( bot_bot(set(B)) = set_or1337092689740270186AtMost(B,A3,B2) )
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% atLeastatMost_empty_iff2
tff(fact_2101_atLeastatMost__empty__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B] :
          ( ( set_or1337092689740270186AtMost(B,A3,B2) = bot_bot(set(B)) )
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),B2) ) ) ).

% atLeastatMost_empty_iff
tff(fact_2102_atLeastatMost__empty,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3)
         => ( set_or1337092689740270186AtMost(B,A3,B2) = bot_bot(set(B)) ) ) ) ).

% atLeastatMost_empty
tff(fact_2103_atLeastLessThan__empty,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
         => ( set_or7035219750837199246ssThan(B,A3,B2) = bot_bot(set(B)) ) ) ) ).

% atLeastLessThan_empty
tff(fact_2104_atLeastLessThan__empty__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B] :
          ( ( set_or7035219750837199246ssThan(B,A3,B2) = bot_bot(set(B)) )
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% atLeastLessThan_empty_iff
tff(fact_2105_atLeastLessThan__empty__iff2,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B,B2: B] :
          ( ( bot_bot(set(B)) = set_or7035219750837199246ssThan(B,A3,B2) )
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% atLeastLessThan_empty_iff2
tff(fact_2106_prod_Oempty,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(C,B)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),G),bot_bot(set(C))) = one_one(B) ) ).

% prod.empty
tff(fact_2107_group__add__class_Ominus__comp__minus,axiom,
    ! [B: $tType] :
      ( group_add(B)
     => ( aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),uminus_uminus(B)),uminus_uminus(B)) = id(B) ) ) ).

% group_add_class.minus_comp_minus
tff(fact_2108_boolean__algebra__class_Ominus__comp__minus,axiom,
    ! [B: $tType] :
      ( boolea8198339166811842893lgebra(B)
     => ( aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),uminus_uminus(B)),uminus_uminus(B)) = id(B) ) ) ).

% boolean_algebra_class.minus_comp_minus
tff(fact_2109_rel__of__empty,axiom,
    ! [C: $tType,B: $tType,P: fun(product_prod(B,C),$o)] : rel_of(B,C,aTP_Lamp_hj(B,option(C)),P) = bot_bot(set(product_prod(B,C))) ).

% rel_of_empty
tff(fact_2110_comp__the__Some,axiom,
    ! [B: $tType] : aa(fun(B,option(B)),fun(B,B),aa(fun(option(B),B),fun(fun(B,option(B)),fun(B,B)),comp(option(B),B,B),the2(B)),some(B)) = id(B) ).

% comp_the_Some
tff(fact_2111_fun_Omap__id0,axiom,
    ! [C: $tType,B: $tType] : aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),id(C)) = id(fun(B,C)) ).

% fun.map_id0
tff(fact_2112_Iio__eq__empty__iff,axiom,
    ! [B: $tType] :
      ( ( linorder(B)
        & order_bot(B) )
     => ! [N: B] :
          ( ( aa(B,set(B),set_ord_lessThan(B),N) = bot_bot(set(B)) )
        <=> ( N = bot_bot(B) ) ) ) ).

% Iio_eq_empty_iff
tff(fact_2113_option_Omap__id0,axiom,
    ! [B: $tType] : aa(fun(B,B),fun(option(B),option(B)),map_option(B,B),id(B)) = id(option(B)) ).

% option.map_id0
tff(fact_2114_set__notEmptyE,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( S2 != bot_bot(set(B)) )
     => ~ ! [X3: B] : ~ member(B,X3,S2) ) ).

% set_notEmptyE
tff(fact_2115_memb__imp__not__empty,axiom,
    ! [B: $tType,X2: B,S2: set(B)] :
      ( member(B,X2,S2)
     => ( S2 != bot_bot(set(B)) ) ) ).

% memb_imp_not_empty
tff(fact_2116_id__def,axiom,
    ! [B: $tType,X: B] : aa(B,B,id(B),X) = X ).

% id_def
tff(fact_2117_eq__id__iff,axiom,
    ! [B: $tType,F: fun(B,B)] :
      ( ! [X4: B] : aa(B,B,F,X4) = X4
    <=> ( F = id(B) ) ) ).

% eq_id_iff
tff(fact_2118_comp__eq__id__dest,axiom,
    ! [D: $tType,C: $tType,B: $tType,A3: fun(D,C),B2: fun(B,D),C2: fun(B,C),V: B] :
      ( ( aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),A3),B2) = aa(fun(B,C),fun(B,C),aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),id(C)),C2) )
     => ( aa(D,C,A3,aa(B,D,B2,V)) = aa(B,C,C2,V) ) ) ).

% comp_eq_id_dest
tff(fact_2119_pointfree__idE,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),G: fun(B,C),X2: B] :
      ( ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),F),G) = id(B) )
     => ( aa(C,B,F,aa(B,C,G,X2)) = X2 ) ) ).

% pointfree_idE
tff(fact_2120_option_Omap__id,axiom,
    ! [B: $tType,T2: option(B)] : aa(option(B),option(B),aa(fun(B,B),fun(option(B),option(B)),map_option(B,B),id(B)),T2) = T2 ).

% option.map_id
tff(fact_2121_not__empty__eq__Iic__eq__empty,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [Ha: B] : bot_bot(set(B)) != aa(B,set(B),set_ord_atMost(B),Ha) ) ).

% not_empty_eq_Iic_eq_empty
tff(fact_2122_lessThan__non__empty,axiom,
    ! [B: $tType] :
      ( no_bot(B)
     => ! [X2: B] : aa(B,set(B),set_ord_lessThan(B),X2) != bot_bot(set(B)) ) ).

% lessThan_non_empty
tff(fact_2123_subset__minus__empty,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
     => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5) = bot_bot(set(B)) ) ) ).

% subset_minus_empty
tff(fact_2124_atLeastLessThan0,axiom,
    ! [M: nat] : set_or7035219750837199246ssThan(nat,M,zero_zero(nat)) = bot_bot(set(nat)) ).

% atLeastLessThan0
tff(fact_2125_lessThan__empty__iff,axiom,
    ! [N: nat] :
      ( ( aa(nat,set(nat),set_ord_lessThan(nat),N) = bot_bot(set(nat)) )
    <=> ( N = zero_zero(nat) ) ) ).

% lessThan_empty_iff
tff(fact_2126_set__to__map__empty__iff_I1_J,axiom,
    ! [C: $tType,B: $tType,S2: set(product_prod(B,C))] :
      ( ! [X4: B] : aa(B,option(C),set_to_map(B,C,S2),X4) = none(C)
    <=> ( S2 = bot_bot(set(product_prod(B,C))) ) ) ).

% set_to_map_empty_iff(1)
tff(fact_2127_Code__Numeral_Osub__code_I1_J,axiom,
    aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,one2),one2) = zero_zero(code_integer) ).

% Code_Numeral.sub_code(1)
tff(fact_2128_set__to__map__empty__iff_I2_J,axiom,
    ! [C: $tType,B: $tType,S2: set(product_prod(B,C))] :
      ( ( aTP_Lamp_hj(B,option(C)) = set_to_map(B,C,S2) )
    <=> ( S2 = bot_bot(set(product_prod(B,C))) ) ) ).

% set_to_map_empty_iff(2)
tff(fact_2129_less__integer__def,axiom,
    ord_less(code_integer) = aa(fun(int,fun(int,$o)),fun(code_integer,fun(code_integer,$o)),map_fun(code_integer,int,fun(int,$o),fun(code_integer,$o),code_int_of_integer,map_fun(code_integer,int,$o,$o,code_int_of_integer,id($o))),ord_less(int)) ).

% less_integer_def
tff(fact_2130_less__eq__integer__def,axiom,
    ord_less_eq(code_integer) = aa(fun(int,fun(int,$o)),fun(code_integer,fun(code_integer,$o)),map_fun(code_integer,int,fun(int,$o),fun(code_integer,$o),code_int_of_integer,map_fun(code_integer,int,$o,$o,code_int_of_integer,id($o))),ord_less_eq(int)) ).

% less_eq_integer_def
tff(fact_2131_Code__Numeral_Osub__code_I6_J,axiom,
    ! [M: num,N: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,aa(num,num,bit0,M)),aa(num,num,bit0,N)) = aa(code_integer,code_integer,code_dup,aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,M),N)) ).

% Code_Numeral.sub_code(6)
tff(fact_2132_Code__Numeral_Osub__code_I7_J,axiom,
    ! [M: num,N: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,aa(num,num,bit1,M)),aa(num,num,bit1,N)) = aa(code_integer,code_integer,code_dup,aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,M),N)) ).

% Code_Numeral.sub_code(7)
tff(fact_2133_sub_Orep__eq,axiom,
    ! [X2: num,Xa: num] : aa(code_integer,int,code_int_of_integer,aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,X2),Xa)) = aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(num,int,numeral_numeral(int),X2)),aa(num,int,numeral_numeral(int),Xa)) ).

% sub.rep_eq
tff(fact_2134_sub_Oabs__eq,axiom,
    ! [Xa: num,X2: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,Xa),X2) = aa(int,code_integer,code_integer_of_int,aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(num,int,numeral_numeral(int),Xa)),aa(num,int,numeral_numeral(int),X2))) ).

% sub.abs_eq
tff(fact_2135_image__mult__atLeastAtMost__if,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [C2: B,X2: B,Y: B] :
          aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),times_times(B),C2)),set_or1337092689740270186AtMost(B,X2,Y)) = $ite(
            aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),C2),
            set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),times_times(B),C2),X2),aa(B,B,aa(B,fun(B,B),times_times(B),C2),Y)),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),times_times(B),C2),Y),aa(B,B,aa(B,fun(B,B),times_times(B),C2),X2)),bot_bot(set(B))) ) ) ).

% image_mult_atLeastAtMost_if
tff(fact_2136_image__mult__atLeastAtMost__if_H,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [C2: B,X2: B,Y: B] :
          aa(set(B),set(B),image2(B,B,aTP_Lamp_hk(B,fun(B,B),C2)),set_or1337092689740270186AtMost(B,X2,Y)) = $ite(
            aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),C2),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),times_times(B),X2),C2),aa(B,B,aa(B,fun(B,B),times_times(B),Y),C2)),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),times_times(B),Y),C2),aa(B,B,aa(B,fun(B,B),times_times(B),X2),C2))),
            bot_bot(set(B)) ) ) ).

% image_mult_atLeastAtMost_if'
tff(fact_2137_image__affinity__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [M: B,C2: B,A3: B,B2: B] :
          aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),aTP_Lamp_hl(B,fun(B,fun(B,B)),M),C2)),set_or1337092689740270186AtMost(B,A3,B2)) = $ite(
            set_or1337092689740270186AtMost(B,A3,B2) = bot_bot(set(B)),
            bot_bot(set(B)),
            $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),M),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),A3)),C2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),B2)),C2)),set_or1337092689740270186AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),B2)),C2),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),M),A3)),C2))) ) ) ).

% image_affinity_atLeastAtMost
tff(fact_2138_and__int_Osimps,axiom,
    ! [K: int,L: int] :
      aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),K),L) = $ite(
        ( member(int,K,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int)))))
        & member(int,L,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int))))) ),
        aa(int,int,uminus_uminus(int),
          aa($o,int,zero_neq_one_of_bool(int),
            ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K)
            & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L) ))),
        aa(int,int,
          aa(int,fun(int,int),plus_plus(int),
            aa($o,int,zero_neq_one_of_bool(int),
              ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K)
              & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L) ))),
          aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ) ).

% and_int.simps
tff(fact_2139_and__int_Oelims,axiom,
    ! [X2: int,Xa: int,Y: int] :
      ( ( aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),X2),Xa) = Y )
     => ( Y = $ite(
            ( member(int,X2,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int)))))
            & member(int,Xa,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int))))) ),
            aa(int,int,uminus_uminus(int),
              aa($o,int,zero_neq_one_of_bool(int),
                ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),X2)
                & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),Xa) ))),
            aa(int,int,
              aa(int,fun(int,int),plus_plus(int),
                aa($o,int,zero_neq_one_of_bool(int),
                  ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),X2)
                  & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),Xa) ))),
              aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),X2),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),Xa),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ) ) ) ).

% and_int.elims
tff(fact_2140_and__int_Opelims,axiom,
    ! [X2: int,Xa: int,Y: int] :
      ( ( aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),X2),Xa) = Y )
     => ( aa(product_prod(int,int),$o,accp(product_prod(int,int),bit_and_int_rel),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),X2),Xa))
       => ~ ( ( Y = $ite(
                  ( member(int,X2,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int)))))
                  & member(int,Xa,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int))))) ),
                  aa(int,int,uminus_uminus(int),
                    aa($o,int,zero_neq_one_of_bool(int),
                      ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),X2)
                      & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),Xa) ))),
                  aa(int,int,
                    aa(int,fun(int,int),plus_plus(int),
                      aa($o,int,zero_neq_one_of_bool(int),
                        ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),X2)
                        & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),Xa) ))),
                    aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),X2),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),Xa),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ) )
           => ~ aa(product_prod(int,int),$o,accp(product_prod(int,int),bit_and_int_rel),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),X2),Xa)) ) ) ) ).

% and_int.pelims
tff(fact_2141_and__int_Opsimps,axiom,
    ! [K: int,L: int] :
      ( aa(product_prod(int,int),$o,accp(product_prod(int,int),bit_and_int_rel),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),K),L))
     => ( aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),K),L) = $ite(
            ( member(int,K,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int)))))
            & member(int,L,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int))))) ),
            aa(int,int,uminus_uminus(int),
              aa($o,int,zero_neq_one_of_bool(int),
                ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K)
                & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L) ))),
            aa(int,int,
              aa(int,fun(int,int),plus_plus(int),
                aa($o,int,zero_neq_one_of_bool(int),
                  ( ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),K)
                  & ~ dvd_dvd(int,aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)),L) ))),
              aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(int,int,aa(int,fun(int,int),bit_se5824344872417868541ns_and(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),K),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))))) ) ) ) ).

% and_int.psimps
tff(fact_2142_and__int_Opinduct,axiom,
    ! [A0: int,A1: int,P: fun(int,fun(int,$o))] :
      ( aa(product_prod(int,int),$o,accp(product_prod(int,int),bit_and_int_rel),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A0),A1))
     => ( ! [K3: int,L5: int] :
            ( aa(product_prod(int,int),$o,accp(product_prod(int,int),bit_and_int_rel),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),K3),L5))
           => ( ( ~ ( member(int,K3,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int)))))
                    & member(int,L5,aa(set(int),set(int),insert2(int,zero_zero(int)),aa(set(int),set(int),insert2(int,aa(int,int,uminus_uminus(int),one_one(int))),bot_bot(set(int))))) )
               => aa(int,$o,aa(int,fun(int,$o),P,aa(int,int,aa(int,fun(int,int),divide_divide(int),K3),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))),aa(int,int,aa(int,fun(int,int),divide_divide(int),L5),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2)))) )
             => aa(int,$o,aa(int,fun(int,$o),P,K3),L5) ) )
       => aa(int,$o,aa(int,fun(int,$o),P,A0),A1) ) ) ).

% and_int.pinduct
tff(fact_2143_mask__mod__exp,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [N: nat,M: nat] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)),one_one(B))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),aa(nat,nat,ord_min(nat,M),N))),one_one(B)) ) ).

% mask_mod_exp
tff(fact_2144_pair__leqI2,axiom,
    ! [A3: nat,B2: nat,S: nat,T2: 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_eq(nat),S),T2)
       => member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),A3),S)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),B2),T2)),fun_pair_leq) ) ) ).

% pair_leqI2
tff(fact_2145_min__eq__arg_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [M: B,N: B] :
          ( ( aa(B,B,ord_min(B,M),N) = M )
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),N) ) ) ).

% min_eq_arg(1)
tff(fact_2146_min__eq__arg_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [M: B,N: B] :
          ( ( aa(B,B,ord_min(B,M),N) = N )
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),N),M) ) ) ).

% min_eq_arg(2)
tff(fact_2147_min__arg__le_I1_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [N: B,M: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),N),aa(B,B,ord_min(B,M),N))
        <=> ( aa(B,B,ord_min(B,M),N) = N ) ) ) ).

% min_arg_le(1)
tff(fact_2148_min__arg__le_I2_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [M: B,N: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),aa(B,B,ord_min(B,M),N))
        <=> ( aa(B,B,ord_min(B,M),N) = M ) ) ) ).

% min_arg_le(2)
tff(fact_2149_min__arg__not__ge_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [M: B,N: B] :
          ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,ord_min(B,M),N)),M)
        <=> ( aa(B,B,ord_min(B,M),N) = M ) ) ) ).

% min_arg_not_ge(1)
tff(fact_2150_min__arg__not__ge_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [M: B,N: B] :
          ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,ord_min(B,M),N)),N)
        <=> ( aa(B,B,ord_min(B,M),N) = N ) ) ) ).

% min_arg_not_ge(2)
tff(fact_2151_min__less__self__conv_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,ord_min(B,A3),B2)),A3)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ).

% min_less_self_conv(1)
tff(fact_2152_min__less__self__conv_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,ord_min(B,A3),B2)),B2)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% min_less_self_conv(2)
tff(fact_2153_min__simps_I1_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ( aa(B,B,ord_min(B,A3),B2) = A3 ) ) ) ).

% min_simps(1)
tff(fact_2154_min__simps_I2_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [B2: B,A3: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3)
         => ( aa(B,B,ord_min(B,A3),B2) = B2 ) ) ) ).

% min_simps(2)
tff(fact_2155_min__0__1_I2_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ( aa(B,B,ord_min(B,one_one(B)),zero_zero(B)) = zero_zero(B) ) ) ).

% min_0_1(2)
tff(fact_2156_min__0__1_I1_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ( aa(B,B,ord_min(B,zero_zero(B)),one_one(B)) = zero_zero(B) ) ) ).

% min_0_1(1)
tff(fact_2157_min__0__1_I5_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [X2: num] : aa(B,B,ord_min(B,one_one(B)),aa(num,B,numeral_numeral(B),X2)) = one_one(B) ) ).

% min_0_1(5)
tff(fact_2158_min__0__1_I6_J,axiom,
    ! [B: $tType] :
      ( linord181362715937106298miring(B)
     => ! [X2: num] : aa(B,B,ord_min(B,aa(num,B,numeral_numeral(B),X2)),one_one(B)) = one_one(B) ) ).

% min_0_1(6)
tff(fact_2159_atLeastAtMost__singleton__iff,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [A3: B,B2: B,C2: B] :
          ( ( set_or1337092689740270186AtMost(B,A3,B2) = aa(set(B),set(B),insert2(B,C2),bot_bot(set(B))) )
        <=> ( ( A3 = B2 )
            & ( B2 = C2 ) ) ) ) ).

% atLeastAtMost_singleton_iff
tff(fact_2160_atLeastAtMost__singleton,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [A3: B] : set_or1337092689740270186AtMost(B,A3,A3) = aa(set(B),set(B),insert2(B,A3),bot_bot(set(B))) ) ).

% atLeastAtMost_singleton
tff(fact_2161_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,ord_min(nat,B2),aa(nat,nat,suc,A3)) = aa(nat,nat,suc,A3) ) ) ).

% min_Suc_gt(2)
tff(fact_2162_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,ord_min(nat,aa(nat,nat,suc,A3)),B2) = aa(nat,nat,suc,A3) ) ) ).

% min_Suc_gt(1)
tff(fact_2163_case__prod__Pair,axiom,
    ! [C: $tType,B: $tType] : aa(fun(B,fun(C,product_prod(B,C))),fun(product_prod(B,C),product_prod(B,C)),product_case_prod(B,C,product_prod(B,C)),product_Pair(B,C)) = id(product_prod(B,C)) ).

% case_prod_Pair
tff(fact_2164_single__Diff__lessThan,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [K: B] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),aa(set(B),set(B),insert2(B,K),bot_bot(set(B)))),aa(B,set(B),set_ord_lessThan(B),K)) = aa(set(B),set(B),insert2(B,K),bot_bot(set(B))) ) ).

% single_Diff_lessThan
tff(fact_2165_min__add__distrib__right,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [X2: B,Y: B,Z2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(B,B,ord_min(B,Y),Z2)) = aa(B,B,ord_min(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Y)),aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Z2)) ) ).

% min_add_distrib_right
tff(fact_2166_min__add__distrib__left,axiom,
    ! [B: $tType] :
      ( ordere2412721322843649153imp_le(B)
     => ! [X2: B,Y: B,Z2: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,ord_min(B,X2),Y)),Z2) = aa(B,B,ord_min(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),Z2)),aa(B,B,aa(B,fun(B,B),plus_plus(B),Y),Z2)) ) ).

% min_add_distrib_left
tff(fact_2167_min__diff__distrib__left,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B,Y: B,Z2: B] : aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,ord_min(B,X2),Y)),Z2) = aa(B,B,ord_min(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),X2),Z2)),aa(B,B,aa(B,fun(B,B),minus_minus(B),Y),Z2)) ) ).

% min_diff_distrib_left
tff(fact_2168_bot__option__def,axiom,
    ! [B: $tType] :
      ( order(B)
     => ( bot_bot(option(B)) = none(B) ) ) ).

% bot_option_def
tff(fact_2169_bot__empty__eq2,axiom,
    ! [C: $tType,B: $tType,X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),bot_bot(fun(B,fun(C,$o))),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),bot_bot(set(product_prod(B,C)))) ) ).

% bot_empty_eq2
tff(fact_2170_map__fun_Oidentity,axiom,
    ! [C: $tType,B: $tType] : map_fun(B,B,C,C,aTP_Lamp_ay(B,B),aTP_Lamp_ae(C,C)) = id(fun(B,C)) ).

% map_fun.identity
tff(fact_2171_map__option_Oidentity,axiom,
    ! [B: $tType] : aa(fun(B,B),fun(option(B),option(B)),map_option(B,B),aTP_Lamp_ay(B,B)) = id(option(B)) ).

% map_option.identity
tff(fact_2172_minus__max__eq__min,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [X2: B,Y: B] : aa(B,B,uminus_uminus(B),aa(B,B,ord_max(B,X2),Y)) = aa(B,B,ord_min(B,aa(B,B,uminus_uminus(B),X2)),aa(B,B,uminus_uminus(B),Y)) ) ).

% minus_max_eq_min
tff(fact_2173_minus__min__eq__max,axiom,
    ! [B: $tType] :
      ( linord5086331880401160121up_add(B)
     => ! [X2: B,Y: B] : aa(B,B,uminus_uminus(B),aa(B,B,ord_min(B,X2),Y)) = aa(B,B,ord_max(B,aa(B,B,uminus_uminus(B),X2)),aa(B,B,uminus_uminus(B),Y)) ) ).

% minus_min_eq_max
tff(fact_2174_insert__minus__eq,axiom,
    ! [B: $tType,X2: B,Y: B,A4: set(B)] :
      ( ( X2 != Y )
     => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),aa(set(B),set(B),insert2(B,X2),A4)),aa(set(B),set(B),insert2(B,Y),bot_bot(set(B)))) = aa(set(B),set(B),insert2(B,X2),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,Y),bot_bot(set(B))))) ) ) ).

% insert_minus_eq
tff(fact_2175_set__minus__singleton__eq,axiom,
    ! [B: $tType,X2: B,X7: set(B)] :
      ( ~ member(B,X2,X7)
     => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),X7),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))) = X7 ) ) ).

% set_minus_singleton_eq
tff(fact_2176_atLeastAtMost__singleton_H,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [A3: B,B2: B] :
          ( ( A3 = B2 )
         => ( set_or1337092689740270186AtMost(B,A3,B2) = aa(set(B),set(B),insert2(B,A3),bot_bot(set(B))) ) ) ) ).

% atLeastAtMost_singleton'
tff(fact_2177_remove__subset,axiom,
    ! [B: $tType,X2: B,S2: set(B)] :
      ( member(B,X2,S2)
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))),S2) ) ).

% remove_subset
tff(fact_2178_nat__of__integer__def,axiom,
    code_nat_of_integer = aa(fun(int,nat),fun(code_integer,nat),map_fun(code_integer,int,nat,nat,code_int_of_integer,id(nat)),nat2) ).

% nat_of_integer_def
tff(fact_2179_bit__integer__def,axiom,
    bit_se5641148757651400278ts_bit(code_integer) = aa(fun(int,fun(nat,$o)),fun(code_integer,fun(nat,$o)),map_fun(code_integer,int,fun(nat,$o),fun(nat,$o),code_int_of_integer,id(fun(nat,$o))),bit_se5641148757651400278ts_bit(int)) ).

% bit_integer_def
tff(fact_2180_mask__integer__def,axiom,
    bit_se2239418461657761734s_mask(code_integer) = aa(fun(nat,int),fun(nat,code_integer),map_fun(nat,nat,int,code_integer,id(nat),code_integer_of_int),bit_se2239418461657761734s_mask(int)) ).

% mask_integer_def
tff(fact_2181_atLeastLessThan__eq__atLeastAtMost__diff,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [A3: B,B2: B] : set_or7035219750837199246ssThan(B,A3,B2) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),set_or1337092689740270186AtMost(B,A3,B2)),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))) ) ).

% atLeastLessThan_eq_atLeastAtMost_diff
tff(fact_2182_atLeastAtMostPlus1__int__conv,axiom,
    ! [M: int,N: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),M),aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),N))
     => ( set_or1337092689740270186AtMost(int,M,aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),N)) = aa(set(int),set(int),insert2(int,aa(int,int,aa(int,fun(int,int),plus_plus(int),one_one(int)),N)),set_or1337092689740270186AtMost(int,M,N)) ) ) ).

% atLeastAtMostPlus1_int_conv
tff(fact_2183_simp__from__to,axiom,
    ! [I: int,J: int] :
      set_or1337092689740270186AtMost(int,I,J) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less(int),J),I),bot_bot(set(int)),aa(set(int),set(int),insert2(int,I),set_or1337092689740270186AtMost(int,aa(int,int,aa(int,fun(int,int),plus_plus(int),I),one_one(int)),J))) ).

% simp_from_to
tff(fact_2184_Code__Numeral_Osub__def,axiom,
    code_sub = aa(fun(num,fun(num,int)),fun(num,fun(num,code_integer)),map_fun(num,num,fun(num,int),fun(num,code_integer),id(num),map_fun(num,num,int,code_integer,id(num),code_integer_of_int)),aTP_Lamp_hm(num,fun(num,int))) ).

% Code_Numeral.sub_def
tff(fact_2185_num__of__integer__def,axiom,
    code_num_of_integer = aa(fun(int,num),fun(code_integer,num),map_fun(code_integer,int,num,num,code_int_of_integer,id(num)),aa(fun(int,nat),fun(int,num),aa(fun(nat,num),fun(fun(int,nat),fun(int,num)),comp(nat,num,int),num_of_nat),nat2)) ).

% num_of_integer_def
tff(fact_2186_take__bit__integer__def,axiom,
    bit_se2584673776208193580ke_bit(code_integer) = aa(fun(nat,fun(int,int)),fun(nat,fun(code_integer,code_integer)),map_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),id(nat),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se2584673776208193580ke_bit(int)) ).

% take_bit_integer_def
tff(fact_2187_drop__bit__integer__def,axiom,
    bit_se4197421643247451524op_bit(code_integer) = aa(fun(nat,fun(int,int)),fun(nat,fun(code_integer,code_integer)),map_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),id(nat),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se4197421643247451524op_bit(int)) ).

% drop_bit_integer_def
tff(fact_2188_push__bit__integer__def,axiom,
    bit_se4730199178511100633sh_bit(code_integer) = aa(fun(nat,fun(int,int)),fun(nat,fun(code_integer,code_integer)),map_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),id(nat),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se4730199178511100633sh_bit(int)) ).

% push_bit_integer_def
tff(fact_2189_unset__bit__integer__def,axiom,
    bit_se2638667681897837118et_bit(code_integer) = aa(fun(nat,fun(int,int)),fun(nat,fun(code_integer,code_integer)),map_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),id(nat),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se2638667681897837118et_bit(int)) ).

% unset_bit_integer_def
tff(fact_2190_set__bit__integer__def,axiom,
    bit_se5668285175392031749et_bit(code_integer) = aa(fun(nat,fun(int,int)),fun(nat,fun(code_integer,code_integer)),map_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),id(nat),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se5668285175392031749et_bit(int)) ).

% set_bit_integer_def
tff(fact_2191_flip__bit__integer__def,axiom,
    bit_se8732182000553998342ip_bit(code_integer) = aa(fun(nat,fun(int,int)),fun(nat,fun(code_integer,code_integer)),map_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),id(nat),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int)),bit_se8732182000553998342ip_bit(int)) ).

% flip_bit_integer_def
tff(fact_2192_pair__leqI1,axiom,
    ! [A3: nat,B2: nat,S: nat,T2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),A3),B2)
     => member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),A3),S)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),B2),T2)),fun_pair_leq) ) ).

% pair_leqI1
tff(fact_2193_image__minus__const__atLeastLessThan__nat,axiom,
    ! [C2: nat,X2: nat,Y: nat] :
      aa(set(nat),set(nat),image2(nat,nat,aTP_Lamp_hn(nat,fun(nat,nat),C2)),set_or7035219750837199246ssThan(nat,X2,Y)) = $ite(
        aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),C2),Y),
        set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),X2),C2),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Y),C2)),
        $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),Y),aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),bot_bot(set(nat))),bot_bot(set(nat))) ) ).

% image_minus_const_atLeastLessThan_nat
tff(fact_2194_card__atLeastAtMost__int,axiom,
    ! [L: int,U: int] : finite_card(int,set_or1337092689740270186AtMost(int,L,U)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),U),L)),one_one(int))) ).

% card_atLeastAtMost_int
tff(fact_2195_range__mod,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(set(nat),set(nat),image2(nat,nat,aTP_Lamp_ho(nat,fun(nat,nat),N)),top_top(set(nat))) = set_or7035219750837199246ssThan(nat,zero_zero(nat),N) ) ) ).

% range_mod
tff(fact_2196_Some__image__these__eq,axiom,
    ! [B: $tType,A4: set(option(B))] : aa(set(B),set(option(B)),image2(B,option(B),some(B)),these(B,A4)) = aa(fun(option(B),$o),set(option(B)),collect(option(B)),aTP_Lamp_hp(set(option(B)),fun(option(B),$o),A4)) ).

% Some_image_these_eq
tff(fact_2197_prod__mono2,axiom,
    ! [C: $tType,B: $tType] :
      ( linordered_idom(C)
     => ! [B5: set(B),A4: set(B),F: fun(B,C)] :
          ( finite_finite2(B,B5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
           => ( ! [B3: B] :
                  ( member(B,B3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),B5),A4))
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(B,C,F,B3)) )
             => ( ! [A5: B] :
                    ( member(B,A5,A4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(B,C,F,A5)) )
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),A4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),B5)) ) ) ) ) ) ).

% prod_mono2
tff(fact_2198_the__dflt__None__nonempty,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( S2 != bot_bot(set(B)) )
     => ( dflt_None_set(B,S2) = aa(set(B),option(set(B)),some(set(B)),S2) ) ) ).

% the_dflt_None_nonempty
tff(fact_2199_the__dflt__None__empty,axiom,
    ! [B: $tType] : dflt_None_set(B,bot_bot(set(B))) = none(set(B)) ).

% the_dflt_None_empty
tff(fact_2200_atMost__UNIV__triv,axiom,
    ! [B: $tType] : aa(set(B),set(set(B)),set_ord_atMost(set(B)),top_top(set(B))) = top_top(set(set(B))) ).

% atMost_UNIV_triv
tff(fact_2201_finite__atLeastAtMost,axiom,
    ! [L: nat,U: nat] : finite_finite2(nat,set_or1337092689740270186AtMost(nat,L,U)) ).

% finite_atLeastAtMost
tff(fact_2202_finite__atLeastLessThan,axiom,
    ! [L: nat,U: nat] : finite_finite2(nat,set_or7035219750837199246ssThan(nat,L,U)) ).

% finite_atLeastLessThan
tff(fact_2203_int__of__integer__min,axiom,
    ! [K: code_integer,L: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,ord_min(code_integer,K),L)) = aa(int,int,ord_min(int,aa(code_integer,int,code_int_of_integer,K)),aa(code_integer,int,code_int_of_integer,L)) ).

% int_of_integer_min
tff(fact_2204_finite__atMost,axiom,
    ! [K: nat] : finite_finite2(nat,aa(nat,set(nat),set_ord_atMost(nat),K)) ).

% finite_atMost
tff(fact_2205_finite__lessThan,axiom,
    ! [K: nat] : finite_finite2(nat,aa(nat,set(nat),set_ord_lessThan(nat),K)) ).

% finite_lessThan
tff(fact_2206_finite__atLeastAtMost__int,axiom,
    ! [L: int,U: int] : finite_finite2(int,set_or1337092689740270186AtMost(int,L,U)) ).

% finite_atLeastAtMost_int
tff(fact_2207_finite__atLeastLessThan__int,axiom,
    ! [L: int,U: int] : finite_finite2(int,set_or7035219750837199246ssThan(int,L,U)) ).

% finite_atLeastLessThan_int
tff(fact_2208_finite__atLeastLessThan__integer,axiom,
    ! [L: code_integer,U: code_integer] : finite_finite2(code_integer,set_or7035219750837199246ssThan(code_integer,L,U)) ).

% finite_atLeastLessThan_integer
tff(fact_2209_finite__atLeastAtMost__integer,axiom,
    ! [L: code_integer,U: code_integer] : finite_finite2(code_integer,set_or1337092689740270186AtMost(code_integer,L,U)) ).

% finite_atLeastAtMost_integer
tff(fact_2210_finite__option__UNIV,axiom,
    ! [B: $tType] :
      ( finite_finite2(option(B),top_top(set(option(B))))
    <=> finite_finite2(B,top_top(set(B))) ) ).

% finite_option_UNIV
tff(fact_2211_card__eq__UNIV,axiom,
    ! [B: $tType] :
      ( finite_finite(B)
     => ! [S2: set(B)] :
          ( ( finite_card(B,S2) = finite_card(B,top_top(set(B))) )
        <=> ( S2 = top_top(set(B)) ) ) ) ).

% card_eq_UNIV
tff(fact_2212_card__eq__UNIV2,axiom,
    ! [B: $tType] :
      ( finite_finite(B)
     => ! [S2: set(B)] :
          ( ( finite_card(B,top_top(set(B))) = finite_card(B,S2) )
        <=> ( S2 = top_top(set(B)) ) ) ) ).

% card_eq_UNIV2
tff(fact_2213_these__empty,axiom,
    ! [B: $tType] : these(B,bot_bot(set(option(B)))) = bot_bot(set(B)) ).

% these_empty
tff(fact_2214_these__insert__None,axiom,
    ! [B: $tType,A4: set(option(B))] : these(B,aa(set(option(B)),set(option(B)),insert2(option(B),none(B)),A4)) = these(B,A4) ).

% these_insert_None
tff(fact_2215_the__dflt__None__set,axiom,
    ! [B: $tType,X2: set(B)] : the_default(set(B),bot_bot(set(B)),dflt_None_set(B,X2)) = X2 ).

% the_dflt_None_set
tff(fact_2216_surj__plus,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),top_top(set(B))) = top_top(set(B)) ) ).

% surj_plus
tff(fact_2217_infinite__Icc__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( ~ finite_finite2(B,set_or1337092689740270186AtMost(B,A3,B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% infinite_Icc_iff
tff(fact_2218_infinite__Ico__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( ~ finite_finite2(B,set_or7035219750837199246ssThan(B,A3,B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% infinite_Ico_iff
tff(fact_2219_prod_Oinfinite,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(B),G: fun(B,C)] :
          ( ~ finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),A4) = one_one(C) ) ) ) ).

% prod.infinite
tff(fact_2220_card__ge__UNIV,axiom,
    ! [B: $tType] :
      ( finite_finite(B)
     => ! [S2: set(B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(B,top_top(set(B)))),finite_card(B,S2))
        <=> ( S2 = top_top(set(B)) ) ) ) ).

% card_ge_UNIV
tff(fact_2221_surj__diff__right,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B] : aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),top_top(set(B))) = top_top(set(B)) ) ).

% surj_diff_right
tff(fact_2222_prod__eq__1__iff,axiom,
    ! [B: $tType,A4: set(B),F: fun(B,nat)] :
      ( finite_finite2(B,A4)
     => ( ( aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7121269368397514597t_prod(B,nat),F),A4) = one_one(nat) )
      <=> ! [X4: B] :
            ( member(B,X4,A4)
           => ( aa(B,nat,F,X4) = one_one(nat) ) ) ) ) ).

% prod_eq_1_iff
tff(fact_2223_prod_Odelta,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),A3: B,B2: fun(B,C)] :
          ( finite_finite2(B,S2)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),aa(fun(B,C),fun(B,C),aTP_Lamp_hq(B,fun(fun(B,C),fun(B,C)),A3),B2)),S2) = $ite(member(B,A3,S2),aa(B,C,B2,A3),one_one(C)) ) ) ) ).

% prod.delta
tff(fact_2224_prod_Odelta_H,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),A3: B,B2: fun(B,C)] :
          ( finite_finite2(B,S2)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),aa(fun(B,C),fun(B,C),aTP_Lamp_hr(B,fun(fun(B,C),fun(B,C)),A3),B2)),S2) = $ite(member(B,A3,S2),aa(B,C,B2,A3),one_one(C)) ) ) ) ).

% prod.delta'
tff(fact_2225_these__insert__Some,axiom,
    ! [B: $tType,X2: B,A4: set(option(B))] : these(B,aa(set(option(B)),set(option(B)),insert2(option(B),aa(B,option(B),some(B),X2)),A4)) = aa(set(B),set(B),insert2(B,X2),these(B,A4)) ).

% these_insert_Some
tff(fact_2226_these__image__Some__eq,axiom,
    ! [B: $tType,A4: set(B)] : these(B,aa(set(B),set(option(B)),image2(B,option(B),some(B)),A4)) = A4 ).

% these_image_Some_eq
tff(fact_2227_sum_Oinsert,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),X2: B,G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( ~ member(B,X2,A4)
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),insert2(B,X2),A4)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,G,X2)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4)) ) ) ) ) ).

% sum.insert
tff(fact_2228_atLeastLessThan__singleton,axiom,
    ! [M: nat] : set_or7035219750837199246ssThan(nat,M,aa(nat,nat,suc,M)) = aa(set(nat),set(nat),insert2(nat,M),bot_bot(set(nat))) ).

% atLeastLessThan_singleton
tff(fact_2229_atMost__0,axiom,
    aa(nat,set(nat),set_ord_atMost(nat),zero_zero(nat)) = aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),bot_bot(set(nat))) ).

% atMost_0
tff(fact_2230_card__atLeastLessThan__int,axiom,
    ! [L: int,U: int] : finite_card(int,set_or7035219750837199246ssThan(int,L,U)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),minus_minus(int),U),L)) ).

% card_atLeastLessThan_int
tff(fact_2231_card__doubleton__eq__2__iff,axiom,
    ! [B: $tType,A3: B,B2: B] :
      ( ( finite_card(B,aa(set(B),set(B),insert2(B,A3),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) )
    <=> ( A3 != B2 ) ) ).

% card_doubleton_eq_2_iff
tff(fact_2232_atMost__eq__UNIV__iff,axiom,
    ! [B: $tType] :
      ( order_top(B)
     => ! [X2: B] :
          ( ( aa(B,set(B),set_ord_atMost(B),X2) = top_top(set(B)) )
        <=> ( X2 = top_top(B) ) ) ) ).

% atMost_eq_UNIV_iff
tff(fact_2233_card__le__if__inj__on__rel,axiom,
    ! [C: $tType,B: $tType,B5: set(B),A4: set(C),R: fun(C,fun(B,$o))] :
      ( finite_finite2(B,B5)
     => ( ! [A5: C] :
            ( member(C,A5,A4)
           => ? [B6: B] :
                ( member(B,B6,B5)
                & aa(B,$o,aa(C,fun(B,$o),R,A5),B6) ) )
       => ( ! [A12: C,A23: C,B3: B] :
              ( member(C,A12,A4)
             => ( member(C,A23,A4)
               => ( member(B,B3,B5)
                 => ( aa(B,$o,aa(C,fun(B,$o),R,A12),B3)
                   => ( aa(B,$o,aa(C,fun(B,$o),R,A23),B3)
                     => ( A12 = A23 ) ) ) ) ) )
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(C,A4)),finite_card(B,B5)) ) ) ) ).

% card_le_if_inj_on_rel
tff(fact_2234_top__option__def,axiom,
    ! [B: $tType] :
      ( order_top(B)
     => ( top_top(option(B)) = aa(B,option(B),some(B),top_top(B)) ) ) ).

% top_option_def
tff(fact_2235_finite__if__eq__beyond__finite,axiom,
    ! [B: $tType,S2: set(B),S3: set(B)] :
      ( finite_finite2(B,S2)
     => finite_finite2(set(B),aa(fun(set(B),$o),set(set(B)),collect(set(B)),aa(set(B),fun(set(B),$o),aTP_Lamp_hs(set(B),fun(set(B),fun(set(B),$o)),S2),S3))) ) ).

% finite_if_eq_beyond_finite
tff(fact_2236_finite__range__Some,axiom,
    ! [B: $tType] :
      ( finite_finite2(option(B),aa(set(B),set(option(B)),image2(B,option(B),some(B)),top_top(set(B))))
    <=> finite_finite2(B,top_top(set(B))) ) ).

% finite_range_Some
tff(fact_2237_obtain__subset__with__card__n,axiom,
    ! [B: $tType,N: nat,S2: set(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),finite_card(B,S2))
     => ~ ! [T3: set(B)] :
            ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),T3),S2)
           => ( ( finite_card(B,T3) = N )
             => ~ finite_finite2(B,T3) ) ) ) ).

% obtain_subset_with_card_n
tff(fact_2238_atLeastAtMost__eq__UNIV__iff,axiom,
    ! [B: $tType] :
      ( bounded_lattice(B)
     => ! [X2: B,Y: B] :
          ( ( set_or1337092689740270186AtMost(B,X2,Y) = top_top(set(B)) )
        <=> ( ( X2 = bot_bot(B) )
            & ( Y = top_top(B) ) ) ) ) ).

% atLeastAtMost_eq_UNIV_iff
tff(fact_2239_UNIV__option__conv,axiom,
    ! [B: $tType] : top_top(set(option(B))) = aa(set(option(B)),set(option(B)),insert2(option(B),none(B)),aa(set(B),set(option(B)),image2(B,option(B),some(B)),top_top(set(B)))) ).

% UNIV_option_conv
tff(fact_2240_bounded__nat__set__is__finite,axiom,
    ! [N5: set(nat),N: nat] :
      ( ! [X3: nat] :
          ( member(nat,X3,N5)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X3),N) )
     => finite_finite2(nat,N5) ) ).

% bounded_nat_set_is_finite
tff(fact_2241_finite__nat__set__iff__bounded,axiom,
    ! [N5: set(nat)] :
      ( finite_finite2(nat,N5)
    <=> ? [M6: nat] :
        ! [X4: nat] :
          ( member(nat,X4,N5)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),M6) ) ) ).

% finite_nat_set_iff_bounded
tff(fact_2242_finite__nat__set__iff__bounded__le,axiom,
    ! [N5: set(nat)] :
      ( finite_finite2(nat,N5)
    <=> ? [M6: nat] :
        ! [X4: nat] :
          ( member(nat,X4,N5)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),X4),M6) ) ) ).

% finite_nat_set_iff_bounded_le
tff(fact_2243_surjD,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),Y: B] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ? [X3: C] : Y = aa(C,B,F,X3) ) ).

% surjD
tff(fact_2244_surjE,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),Y: B] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ~ ! [X3: C] : Y != aa(C,B,F,X3) ) ).

% surjE
tff(fact_2245_surjI,axiom,
    ! [C: $tType,B: $tType,G: fun(C,B),F: fun(B,C)] :
      ( ! [X3: B] : aa(C,B,G,aa(B,C,F,X3)) = X3
     => ( aa(set(C),set(B),image2(C,B,G),top_top(set(C))) = top_top(set(B)) ) ) ).

% surjI
tff(fact_2246_surj__def,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
    <=> ! [Y3: B] :
        ? [X4: C] : Y3 = aa(C,B,F,X4) ) ).

% surj_def
tff(fact_2247_these__empty__eq,axiom,
    ! [B: $tType,B5: set(option(B))] :
      ( ( these(B,B5) = bot_bot(set(B)) )
    <=> ( ( B5 = bot_bot(set(option(B))) )
        | ( B5 = aa(set(option(B)),set(option(B)),insert2(option(B),none(B)),bot_bot(set(option(B)))) ) ) ) ).

% these_empty_eq
tff(fact_2248_these__not__empty__eq,axiom,
    ! [B: $tType,B5: set(option(B))] :
      ( ( these(B,B5) != bot_bot(set(B)) )
    <=> ( ( B5 != bot_bot(set(option(B))) )
        & ( B5 != aa(set(option(B)),set(option(B)),insert2(option(B),none(B)),bot_bot(set(option(B)))) ) ) ) ).

% these_not_empty_eq
tff(fact_2249_not__UNIV__eq__Icc,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [L4: B,H2: B] : top_top(set(B)) != set_or1337092689740270186AtMost(B,L4,H2) ) ).

% not_UNIV_eq_Icc
tff(fact_2250_infinite__Iic,axiom,
    ! [B: $tType] :
      ( ( linorder(B)
        & no_bot(B) )
     => ! [A3: B] : ~ finite_finite2(B,aa(B,set(B),set_ord_atMost(B),A3)) ) ).

% infinite_Iic
tff(fact_2251_infinite__Iio,axiom,
    ! [B: $tType] :
      ( ( linorder(B)
        & no_bot(B) )
     => ! [A3: B] : ~ finite_finite2(B,aa(B,set(B),set_ord_lessThan(B),A3)) ) ).

% infinite_Iio
tff(fact_2252_not__UNIV__eq__Iic,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [H2: B] : top_top(set(B)) != aa(B,set(B),set_ord_atMost(B),H2) ) ).

% not_UNIV_eq_Iic
tff(fact_2253_card__1__singletonI,axiom,
    ! [B: $tType,S2: set(B),X2: B] :
      ( finite_finite2(B,S2)
     => ( ( finite_card(B,S2) = one_one(nat) )
       => ( member(B,X2,S2)
         => ( S2 = aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))) ) ) ) ) ).

% card_1_singletonI
tff(fact_2254_finite__M__bounded__by__nat,axiom,
    ! [P: fun(nat,$o),I: nat] : finite_finite2(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_ht(fun(nat,$o),fun(nat,fun(nat,$o)),P),I))) ).

% finite_M_bounded_by_nat
tff(fact_2255_finite__less__ub,axiom,
    ! [F: fun(nat,nat),U: nat] :
      ( ! [N3: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N3),aa(nat,nat,F,N3))
     => finite_finite2(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_hu(fun(nat,nat),fun(nat,fun(nat,$o)),F),U))) ) ).

% finite_less_ub
tff(fact_2256_card__insert__disjoint_H,axiom,
    ! [B: $tType,A4: set(B),X2: B] :
      ( finite_finite2(B,A4)
     => ( ~ member(B,X2,A4)
       => ( aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,aa(set(B),set(B),insert2(B,X2),A4))),aa(nat,nat,suc,zero_zero(nat))) = finite_card(B,A4) ) ) ) ).

% card_insert_disjoint'
tff(fact_2257_in__these__eq,axiom,
    ! [B: $tType,X2: B,A4: set(option(B))] :
      ( member(B,X2,these(B,A4))
    <=> member(option(B),aa(B,option(B),some(B),X2),A4) ) ).

% in_these_eq
tff(fact_2258_infinite__Icc,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ~ finite_finite2(B,set_or1337092689740270186AtMost(B,A3,B2)) ) ) ).

% infinite_Icc
tff(fact_2259_infinite__Ico,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ~ finite_finite2(B,set_or7035219750837199246ssThan(B,A3,B2)) ) ) ).

% infinite_Ico
tff(fact_2260_subset__eq__atLeast0__atMost__finite,axiom,
    ! [N5: set(nat),N: nat] :
      ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),N5),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))
     => finite_finite2(nat,N5) ) ).

% subset_eq_atLeast0_atMost_finite
tff(fact_2261_subset__eq__atLeast0__lessThan__finite,axiom,
    ! [N5: set(nat),N: nat] :
      ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),N5),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))
     => finite_finite2(nat,N5) ) ).

% subset_eq_atLeast0_lessThan_finite
tff(fact_2262_atMost__Suc,axiom,
    ! [K: nat] : aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,K)) = aa(set(nat),set(nat),insert2(nat,aa(nat,nat,suc,K)),aa(nat,set(nat),set_ord_atMost(nat),K)) ).

% atMost_Suc
tff(fact_2263_surj__fun__eq,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(C,B),X7: set(C),G1: fun(B,D),G22: fun(B,D)] :
      ( ( aa(set(C),set(B),image2(C,B,F),X7) = top_top(set(B)) )
     => ( ! [X3: C] :
            ( member(C,X3,X7)
           => ( aa(C,D,aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),G1),F),X3) = aa(C,D,aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),G22),F),X3) ) )
       => ( G1 = G22 ) ) ) ).

% surj_fun_eq
tff(fact_2264_comp__surj,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(B,D)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ( ( aa(set(B),set(D),image2(B,D,G),top_top(set(B))) = top_top(set(D)) )
       => ( aa(set(C),set(D),image2(C,D,aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),G),F)),top_top(set(C))) = top_top(set(D)) ) ) ) ).

% comp_surj
tff(fact_2265_fun_Oset__map,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(D,B),V: fun(C,D)] : aa(set(C),set(B),image2(C,B,aa(fun(C,D),fun(C,B),aa(fun(D,B),fun(fun(C,D),fun(C,B)),comp(D,B,C),F),V)),top_top(set(C))) = aa(set(D),set(B),image2(D,B,F),aa(set(C),set(D),image2(C,D,V),top_top(set(C)))) ).

% fun.set_map
tff(fact_2266_fun_Omap__cong,axiom,
    ! [D: $tType,C: $tType,B: $tType,X2: fun(B,C),Ya: fun(B,C),F: fun(C,D),G: fun(C,D)] :
      ( ( X2 = Ya )
     => ( ! [Z3: C] :
            ( member(C,Z3,aa(set(B),set(C),image2(B,C,Ya),top_top(set(B))))
           => ( aa(C,D,F,Z3) = aa(C,D,G,Z3) ) )
       => ( aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F),X2) = aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),Ya) ) ) ) ).

% fun.map_cong
tff(fact_2267_fun_Omap__cong0,axiom,
    ! [D: $tType,B: $tType,C: $tType,X2: fun(C,B),F: fun(B,D),G: fun(B,D)] :
      ( ! [Z3: B] :
          ( member(B,Z3,aa(set(C),set(B),image2(C,B,X2),top_top(set(C))))
         => ( aa(B,D,F,Z3) = aa(B,D,G,Z3) ) )
     => ( aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),F),X2) = aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),G),X2) ) ) ).

% fun.map_cong0
tff(fact_2268_fun_Oinj__map__strong,axiom,
    ! [D: $tType,B: $tType,C: $tType,X2: fun(C,B),Xa: fun(C,B),F: fun(B,D),Fa: fun(B,D)] :
      ( ! [Z3: B,Za: B] :
          ( member(B,Z3,aa(set(C),set(B),image2(C,B,X2),top_top(set(C))))
         => ( member(B,Za,aa(set(C),set(B),image2(C,B,Xa),top_top(set(C))))
           => ( ( aa(B,D,F,Z3) = aa(B,D,Fa,Za) )
             => ( Z3 = Za ) ) ) )
     => ( ( aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),F),X2) = aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),Fa),Xa) )
       => ( X2 = Xa ) ) ) ).

% fun.inj_map_strong
tff(fact_2269_lessThan__Suc,axiom,
    ! [K: nat] : aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,K)) = aa(set(nat),set(nat),insert2(nat,K),aa(nat,set(nat),set_ord_lessThan(nat),K)) ).

% lessThan_Suc
tff(fact_2270_not__UNIV__le__Icc,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [L: B,Ha: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),top_top(set(B))),set_or1337092689740270186AtMost(B,L,Ha)) ) ).

% not_UNIV_le_Icc
tff(fact_2271_surj__id,axiom,
    ! [B: $tType] : aa(set(B),set(B),image2(B,B,id(B)),top_top(set(B))) = top_top(set(B)) ).

% surj_id
tff(fact_2272_not__UNIV__le__Iic,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [Ha: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),top_top(set(B))),aa(B,set(B),set_ord_atMost(B),Ha)) ) ).

% not_UNIV_le_Iic
tff(fact_2273_sum_Ofinite__Collect__op,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [I4: set(B),X2: fun(B,C),Y: fun(B,C)] :
          ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hv(set(B),fun(fun(B,C),fun(B,$o)),I4),X2)))
         => ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hv(set(B),fun(fun(B,C),fun(B,$o)),I4),Y)))
           => finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aa(fun(B,C),fun(fun(B,C),fun(B,$o)),aTP_Lamp_hw(set(B),fun(fun(B,C),fun(fun(B,C),fun(B,$o))),I4),X2),Y))) ) ) ) ).

% sum.finite_Collect_op
tff(fact_2274_prod_Ofinite__Collect__op,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [I4: set(B),X2: fun(B,C),Y: fun(B,C)] :
          ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hx(set(B),fun(fun(B,C),fun(B,$o)),I4),X2)))
         => ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hx(set(B),fun(fun(B,C),fun(B,$o)),I4),Y)))
           => finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aa(fun(B,C),fun(fun(B,C),fun(B,$o)),aTP_Lamp_hy(set(B),fun(fun(B,C),fun(fun(B,C),fun(B,$o))),I4),X2),Y))) ) ) ) ).

% prod.finite_Collect_op
tff(fact_2275_finite__atLeastZeroLessThan__int,axiom,
    ! [U: int] : finite_finite2(int,set_or7035219750837199246ssThan(int,zero_zero(int),U)) ).

% finite_atLeastZeroLessThan_int
tff(fact_2276_card__eq__sum,axiom,
    ! [B: $tType,A4: set(B)] : finite_card(B,A4) = aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),aTP_Lamp_hz(B,nat)),A4) ).

% card_eq_sum
tff(fact_2277_prod_Ointer__filter,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(B),G: fun(B,C),P: fun(B,$o)] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),aa(fun(B,$o),set(B),collect(B),aa(fun(B,$o),fun(B,$o),aTP_Lamp_ia(set(B),fun(fun(B,$o),fun(B,$o)),A4),P))) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),aa(fun(B,$o),fun(B,C),aTP_Lamp_ib(fun(B,C),fun(fun(B,$o),fun(B,C)),G),P)),A4) ) ) ) ).

% prod.inter_filter
tff(fact_2278_prod__gen__delta,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),A3: B,B2: fun(B,C),C2: C] :
          ( finite_finite2(B,S2)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),aa(C,fun(B,C),aa(fun(B,C),fun(C,fun(B,C)),aTP_Lamp_ic(B,fun(fun(B,C),fun(C,fun(B,C))),A3),B2),C2)),S2) = $ite(member(B,A3,S2),aa(C,C,aa(C,fun(C,C),times_times(C),aa(B,C,B2,A3)),aa(nat,C,aa(C,fun(nat,C),power_power(C),C2),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,S2)),one_one(nat)))),aa(nat,C,aa(C,fun(nat,C),power_power(C),C2),finite_card(B,S2))) ) ) ) ).

% prod_gen_delta
tff(fact_2279_finite__atLeastZeroLessThan__integer,axiom,
    ! [U: code_integer] : finite_finite2(code_integer,set_or7035219750837199246ssThan(code_integer,zero_zero(code_integer),U)) ).

% finite_atLeastZeroLessThan_integer
tff(fact_2280_card__2__iff_H,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( finite_card(B,S2) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) )
    <=> ? [X4: B] :
          ( member(B,X4,S2)
          & ? [Xa2: B] :
              ( member(B,Xa2,S2)
              & ( X4 != Xa2 )
              & ! [Xb4: B] :
                  ( member(B,Xb4,S2)
                 => ( ( Xb4 = X4 )
                    | ( Xb4 = Xa2 ) ) ) ) ) ) ).

% card_2_iff'
tff(fact_2281_sum_Orelated,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [R4: fun(B,fun(B,$o)),S2: set(C),Ha: fun(C,B),G: fun(C,B)] :
          ( aa(B,$o,aa(B,fun(B,$o),R4,zero_zero(B)),zero_zero(B))
         => ( ! [X12: B,Y12: B,X23: B,Y22: B] :
                ( ( aa(B,$o,aa(B,fun(B,$o),R4,X12),X23)
                  & aa(B,$o,aa(B,fun(B,$o),R4,Y12),Y22) )
               => aa(B,$o,aa(B,fun(B,$o),R4,aa(B,B,aa(B,fun(B,B),plus_plus(B),X12),Y12)),aa(B,B,aa(B,fun(B,B),plus_plus(B),X23),Y22)) )
           => ( finite_finite2(C,S2)
             => ( ! [X3: C] :
                    ( member(C,X3,S2)
                   => aa(B,$o,aa(B,fun(B,$o),R4,aa(C,B,Ha,X3)),aa(C,B,G,X3)) )
               => aa(B,$o,aa(B,fun(B,$o),R4,aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7311177749621191930dd_sum(C,B),Ha),S2)),aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7311177749621191930dd_sum(C,B),G),S2)) ) ) ) ) ) ).

% sum.related
tff(fact_2282_prod_Orelated,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(B)
     => ! [R4: fun(B,fun(B,$o)),S2: set(C),Ha: fun(C,B),G: fun(C,B)] :
          ( aa(B,$o,aa(B,fun(B,$o),R4,one_one(B)),one_one(B))
         => ( ! [X12: B,Y12: B,X23: B,Y22: B] :
                ( ( aa(B,$o,aa(B,fun(B,$o),R4,X12),X23)
                  & aa(B,$o,aa(B,fun(B,$o),R4,Y12),Y22) )
               => aa(B,$o,aa(B,fun(B,$o),R4,aa(B,B,aa(B,fun(B,B),times_times(B),X12),Y12)),aa(B,B,aa(B,fun(B,B),times_times(B),X23),Y22)) )
           => ( finite_finite2(C,S2)
             => ( ! [X3: C] :
                    ( member(C,X3,S2)
                   => aa(B,$o,aa(B,fun(B,$o),R4,aa(C,B,Ha,X3)),aa(C,B,G,X3)) )
               => aa(B,$o,aa(B,fun(B,$o),R4,aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),Ha),S2)),aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),G),S2)) ) ) ) ) ) ).

% prod.related
tff(fact_2283_sum_Oinsert__if,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),G: fun(B,C),X2: B] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),insert2(B,X2),A4)) = $ite(member(B,X2,A4),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,G,X2)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4))) ) ) ) ).

% sum.insert_if
tff(fact_2284_atLeast0__atMost__Suc,axiom,
    ! [N: nat] : set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,aa(nat,nat,suc,N)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) ).

% atLeast0_atMost_Suc
tff(fact_2285_atLeast0__lessThan__Suc,axiom,
    ! [N: nat] : set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,N),set_or7035219750837199246ssThan(nat,zero_zero(nat),N)) ).

% atLeast0_lessThan_Suc
tff(fact_2286_Icc__eq__insert__lb__nat,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
     => ( set_or1337092689740270186AtMost(nat,M,N) = aa(set(nat),set(nat),insert2(nat,M),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),N)) ) ) ).

% Icc_eq_insert_lb_nat
tff(fact_2287_atLeastAtMostSuc__conv,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,suc,N))
     => ( set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,aa(nat,nat,suc,N)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% atLeastAtMostSuc_conv
tff(fact_2288_atLeastAtMost__insertL,axiom,
    ! [M: nat,N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
     => ( aa(set(nat),set(nat),insert2(nat,M),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),N)) = set_or1337092689740270186AtMost(nat,M,N) ) ) ).

% atLeastAtMost_insertL
tff(fact_2289_prod_Oreindex__bij__witness__not__neutral,axiom,
    ! [B: $tType,D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S5: set(B),T4: set(C),S2: set(B),I: fun(C,B),J: fun(B,C),T5: set(C),G: fun(B,D),Ha: fun(C,D)] :
          ( finite_finite2(B,S5)
         => ( finite_finite2(C,T4)
           => ( ! [A5: B] :
                  ( member(B,A5,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),S5))
                 => ( aa(C,B,I,aa(B,C,J,A5)) = A5 ) )
             => ( ! [A5: B] :
                    ( member(B,A5,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),S5))
                   => member(C,aa(B,C,J,A5),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),T5),T4)) )
               => ( ! [B3: C] :
                      ( member(C,B3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),T5),T4))
                     => ( aa(B,C,J,aa(C,B,I,B3)) = B3 ) )
                 => ( ! [B3: C] :
                        ( member(C,B3,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),T5),T4))
                       => member(B,aa(C,B,I,B3),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),S5)) )
                   => ( ! [A5: B] :
                          ( member(B,A5,S5)
                         => ( aa(B,D,G,A5) = one_one(D) ) )
                     => ( ! [B3: C] :
                            ( member(C,B3,T4)
                           => ( aa(C,D,Ha,B3) = one_one(D) ) )
                       => ( ! [A5: B] :
                              ( member(B,A5,S2)
                             => ( aa(C,D,Ha,aa(B,C,J,A5)) = aa(B,D,G,A5) ) )
                         => ( aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7121269368397514597t_prod(B,D),G),S2) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),Ha),T5) ) ) ) ) ) ) ) ) ) ) ) ).

% prod.reindex_bij_witness_not_neutral
tff(fact_2290_dflt__None__set__def,axiom,
    ! [B: $tType,S2: set(B)] :
      dflt_None_set(B,S2) = $ite(S2 = bot_bot(set(B)),none(set(B)),aa(set(B),option(set(B)),some(set(B)),S2)) ).

% dflt_None_set_def
tff(fact_2291_sum__eq__1__iff,axiom,
    ! [B: $tType,A4: set(B),F: fun(B,nat)] :
      ( finite_finite2(B,A4)
     => ( ( aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),F),A4) = one_one(nat) )
      <=> ? [X4: B] :
            ( member(B,X4,A4)
            & ( aa(B,nat,F,X4) = one_one(nat) )
            & ! [Xa2: B] :
                ( member(B,Xa2,A4)
               => ( ( X4 != Xa2 )
                 => ( aa(B,nat,F,Xa2) = zero_zero(nat) ) ) ) ) ) ) ).

% sum_eq_1_iff
tff(fact_2292_surj__Compl__image__subset,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),A4: set(C)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),uminus_uminus(set(B)),aa(set(C),set(B),image2(C,B,F),A4))),aa(set(C),set(B),image2(C,B,F),aa(set(C),set(C),uminus_uminus(set(C)),A4))) ) ).

% surj_Compl_image_subset
tff(fact_2293_card__atLeastZeroLessThan__int,axiom,
    ! [U: int] : finite_card(int,set_or7035219750837199246ssThan(int,zero_zero(int),U)) = aa(int,nat,nat2,U) ).

% card_atLeastZeroLessThan_int
tff(fact_2294_atMost__nat__numeral,axiom,
    ! [K: num] : aa(nat,set(nat),set_ord_atMost(nat),aa(num,nat,numeral_numeral(nat),K)) = aa(set(nat),set(nat),insert2(nat,aa(num,nat,numeral_numeral(nat),K)),aa(nat,set(nat),set_ord_atMost(nat),pred_numeral(K))) ).

% atMost_nat_numeral
tff(fact_2295_lessThan__nat__numeral,axiom,
    ! [K: num] : aa(nat,set(nat),set_ord_lessThan(nat),aa(num,nat,numeral_numeral(nat),K)) = aa(set(nat),set(nat),insert2(nat,pred_numeral(K)),aa(nat,set(nat),set_ord_lessThan(nat),pred_numeral(K))) ).

% lessThan_nat_numeral
tff(fact_2296_sum__Suc,axiom,
    ! [B: $tType,F: fun(B,nat),A4: set(B)] : aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),aTP_Lamp_id(fun(B,nat),fun(B,nat),F)),A4) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),F),A4)),finite_card(B,A4)) ).

% sum_Suc
tff(fact_2297_prod_Osetdiff__irrelevant,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(B),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(fun(B,$o),set(B),collect(B),aTP_Lamp_ie(fun(B,C),fun(B,$o),G)))) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),A4) ) ) ) ).

% prod.setdiff_irrelevant
tff(fact_2298_notin__range__Some,axiom,
    ! [B: $tType,X2: option(B)] :
      ( ~ member(option(B),X2,aa(set(B),set(option(B)),image2(B,option(B),some(B)),top_top(set(B))))
    <=> ( X2 = none(B) ) ) ).

% notin_range_Some
tff(fact_2299_less__1__prod2,axiom,
    ! [C: $tType,B: $tType] :
      ( linordered_idom(C)
     => ! [I4: set(B),I: B,F: fun(B,C)] :
          ( finite_finite2(B,I4)
         => ( member(B,I,I4)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(B,C,F,I))
             => ( ! [I2: B] :
                    ( member(B,I2,I4)
                   => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),aa(B,C,F,I2)) )
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),I4)) ) ) ) ) ) ).

% less_1_prod2
tff(fact_2300_less__1__prod,axiom,
    ! [C: $tType,B: $tType] :
      ( linordered_idom(C)
     => ! [I4: set(B),F: fun(B,C)] :
          ( finite_finite2(B,I4)
         => ( ( I4 != bot_bot(set(B)) )
           => ( ! [I2: B] :
                  ( member(B,I2,I4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(B,C,F,I2)) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),one_one(C)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),I4)) ) ) ) ) ).

% less_1_prod
tff(fact_2301_sum_Oreindex__nontrivial,axiom,
    ! [C: $tType,D: $tType,B: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(B),Ha: fun(B,C),G: fun(C,D)] :
          ( finite_finite2(B,A4)
         => ( ! [X3: B,Y4: B] :
                ( member(B,X3,A4)
               => ( member(B,Y4,A4)
                 => ( ( X3 != Y4 )
                   => ( ( aa(B,C,Ha,X3) = aa(B,C,Ha,Y4) )
                     => ( aa(C,D,G,aa(B,C,Ha,X3)) = zero_zero(D) ) ) ) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(B),set(C),image2(B,C,Ha),A4)) = aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7311177749621191930dd_sum(B,D),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),Ha)),A4) ) ) ) ) ).

% sum.reindex_nontrivial
tff(fact_2302_prod_Oreindex__nontrivial,axiom,
    ! [C: $tType,D: $tType,B: $tType] :
      ( comm_monoid_mult(D)
     => ! [A4: set(B),Ha: fun(B,C),G: fun(C,D)] :
          ( finite_finite2(B,A4)
         => ( ! [X3: B,Y4: B] :
                ( member(B,X3,A4)
               => ( member(B,Y4,A4)
                 => ( ( X3 != Y4 )
                   => ( ( aa(B,C,Ha,X3) = aa(B,C,Ha,Y4) )
                     => ( aa(C,D,G,aa(B,C,Ha,X3)) = one_one(D) ) ) ) ) )
           => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(B),set(C),image2(B,C,Ha),A4)) = aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7121269368397514597t_prod(B,D),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),Ha)),A4) ) ) ) ) ).

% prod.reindex_nontrivial
tff(fact_2303_sum_Osubset__diff,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [B5: set(B),A4: set(B),G: fun(B,C)] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),A4)
         => ( finite_finite2(B,A4)
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),B5)) ) ) ) ) ).

% sum.subset_diff
tff(fact_2304_prod_Osame__carrier,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [C5: set(B),A4: set(B),B5: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( finite_finite2(B,C5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),C5)
           => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),C5)
             => ( ! [A5: B] :
                    ( member(B,A5,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),C5),A4))
                   => ( aa(B,C,G,A5) = one_one(C) ) )
               => ( ! [B3: B] :
                      ( member(B,B3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),C5),B5))
                     => ( aa(B,C,Ha,B3) = one_one(C) ) )
                 => ( ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),A4) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),B5) )
                  <=> ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),C5) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),C5) ) ) ) ) ) ) ) ) ).

% prod.same_carrier
tff(fact_2305_prod_Osame__carrierI,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [C5: set(B),A4: set(B),B5: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( finite_finite2(B,C5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),C5)
           => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),C5)
             => ( ! [A5: B] :
                    ( member(B,A5,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),C5),A4))
                   => ( aa(B,C,G,A5) = one_one(C) ) )
               => ( ! [B3: B] :
                      ( member(B,B3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),C5),B5))
                     => ( aa(B,C,Ha,B3) = one_one(C) ) )
                 => ( ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),C5) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),C5) )
                   => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),A4) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),B5) ) ) ) ) ) ) ) ) ).

% prod.same_carrierI
tff(fact_2306_prod_Omono__neutral__left,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [T5: set(B),S2: set(B),G: fun(B,C)] :
          ( finite_finite2(B,T5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
           => ( ! [X3: B] :
                  ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
                 => ( aa(B,C,G,X3) = one_one(C) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),S2) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),T5) ) ) ) ) ) ).

% prod.mono_neutral_left
tff(fact_2307_prod_Omono__neutral__right,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [T5: set(B),S2: set(B),G: fun(B,C)] :
          ( finite_finite2(B,T5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
           => ( ! [X3: B] :
                  ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
                 => ( aa(B,C,G,X3) = one_one(C) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),T5) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),S2) ) ) ) ) ) ).

% prod.mono_neutral_right
tff(fact_2308_prod_Omono__neutral__cong__left,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [T5: set(B),S2: set(B),Ha: fun(B,C),G: fun(B,C)] :
          ( finite_finite2(B,T5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
           => ( ! [X3: B] :
                  ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
                 => ( aa(B,C,Ha,X3) = one_one(C) ) )
             => ( ! [X3: B] :
                    ( member(B,X3,S2)
                   => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) )
               => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),S2) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),T5) ) ) ) ) ) ) ).

% prod.mono_neutral_cong_left
tff(fact_2309_prod_Omono__neutral__cong__right,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [T5: set(B),S2: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( finite_finite2(B,T5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
           => ( ! [X3: B] :
                  ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
                 => ( aa(B,C,G,X3) = one_one(C) ) )
             => ( ! [X3: B] :
                    ( member(B,X3,S2)
                   => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) )
               => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),T5) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),S2) ) ) ) ) ) ) ).

% prod.mono_neutral_cong_right
tff(fact_2310_atLeastLessThanSuc,axiom,
    ! [M: nat,N: nat] :
      set_or7035219750837199246ssThan(nat,M,aa(nat,nat,suc,N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N),aa(set(nat),set(nat),insert2(nat,N),set_or7035219750837199246ssThan(nat,M,N)),bot_bot(set(nat))) ).

% atLeastLessThanSuc
tff(fact_2311_Option_Othese__def,axiom,
    ! [B: $tType,A4: set(option(B))] : these(B,A4) = aa(set(option(B)),set(B),image2(option(B),B,the2(B)),aa(fun(option(B),$o),set(option(B)),collect(option(B)),aTP_Lamp_hp(set(option(B)),fun(option(B),$o),A4))) ).

% Option.these_def
tff(fact_2312_atLeast0__atMost__Suc__eq__insert__0,axiom,
    ! [N: nat] : set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),aa(set(nat),set(nat),image2(nat,nat,suc),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) ).

% atLeast0_atMost_Suc_eq_insert_0
tff(fact_2313_atLeast0__lessThan__Suc__eq__insert__0,axiom,
    ! [N: nat] : set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),aa(set(nat),set(nat),image2(nat,nat,suc),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))) ).

% atLeast0_lessThan_Suc_eq_insert_0
tff(fact_2314_atMost__Suc__eq__insert__0,axiom,
    ! [N: nat] : aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),aa(set(nat),set(nat),image2(nat,nat,suc),aa(nat,set(nat),set_ord_atMost(nat),N))) ).

% atMost_Suc_eq_insert_0
tff(fact_2315_lessThan__Suc__eq__insert__0,axiom,
    ! [N: nat] : aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N)) = aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),aa(set(nat),set(nat),image2(nat,nat,suc),aa(nat,set(nat),set_ord_lessThan(nat),N))) ).

% lessThan_Suc_eq_insert_0
tff(fact_2316_card__2__iff,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( finite_card(B,S2) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) )
    <=> ? [X4: B,Y3: B] :
          ( ( S2 = aa(set(B),set(B),insert2(B,X4),aa(set(B),set(B),insert2(B,Y3),bot_bot(set(B)))) )
          & ( X4 != Y3 ) ) ) ).

% card_2_iff
tff(fact_2317_card__3__iff,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( finite_card(B,S2) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2)) )
    <=> ? [X4: B,Y3: B,Z4: B] :
          ( ( S2 = aa(set(B),set(B),insert2(B,X4),aa(set(B),set(B),insert2(B,Y3),aa(set(B),set(B),insert2(B,Z4),bot_bot(set(B))))) )
          & ( X4 != Y3 )
          & ( Y3 != Z4 )
          & ( X4 != Z4 ) ) ) ).

% card_3_iff
tff(fact_2318_sum__image__le,axiom,
    ! [D: $tType,C: $tType,B: $tType] :
      ( ordere6911136660526730532id_add(C)
     => ! [I4: set(B),G: fun(D,C),F: fun(B,D)] :
          ( finite_finite2(B,I4)
         => ( ! [I2: B] :
                ( member(B,I2,I4)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(D,C,G,aa(B,D,F,I2))) )
           => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(D),C,aa(fun(D,C),fun(set(D),C),groups7311177749621191930dd_sum(D,C),G),aa(set(B),set(D),image2(B,D,F),I4))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),G),F)),I4)) ) ) ) ).

% sum_image_le
tff(fact_2319_sum_Oremove,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),X2: B,G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( member(B,X2,A4)
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,G,X2)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))))) ) ) ) ) ).

% sum.remove
tff(fact_2320_sum_Oinsert__remove,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),G: fun(B,C),X2: B] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),insert2(B,X2),A4)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,G,X2)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))))) ) ) ) ).

% sum.insert_remove
tff(fact_2321_atLeast1__atMost__eq__remove0,axiom,
    ! [N: nat] : set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N) = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),minus_minus(set(nat)),aa(nat,set(nat),set_ord_atMost(nat),N)),aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),bot_bot(set(nat)))) ).

% atLeast1_atMost_eq_remove0
tff(fact_2322_atLeast1__lessThan__eq__remove0,axiom,
    ! [N: nat] : set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,zero_zero(nat)),N) = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),minus_minus(set(nat)),aa(nat,set(nat),set_ord_lessThan(nat),N)),aa(set(nat),set(nat),insert2(nat,zero_zero(nat)),bot_bot(set(nat)))) ).

% atLeast1_lessThan_eq_remove0
tff(fact_2323_atLeastLessThan__nat__numeral,axiom,
    ! [M: nat,K: num] :
      set_or7035219750837199246ssThan(nat,M,aa(num,nat,numeral_numeral(nat),K)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),pred_numeral(K)),aa(set(nat),set(nat),insert2(nat,pred_numeral(K)),set_or7035219750837199246ssThan(nat,M,pred_numeral(K))),bot_bot(set(nat))) ).

% atLeastLessThan_nat_numeral
tff(fact_2324_sum_Odelta__remove,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [S2: set(B),A3: B,B2: fun(B,C),C2: fun(B,C)] :
          ( finite_finite2(B,S2)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),aa(fun(B,C),fun(B,C),aa(fun(B,C),fun(fun(B,C),fun(B,C)),aTP_Lamp_if(B,fun(fun(B,C),fun(fun(B,C),fun(B,C))),A3),B2),C2)),S2) = $ite(member(B,A3,S2),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,B2,A3)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),C2),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),C2),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))))) ) ) ) ).

% sum.delta_remove
tff(fact_2325_prod__le__power,axiom,
    ! [B: $tType,C: $tType] :
      ( linordered_semidom(C)
     => ! [A4: set(B),F: fun(B,C),N: C,K: nat] :
          ( ! [I2: B] :
              ( member(B,I2,A4)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),zero_zero(C)),aa(B,C,F,I2))
                & aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,F,I2)),N) ) )
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(B,A4)),K)
           => ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),one_one(C)),N)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),F),A4)),aa(nat,C,aa(C,fun(nat,C),power_power(C),N),K)) ) ) ) ) ).

% prod_le_power
tff(fact_2326_card__Diff__insert,axiom,
    ! [B: $tType,A3: B,A4: set(B),B5: set(B)] :
      ( member(B,A3,A4)
     => ( ~ member(B,A3,B5)
       => ( finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,A3),B5))) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5))),one_one(nat)) ) ) ) ).

% card_Diff_insert
tff(fact_2327_card__insert__le__m1,axiom,
    ! [B: $tType,N: nat,Y: set(B),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(B,Y)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(B,aa(set(B),set(B),insert2(B,X2),Y))),N) ) ) ).

% card_insert_le_m1
tff(fact_2328_card__Diff__singleton__if,axiom,
    ! [B: $tType,A4: set(B),X2: B] :
      finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))) = $ite(member(B,X2,A4),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,A4)),one_one(nat)),finite_card(B,A4)) ).

% card_Diff_singleton_if
tff(fact_2329_card__Diff__singleton,axiom,
    ! [B: $tType,X2: B,A4: set(B)] :
      ( member(B,X2,A4)
     => ( finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,A4)),one_one(nat)) ) ) ).

% card_Diff_singleton
tff(fact_2330_in__finite__psubset,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),A4),B5),finite_psubset(B))
    <=> ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),A4),B5)
        & finite_finite2(B,B5) ) ) ).

% in_finite_psubset
tff(fact_2331_card__1__singletonE,axiom,
    ! [B: $tType,A4: set(B)] :
      ( ( finite_card(B,A4) = one_one(nat) )
     => ~ ! [X3: B] : A4 != aa(set(B),set(B),insert2(B,X3),bot_bot(set(B))) ) ).

% card_1_singletonE
tff(fact_2332_integer__of__nat__def,axiom,
    code_integer_of_nat = aa(fun(nat,int),fun(nat,code_integer),map_fun(nat,nat,int,code_integer,id(nat),code_integer_of_int),semiring_1_of_nat(int)) ).

% integer_of_nat_def
tff(fact_2333_card__UNIV__unit,axiom,
    finite_card(product_unit,top_top(set(product_unit))) = one_one(nat) ).

% card_UNIV_unit
tff(fact_2334_card__lessThan,axiom,
    ! [U: nat] : finite_card(nat,aa(nat,set(nat),set_ord_lessThan(nat),U)) = U ).

% card_lessThan
tff(fact_2335_card__atLeastLessThan,axiom,
    ! [L: nat,U: nat] : finite_card(nat,set_or7035219750837199246ssThan(nat,L,U)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),U),L) ).

% card_atLeastLessThan
tff(fact_2336_card__atMost,axiom,
    ! [U: nat] : finite_card(nat,aa(nat,set(nat),set_ord_atMost(nat),U)) = aa(nat,nat,suc,U) ).

% card_atMost
tff(fact_2337_Collect__const__case__prod,axiom,
    ! [C: $tType,B: $tType,P: $o] :
      aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_ig($o,fun(B,fun(C,$o)),(P)))) = $ite((P),top_top(set(product_prod(B,C))),bot_bot(set(product_prod(B,C)))) ).

% Collect_const_case_prod
tff(fact_2338_nat__of__integer__integer__of__nat,axiom,
    ! [N: nat] : aa(code_integer,nat,code_nat_of_integer,aa(nat,code_integer,code_integer_of_nat,N)) = N ).

% nat_of_integer_integer_of_nat
tff(fact_2339_card__atLeastAtMost,axiom,
    ! [L: nat,U: nat] : finite_card(nat,set_or1337092689740270186AtMost(nat,L,U)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,suc,U)),L) ).

% card_atLeastAtMost
tff(fact_2340_integer__of__nat_Orep__eq,axiom,
    ! [X2: nat] : aa(code_integer,int,code_int_of_integer,aa(nat,code_integer,code_integer_of_nat,X2)) = aa(nat,int,semiring_1_of_nat(int),X2) ).

% integer_of_nat.rep_eq
tff(fact_2341_int__of__integer__integer__of__nat,axiom,
    ! [N: nat] : aa(code_integer,int,code_int_of_integer,aa(nat,code_integer,code_integer_of_nat,N)) = aa(nat,int,semiring_1_of_nat(int),N) ).

% int_of_integer_integer_of_nat
tff(fact_2342_top__empty__eq2,axiom,
    ! [C: $tType,B: $tType,X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),top_top(fun(B,fun(C,$o))),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),top_top(set(product_prod(B,C)))) ) ).

% top_empty_eq2
tff(fact_2343_int__of__integer__induct,axiom,
    ! [Y: int,P: fun(int,$o)] :
      ( member(int,Y,top_top(set(int)))
     => ( ! [X3: code_integer] : aa(int,$o,P,aa(code_integer,int,code_int_of_integer,X3))
       => aa(int,$o,P,Y) ) ) ).

% int_of_integer_induct
tff(fact_2344_int__of__integer__cases,axiom,
    ! [Y: int] :
      ( member(int,Y,top_top(set(int)))
     => ~ ! [X3: code_integer] : Y != aa(code_integer,int,code_int_of_integer,X3) ) ).

% int_of_integer_cases
tff(fact_2345_int__of__integer,axiom,
    ! [X2: code_integer] : member(int,aa(code_integer,int,code_int_of_integer,X2),top_top(set(int))) ).

% int_of_integer
tff(fact_2346_integer__of__int__inject,axiom,
    ! [X2: int,Y: int] :
      ( member(int,X2,top_top(set(int)))
     => ( member(int,Y,top_top(set(int)))
       => ( ( aa(int,code_integer,code_integer_of_int,X2) = aa(int,code_integer,code_integer_of_int,Y) )
        <=> ( X2 = Y ) ) ) ) ).

% integer_of_int_inject
tff(fact_2347_integer__of__int__induct,axiom,
    ! [P: fun(code_integer,$o),X2: code_integer] :
      ( ! [Y4: int] :
          ( member(int,Y4,top_top(set(int)))
         => aa(code_integer,$o,P,aa(int,code_integer,code_integer_of_int,Y4)) )
     => aa(code_integer,$o,P,X2) ) ).

% integer_of_int_induct
tff(fact_2348_integer__of__int__cases,axiom,
    ! [X2: code_integer] :
      ~ ! [Y4: int] :
          ( ( X2 = aa(int,code_integer,code_integer_of_int,Y4) )
         => ~ member(int,Y4,top_top(set(int))) ) ).

% integer_of_int_cases
tff(fact_2349_subset__card__intvl__is__intvl,axiom,
    ! [A4: set(nat),K: nat] :
      ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),A4),set_or7035219750837199246ssThan(nat,K,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),finite_card(nat,A4))))
     => ( A4 = set_or7035219750837199246ssThan(nat,K,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),finite_card(nat,A4))) ) ) ).

% subset_card_intvl_is_intvl
tff(fact_2350_integer__of__int__inverse,axiom,
    ! [Y: int] :
      ( member(int,Y,top_top(set(int)))
     => ( aa(code_integer,int,code_int_of_integer,aa(int,code_integer,code_integer_of_int,Y)) = Y ) ) ).

% integer_of_int_inverse
tff(fact_2351_subset__eq__atLeast0__lessThan__card,axiom,
    ! [N5: set(nat),N: nat] :
      ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),N5),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(nat,N5)),N) ) ).

% subset_eq_atLeast0_lessThan_card
tff(fact_2352_integer__of__nat__eq__of__nat,axiom,
    code_integer_of_nat = semiring_1_of_nat(code_integer) ).

% integer_of_nat_eq_of_nat
tff(fact_2353_card__less__Suc2,axiom,
    ! [M2: set(nat),I: nat] :
      ( ~ member(nat,zero_zero(nat),M2)
     => ( finite_card(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_ih(set(nat),fun(nat,fun(nat,$o)),M2),I))) = finite_card(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_ii(set(nat),fun(nat,fun(nat,$o)),M2),I))) ) ) ).

% card_less_Suc2
tff(fact_2354_card__less__Suc,axiom,
    ! [M2: set(nat),I: nat] :
      ( member(nat,zero_zero(nat),M2)
     => ( aa(nat,nat,suc,finite_card(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_ih(set(nat),fun(nat,fun(nat,$o)),M2),I)))) = finite_card(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_ii(set(nat),fun(nat,fun(nat,$o)),M2),I))) ) ) ).

% card_less_Suc
tff(fact_2355_card__less,axiom,
    ! [M2: set(nat),I: nat] :
      ( member(nat,zero_zero(nat),M2)
     => ( finite_card(nat,aa(fun(nat,$o),set(nat),collect(nat),aa(nat,fun(nat,$o),aTP_Lamp_ii(set(nat),fun(nat,fun(nat,$o)),M2),I))) != zero_zero(nat) ) ) ).

% card_less
tff(fact_2356_integer__of__nat__0,axiom,
    aa(nat,code_integer,code_integer_of_nat,zero_zero(nat)) = zero_zero(code_integer) ).

% integer_of_nat_0
tff(fact_2357_integer__of__nat_Oabs__eq,axiom,
    ! [X2: nat] : aa(nat,code_integer,code_integer_of_nat,X2) = aa(int,code_integer,code_integer_of_int,aa(nat,int,semiring_1_of_nat(int),X2)) ).

% integer_of_nat.abs_eq
tff(fact_2358_integer__of__nat__numeral,axiom,
    ! [N: num] : aa(nat,code_integer,code_integer_of_nat,aa(num,nat,numeral_numeral(nat),N)) = aa(num,code_integer,numeral_numeral(code_integer),N) ).

% integer_of_nat_numeral
tff(fact_2359_integer__of__nat__1,axiom,
    aa(nat,code_integer,code_integer_of_nat,one_one(nat)) = one_one(code_integer) ).

% integer_of_nat_1
tff(fact_2360_card__sum__le__nat__sum,axiom,
    ! [S2: set(nat)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_bz(nat,nat)),set_or7035219750837199246ssThan(nat,zero_zero(nat),finite_card(nat,S2)))),aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7311177749621191930dd_sum(nat,nat),aTP_Lamp_bz(nat,nat)),S2)) ).

% card_sum_le_nat_sum
tff(fact_2361_set__encode__insert,axiom,
    ! [A4: set(nat),N: nat] :
      ( finite_finite2(nat,A4)
     => ( ~ member(nat,N,A4)
       => ( nat_set_encode(aa(set(nat),set(nat),insert2(nat,N),A4)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)),nat_set_encode(A4)) ) ) ) ).

% set_encode_insert
tff(fact_2362_card__greaterThanLessThan__int,axiom,
    ! [L: int,U: int] : finite_card(int,set_or5935395276787703475ssThan(int,L,U)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),minus_minus(int),U),aa(int,int,aa(int,fun(int,int),plus_plus(int),L),one_one(int)))) ).

% card_greaterThanLessThan_int
tff(fact_2363_wmax__insertI,axiom,
    ! [Y: product_prod(nat,nat),YS: set(product_prod(nat,nat)),X2: product_prod(nat,nat),XS: set(product_prod(nat,nat))] :
      ( member(product_prod(nat,nat),Y,YS)
     => ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X2),Y),fun_pair_leq)
       => ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),XS),YS),fun_max_weak)
         => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),set(product_prod(nat,nat)),insert2(product_prod(nat,nat),X2),XS)),YS),fun_max_weak) ) ) ) ).

% wmax_insertI
tff(fact_2364_wmin__insertI,axiom,
    ! [X2: product_prod(nat,nat),XS: set(product_prod(nat,nat)),Y: product_prod(nat,nat),YS: set(product_prod(nat,nat))] :
      ( member(product_prod(nat,nat),X2,XS)
     => ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X2),Y),fun_pair_leq)
       => ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),XS),YS),fun_min_weak)
         => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),XS),aa(set(product_prod(nat,nat)),set(product_prod(nat,nat)),insert2(product_prod(nat,nat),Y),YS)),fun_min_weak) ) ) ) ).

% wmin_insertI
tff(fact_2365_smin__insertI,axiom,
    ! [X2: product_prod(nat,nat),XS: set(product_prod(nat,nat)),Y: product_prod(nat,nat),YS: set(product_prod(nat,nat))] :
      ( member(product_prod(nat,nat),X2,XS)
     => ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X2),Y),fun_pair_less)
       => ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),XS),YS),fun_min_strict)
         => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),XS),aa(set(product_prod(nat,nat)),set(product_prod(nat,nat)),insert2(product_prod(nat,nat),Y),YS)),fun_min_strict) ) ) ) ).

% smin_insertI
tff(fact_2366_prod_Oinsert_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [I4: set(B),P3: fun(B,C),I: B] :
          ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hx(set(B),fun(fun(B,C),fun(B,$o)),I4),P3)))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),P3),aa(set(B),set(B),insert2(B,I),I4)) = $ite(member(B,I,I4),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),P3),I4),aa(C,C,aa(C,fun(C,C),times_times(C),aa(B,C,P3,I)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),P3),I4))) ) ) ) ).

% prod.insert'
tff(fact_2367_greaterThanLessThan__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,L: B,U: B] :
          ( member(B,I,set_or5935395276787703475ssThan(B,L,U))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),I)
            & aa(B,$o,aa(B,fun(B,$o),ord_less(B),I),U) ) ) ) ).

% greaterThanLessThan_iff
tff(fact_2368_finite__greaterThanLessThan__int,axiom,
    ! [L: int,U: int] : finite_finite2(int,set_or5935395276787703475ssThan(int,L,U)) ).

% finite_greaterThanLessThan_int
tff(fact_2369_greaterThanLessThan__empty__iff2,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( ( bot_bot(set(B)) = set_or5935395276787703475ssThan(B,A3,B2) )
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ).

% greaterThanLessThan_empty_iff2
tff(fact_2370_greaterThanLessThan__empty__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( ( set_or5935395276787703475ssThan(B,A3,B2) = bot_bot(set(B)) )
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3) ) ) ).

% greaterThanLessThan_empty_iff
tff(fact_2371_greaterThanLessThan__empty,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,K: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),K)
         => ( set_or5935395276787703475ssThan(B,K,L) = bot_bot(set(B)) ) ) ) ).

% greaterThanLessThan_empty
tff(fact_2372_infinite__Ioo__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( ~ finite_finite2(B,set_or5935395276787703475ssThan(B,A3,B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% infinite_Ioo_iff
tff(fact_2373_image__uminus__greaterThanLessThan,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B,Y: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),set_or5935395276787703475ssThan(B,X2,Y)) = set_or5935395276787703475ssThan(B,aa(B,B,uminus_uminus(B),Y),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_greaterThanLessThan
tff(fact_2374_prod_Oempty_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [P3: fun(C,B)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups1962203154675924110t_prod(C,B),P3),bot_bot(set(C))) = one_one(B) ) ).

% prod.empty'
tff(fact_2375_smin__emptyI,axiom,
    ! [X7: set(product_prod(nat,nat))] :
      ( ( X7 != bot_bot(set(product_prod(nat,nat))) )
     => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),X7),bot_bot(set(product_prod(nat,nat)))),fun_min_strict) ) ).

% smin_emptyI
tff(fact_2376_wmax__emptyI,axiom,
    ! [X7: set(product_prod(nat,nat))] :
      ( finite_finite2(product_prod(nat,nat),X7)
     => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),bot_bot(set(product_prod(nat,nat)))),X7),fun_max_weak) ) ).

% wmax_emptyI
tff(fact_2377_wmin__emptyI,axiom,
    ! [X7: set(product_prod(nat,nat))] : member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),X7),bot_bot(set(product_prod(nat,nat)))),fun_min_weak) ).

% wmin_emptyI
tff(fact_2378_prod_Onon__neutral_H,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(C,B),I4: set(C)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups1962203154675924110t_prod(C,B),G),aa(fun(C,$o),set(C),collect(C),aa(set(C),fun(C,$o),aTP_Lamp_ij(fun(C,B),fun(set(C),fun(C,$o)),G),I4))) = aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups1962203154675924110t_prod(C,B),G),I4) ) ).

% prod.non_neutral'
tff(fact_2379_infinite__Ioo,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ~ finite_finite2(B,set_or5935395276787703475ssThan(B,A3,B2)) ) ) ).

% infinite_Ioo
tff(fact_2380_greaterThanLessThan__subseteq__greaterThanLessThan,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or5935395276787703475ssThan(B,A3,B2)),set_or5935395276787703475ssThan(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% greaterThanLessThan_subseteq_greaterThanLessThan
tff(fact_2381_prod__decode__aux_Ocases,axiom,
    ! [X2: product_prod(nat,nat)] :
      ~ ! [K3: nat,M4: nat] : X2 != aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),K3),M4) ).

% prod_decode_aux.cases
tff(fact_2382_atLeastPlusOneLessThan__greaterThanLessThan__int,axiom,
    ! [L: int,U: int] : set_or7035219750837199246ssThan(int,aa(int,int,aa(int,fun(int,int),plus_plus(int),L),one_one(int)),U) = set_or5935395276787703475ssThan(int,L,U) ).

% atLeastPlusOneLessThan_greaterThanLessThan_int
tff(fact_2383_prod_Omono__neutral__left_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),T5: set(B),G: fun(B,C)] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
         => ( ! [X3: B] :
                ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
               => ( aa(B,C,G,X3) = one_one(C) ) )
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),S2) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),T5) ) ) ) ) ).

% prod.mono_neutral_left'
tff(fact_2384_prod_Omono__neutral__right_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),T5: set(B),G: fun(B,C)] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
         => ( ! [X3: B] :
                ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
               => ( aa(B,C,G,X3) = one_one(C) ) )
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),T5) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),S2) ) ) ) ) ).

% prod.mono_neutral_right'
tff(fact_2385_prod_Omono__neutral__cong__left_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),T5: set(B),Ha: fun(B,C),G: fun(B,C)] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
         => ( ! [I2: B] :
                ( member(B,I2,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
               => ( aa(B,C,Ha,I2) = one_one(C) ) )
           => ( ! [X3: B] :
                  ( member(B,X3,S2)
                 => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),S2) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),Ha),T5) ) ) ) ) ) ).

% prod.mono_neutral_cong_left'
tff(fact_2386_prod_Omono__neutral__cong__right_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [S2: set(B),T5: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),T5)
         => ( ! [X3: B] :
                ( member(B,X3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
               => ( aa(B,C,G,X3) = one_one(C) ) )
           => ( ! [X3: B] :
                  ( member(B,X3,S2)
                 => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),T5) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),Ha),S2) ) ) ) ) ) ).

% prod.mono_neutral_cong_right'
tff(fact_2387_prod_Odistrib_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [I4: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hx(set(B),fun(fun(B,C),fun(B,$o)),I4),G)))
         => ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hx(set(B),fun(fun(B,C),fun(B,$o)),I4),Ha)))
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),aa(fun(B,C),fun(B,C),aTP_Lamp_ik(fun(B,C),fun(fun(B,C),fun(B,C)),G),Ha)),I4) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),G),I4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1962203154675924110t_prod(B,C),Ha),I4)) ) ) ) ) ).

% prod.distrib'
tff(fact_2388_prod_OG__def,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [P3: fun(C,B),I4: set(C)] :
          aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups1962203154675924110t_prod(C,B),P3),I4) = $ite(finite_finite2(C,aa(fun(C,$o),set(C),collect(C),aa(set(C),fun(C,$o),aTP_Lamp_ij(fun(C,B),fun(set(C),fun(C,$o)),P3),I4))),aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),P3),aa(fun(C,$o),set(C),collect(C),aa(set(C),fun(C,$o),aTP_Lamp_ij(fun(C,B),fun(set(C),fun(C,$o)),P3),I4))),one_one(B)) ) ).

% prod.G_def
tff(fact_2389_greaterThanLessThan__subseteq__atLeastAtMost__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or5935395276787703475ssThan(B,A3,B2)),set_or1337092689740270186AtMost(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% greaterThanLessThan_subseteq_atLeastAtMost_iff
tff(fact_2390_greaterThanLessThan__subseteq__atLeastLessThan__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or5935395276787703475ssThan(B,A3,B2)),set_or7035219750837199246ssThan(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% greaterThanLessThan_subseteq_atLeastLessThan_iff
tff(fact_2391_atLeastAtMost__diff__ends,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),set_or1337092689740270186AtMost(B,A3,B2)),aa(set(B),set(B),insert2(B,A3),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))) = set_or5935395276787703475ssThan(B,A3,B2) ) ).

% atLeastAtMost_diff_ends
tff(fact_2392_smax__insertI,axiom,
    ! [Y: product_prod(nat,nat),Y7: set(product_prod(nat,nat)),X2: product_prod(nat,nat),X7: set(product_prod(nat,nat))] :
      ( member(product_prod(nat,nat),Y,Y7)
     => ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X2),Y),fun_pair_less)
       => ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),X7),Y7),fun_max_strict)
         => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),set(product_prod(nat,nat)),insert2(product_prod(nat,nat),X2),X7)),Y7),fun_max_strict) ) ) ) ).

% smax_insertI
tff(fact_2393_set__decode__plus__power__2,axiom,
    ! [N: nat,Z2: nat] :
      ( ~ member(nat,N,nat_set_decode(Z2))
     => ( nat_set_decode(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)),Z2)) = aa(set(nat),set(nat),insert2(nat,N),nat_set_decode(Z2)) ) ) ).

% set_decode_plus_power_2
tff(fact_2394_prod__decode__aux_Osimps,axiom,
    ! [K: nat,M: nat] :
      nat_prod_decode_aux(K,M) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),K),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),M),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),K),M)),nat_prod_decode_aux(aa(nat,nat,suc,K),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),M),aa(nat,nat,suc,K)))) ).

% prod_decode_aux.simps
tff(fact_2395_prod__decode__aux_Oelims,axiom,
    ! [X2: nat,Xa: nat,Y: product_prod(nat,nat)] :
      ( ( nat_prod_decode_aux(X2,Xa) = Y )
     => ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Xa),X2),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),Xa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),X2),Xa)),nat_prod_decode_aux(aa(nat,nat,suc,X2),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Xa),aa(nat,nat,suc,X2)))) ) ) ).

% prod_decode_aux.elims
tff(fact_2396_min__rpair__set,axiom,
    fun_reduction_pair(set(product_prod(nat,nat)),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_prod(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),fun(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_prod(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))))),product_Pair(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),fun_min_strict),fun_min_weak)) ).

% min_rpair_set
tff(fact_2397_triangle__Suc,axiom,
    ! [N: nat] : nat_triangle(aa(nat,nat,suc,N)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_triangle(N)),aa(nat,nat,suc,N)) ).

% triangle_Suc
tff(fact_2398_finite__greaterThanLessThan,axiom,
    ! [L: nat,U: nat] : finite_finite2(nat,set_or5935395276787703475ssThan(nat,L,U)) ).

% finite_greaterThanLessThan
tff(fact_2399_finite__greaterThanLessThan__integer,axiom,
    ! [L: code_integer,U: code_integer] : finite_finite2(code_integer,set_or5935395276787703475ssThan(code_integer,L,U)) ).

% finite_greaterThanLessThan_integer
tff(fact_2400_card__greaterThanLessThan,axiom,
    ! [L: nat,U: nat] : finite_card(nat,set_or5935395276787703475ssThan(nat,L,U)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),U),aa(nat,nat,suc,L)) ).

% card_greaterThanLessThan
tff(fact_2401_max__rpair__set,axiom,
    fun_reduction_pair(set(product_prod(nat,nat)),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_prod(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),fun(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_prod(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))))),product_Pair(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),fun_max_strict),fun_max_weak)) ).

% max_rpair_set
tff(fact_2402_atLeastSucLessThan__greaterThanLessThan,axiom,
    ! [L: nat,U: nat] : set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,L),U) = set_or5935395276787703475ssThan(nat,L,U) ).

% atLeastSucLessThan_greaterThanLessThan
tff(fact_2403_smax__emptyI,axiom,
    ! [Y7: set(product_prod(nat,nat))] :
      ( finite_finite2(product_prod(nat,nat),Y7)
     => ( ( Y7 != bot_bot(set(product_prod(nat,nat))) )
       => member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),bot_bot(set(product_prod(nat,nat)))),Y7),fun_max_strict) ) ) ).

% smax_emptyI
tff(fact_2404_atLeastPlusOneLessThan__greaterThanLessThan__integer,axiom,
    ! [L: code_integer,U: code_integer] : set_or7035219750837199246ssThan(code_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),L),one_one(code_integer)),U) = set_or5935395276787703475ssThan(code_integer,L,U) ).

% atLeastPlusOneLessThan_greaterThanLessThan_integer
tff(fact_2405_prod__decode__aux_Opelims,axiom,
    ! [X2: nat,Xa: nat,Y: product_prod(nat,nat)] :
      ( ( nat_prod_decode_aux(X2,Xa) = Y )
     => ( aa(product_prod(nat,nat),$o,accp(product_prod(nat,nat),nat_pr5047031295181774490ux_rel),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Xa))
       => ~ ( ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Xa),X2),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),Xa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),X2),Xa)),nat_prod_decode_aux(aa(nat,nat,suc,X2),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Xa),aa(nat,nat,suc,X2)))) )
           => ~ aa(product_prod(nat,nat),$o,accp(product_prod(nat,nat),nat_pr5047031295181774490ux_rel),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Xa)) ) ) ) ).

% prod_decode_aux.pelims
tff(fact_2406_total__on__singleton,axiom,
    ! [B: $tType,X2: B] : total_on(B,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),X2)),bot_bot(set(product_prod(B,B))))) ).

% total_on_singleton
tff(fact_2407_prod__encode__prod__decode__aux,axiom,
    ! [K: nat,M: nat] : aa(product_prod(nat,nat),nat,nat_prod_encode,nat_prod_decode_aux(K,M)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_triangle(K)),M) ).

% prod_encode_prod_decode_aux
tff(fact_2408_sum_Oinsert_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [I4: set(B),P3: fun(B,C),I: B] :
          ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hv(set(B),fun(fun(B,C),fun(B,$o)),I4),P3)))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),P3),aa(set(B),set(B),insert2(B,I),I4)) = $ite(member(B,I,I4),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),P3),I4),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,P3,I)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),P3),I4))) ) ) ) ).

% sum.insert'
tff(fact_2409_max__ext_Omax__extI,axiom,
    ! [B: $tType,X7: set(B),Y7: set(B),R4: set(product_prod(B,B))] :
      ( finite_finite2(B,X7)
     => ( finite_finite2(B,Y7)
       => ( ( Y7 != bot_bot(set(B)) )
         => ( ! [X3: B] :
                ( member(B,X3,X7)
               => ? [Xa3: B] :
                    ( member(B,Xa3,Y7)
                    & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Xa3),R4) ) )
           => member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),X7),Y7),max_ext(B,R4)) ) ) ) ) ).

% max_ext.max_extI
tff(fact_2410_total__on__def,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( total_on(B,A4,R)
    <=> ! [X4: B] :
          ( member(B,X4,A4)
         => ! [Xa2: B] :
              ( member(B,Xa2,A4)
             => ( ( X4 != Xa2 )
               => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R)
                  | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),R) ) ) ) ) ) ).

% total_on_def
tff(fact_2411_total__onI,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,A4)
         => ( member(B,Y4,A4)
           => ( ( X3 != Y4 )
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R)
                | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),X3),R) ) ) ) )
     => total_on(B,A4,R) ) ).

% total_onI
tff(fact_2412_sum_Odistrib__triv_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [I4: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( finite_finite2(B,I4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),aa(fun(B,C),fun(B,C),aTP_Lamp_il(fun(B,C),fun(fun(B,C),fun(B,C)),G),Ha)),I4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),G),I4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),Ha),I4)) ) ) ) ).

% sum.distrib_triv'
tff(fact_2413_le__prod__encode__1,axiom,
    ! [A3: nat,B2: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),aa(product_prod(nat,nat),nat,nat_prod_encode,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),A3),B2))) ).

% le_prod_encode_1
tff(fact_2414_le__prod__encode__2,axiom,
    ! [B2: nat,A3: nat] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),B2),aa(product_prod(nat,nat),nat,nat_prod_encode,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),A3),B2))) ).

% le_prod_encode_2
tff(fact_2415_sum_Odistrib_H,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [I4: set(B),G: fun(B,C),Ha: fun(B,C)] :
          ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hv(set(B),fun(fun(B,C),fun(B,$o)),I4),G)))
         => ( finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_hv(set(B),fun(fun(B,C),fun(B,$o)),I4),Ha)))
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),aa(fun(B,C),fun(B,C),aTP_Lamp_il(fun(B,C),fun(fun(B,C),fun(B,C)),G),Ha)),I4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),G),I4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups1027152243600224163dd_sum(B,C),Ha),I4)) ) ) ) ) ).

% sum.distrib'
tff(fact_2416_prod__encode__def,axiom,
    nat_prod_encode = aa(fun(nat,fun(nat,nat)),fun(product_prod(nat,nat),nat),product_case_prod(nat,nat,nat),aTP_Lamp_im(nat,fun(nat,nat))) ).

% prod_encode_def
tff(fact_2417_max__ext_Ocases,axiom,
    ! [B: $tType,A1: set(B),A22: set(B),R4: set(product_prod(B,B))] :
      ( member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),A1),A22),max_ext(B,R4))
     => ~ ( finite_finite2(B,A1)
         => ( finite_finite2(B,A22)
           => ( ( A22 != bot_bot(set(B)) )
             => ~ ! [X: B] :
                    ( member(B,X,A1)
                   => ? [Xa4: B] :
                        ( member(B,Xa4,A22)
                        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa4),R4) ) ) ) ) ) ) ).

% max_ext.cases
tff(fact_2418_max__ext_Osimps,axiom,
    ! [B: $tType,A1: set(B),A22: set(B),R4: set(product_prod(B,B))] :
      ( member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),A1),A22),max_ext(B,R4))
    <=> ( finite_finite2(B,A1)
        & finite_finite2(B,A22)
        & ( A22 != bot_bot(set(B)) )
        & ! [X4: B] :
            ( member(B,X4,A1)
           => ? [Xa2: B] :
                ( member(B,Xa2,A22)
                & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R4) ) ) ) ) ).

% max_ext.simps
tff(fact_2419_max__extp__eq,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),X2: set(B),Y: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),max_extp(B,R),X2),Y)
    <=> member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),X2),Y),max_ext(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% max_extp_eq
tff(fact_2420_max__extp__max__ext__eq,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),X: set(B),Xa3: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),max_extp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R4)),X),Xa3)
    <=> member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),X),Xa3),max_ext(B,R4)) ) ).

% max_extp_max_ext_eq
tff(fact_2421_one__div__numeral,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),aa(num,B,numeral_numeral(B),N)) = aa(product_prod(B,B),B,product_fst(B,B),unique8689654367752047608divmod(B,one2,N)) ) ).

% one_div_numeral
tff(fact_2422_sqr_Osimps_I3_J,axiom,
    ! [N: num] : sqr(aa(num,num,bit1,N)) = aa(num,num,bit1,aa(num,num,bit0,aa(num,num,aa(num,fun(num,num),plus_plus(num),sqr(N)),N))) ).

% sqr.simps(3)
tff(fact_2423_one__mod__numeral,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [N: num] : aa(B,B,aa(B,fun(B,B),modulo_modulo(B),one_one(B)),aa(num,B,numeral_numeral(B),N)) = aa(product_prod(B,B),B,product_snd(B,B),unique8689654367752047608divmod(B,one2,N)) ) ).

% one_mod_numeral
tff(fact_2424_card__UNION,axiom,
    ! [B: $tType,A4: set(set(B))] :
      ( finite_finite2(set(B),A4)
     => ( ! [X3: set(B)] :
            ( member(set(B),X3,A4)
           => finite_finite2(B,X3) )
       => ( finite_card(B,aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),A4)) = aa(int,nat,nat2,aa(set(set(set(B))),int,aa(fun(set(set(B)),int),fun(set(set(set(B))),int),groups7311177749621191930dd_sum(set(set(B)),int),aTP_Lamp_io(set(set(B)),int)),aa(fun(set(set(B)),$o),set(set(set(B))),collect(set(set(B))),aTP_Lamp_ip(set(set(B)),fun(set(set(B)),$o),A4)))) ) ) ) ).

% card_UNION
tff(fact_2425_Sup__atMost,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [Y: B] : aa(set(B),B,complete_Sup_Sup(B),aa(B,set(B),set_ord_atMost(B),Y)) = Y ) ).

% Sup_atMost
tff(fact_2426_Sup__lessThan,axiom,
    ! [B: $tType] :
      ( ( comple6319245703460814977attice(B)
        & dense_linorder(B) )
     => ! [Y: B] : aa(set(B),B,complete_Sup_Sup(B),aa(B,set(B),set_ord_lessThan(B),Y)) = Y ) ).

% Sup_lessThan
tff(fact_2427_fst__apsnd,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),X2: product_prod(B,D)] : aa(product_prod(B,C),B,product_fst(B,C),aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),F),X2)) = aa(product_prod(B,D),B,product_fst(B,D),X2) ).

% fst_apsnd
tff(fact_2428_fst__comp__apsnd,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(C,D)] : aa(fun(product_prod(B,C),product_prod(B,D)),fun(product_prod(B,C),B),aa(fun(product_prod(B,D),B),fun(fun(product_prod(B,C),product_prod(B,D)),fun(product_prod(B,C),B)),comp(product_prod(B,D),B,product_prod(B,C)),product_fst(B,D)),aa(fun(C,D),fun(product_prod(B,C),product_prod(B,D)),product_apsnd(C,D,B),F)) = product_fst(B,C) ).

% fst_comp_apsnd
tff(fact_2429_apsnd__eq__conv,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),X2: product_prod(B,D),G: fun(D,C)] :
      ( ( aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),F),X2) = aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),G),X2) )
    <=> ( aa(D,C,F,aa(product_prod(B,D),D,product_snd(B,D),X2)) = aa(D,C,G,aa(product_prod(B,D),D,product_snd(B,D),X2)) ) ) ).

% apsnd_eq_conv
tff(fact_2430_snd__apsnd,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(D,B),X2: product_prod(C,D)] : aa(product_prod(C,B),B,product_snd(C,B),aa(product_prod(C,D),product_prod(C,B),aa(fun(D,B),fun(product_prod(C,D),product_prod(C,B)),product_apsnd(D,B,C),F),X2)) = aa(D,B,F,aa(product_prod(C,D),D,product_snd(C,D),X2)) ).

% snd_apsnd
tff(fact_2431_snd__comp__apsnd,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(C,D)] : aa(fun(product_prod(B,C),product_prod(B,D)),fun(product_prod(B,C),D),aa(fun(product_prod(B,D),D),fun(fun(product_prod(B,C),product_prod(B,D)),fun(product_prod(B,C),D)),comp(product_prod(B,D),D,product_prod(B,C)),product_snd(B,D)),aa(fun(C,D),fun(product_prod(B,C),product_prod(B,D)),product_apsnd(C,D,B),F)) = aa(fun(product_prod(B,C),C),fun(product_prod(B,C),D),aa(fun(C,D),fun(fun(product_prod(B,C),C),fun(product_prod(B,C),D)),comp(C,D,product_prod(B,C)),F),product_snd(B,C)) ).

% snd_comp_apsnd
tff(fact_2432_fst__divmod__integer,axiom,
    ! [K: code_integer,L: code_integer] : aa(product_prod(code_integer,code_integer),code_integer,product_fst(code_integer,code_integer),code_divmod_integer(K,L)) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),K),L) ).

% fst_divmod_integer
tff(fact_2433_snd__divmod__integer,axiom,
    ! [K: code_integer,L: code_integer] : aa(product_prod(code_integer,code_integer),code_integer,product_snd(code_integer,code_integer),code_divmod_integer(K,L)) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),K),L) ).

% snd_divmod_integer
tff(fact_2434_Sup__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y)
         => ( aa(set(B),B,complete_Sup_Sup(B),set_or1337092689740270186AtMost(B,X2,Y)) = Y ) ) ) ).

% Sup_atLeastAtMost
tff(fact_2435_Inf__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y)
         => ( complete_Inf_Inf(B,set_or1337092689740270186AtMost(B,X2,Y)) = X2 ) ) ) ).

% Inf_atLeastAtMost
tff(fact_2436_Sup__atLeastLessThan,axiom,
    ! [B: $tType] :
      ( ( comple6319245703460814977attice(B)
        & dense_linorder(B) )
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y)
         => ( aa(set(B),B,complete_Sup_Sup(B),set_or7035219750837199246ssThan(B,X2,Y)) = Y ) ) ) ).

% Sup_atLeastLessThan
tff(fact_2437_Inf__atLeastLessThan,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y)
         => ( complete_Inf_Inf(B,set_or7035219750837199246ssThan(B,X2,Y)) = X2 ) ) ) ).

% Inf_atLeastLessThan
tff(fact_2438_prod_Ocollapse,axiom,
    ! [C: $tType,B: $tType,Prod: product_prod(B,C)] : aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(product_prod(B,C),B,product_fst(B,C),Prod)),aa(product_prod(B,C),C,product_snd(B,C),Prod)) = Prod ).

% prod.collapse
tff(fact_2439_Inf__atMost,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B] : complete_Inf_Inf(B,aa(B,set(B),set_ord_atMost(B),X2)) = bot_bot(B) ) ).

% Inf_atMost
tff(fact_2440_Sup__greaterThanLessThan,axiom,
    ! [B: $tType] :
      ( ( comple6319245703460814977attice(B)
        & dense_linorder(B) )
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y)
         => ( aa(set(B),B,complete_Sup_Sup(B),set_or5935395276787703475ssThan(B,X2,Y)) = Y ) ) ) ).

% Sup_greaterThanLessThan
tff(fact_2441_img__fst,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,S2: set(product_prod(B,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),S2)
     => member(B,A3,aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),S2)) ) ).

% img_fst
tff(fact_2442_Inf__greaterThanLessThan,axiom,
    ! [B: $tType] :
      ( ( comple6319245703460814977attice(B)
        & dense_linorder(B) )
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y)
         => ( complete_Inf_Inf(B,set_or5935395276787703475ssThan(B,X2,Y)) = X2 ) ) ) ).

% Inf_greaterThanLessThan
tff(fact_2443_img__snd,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,S2: set(product_prod(B,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),S2)
     => member(C,B2,aa(set(product_prod(B,C)),set(C),image2(product_prod(B,C),C,product_snd(B,C)),S2)) ) ).

% img_snd
tff(fact_2444_fst__divmod__abs,axiom,
    ! [K: code_integer,L: code_integer] : aa(product_prod(code_integer,code_integer),code_integer,product_fst(code_integer,code_integer),code_divmod_abs(K,L)) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),divide_divide(code_integer),aa(code_integer,code_integer,abs_abs(code_integer),K)),aa(code_integer,code_integer,abs_abs(code_integer),L)) ).

% fst_divmod_abs
tff(fact_2445_snd__divmod__abs,axiom,
    ! [K: code_integer,L: code_integer] : aa(product_prod(code_integer,code_integer),code_integer,product_snd(code_integer,code_integer),code_divmod_abs(K,L)) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),modulo_modulo(code_integer),aa(code_integer,code_integer,abs_abs(code_integer),K)),aa(code_integer,code_integer,abs_abs(code_integer),L)) ).

% snd_divmod_abs
tff(fact_2446_Inf__atMostLessThan,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),top_top(B)),X2)
         => ( complete_Inf_Inf(B,aa(B,set(B),set_ord_lessThan(B),X2)) = bot_bot(B) ) ) ) ).

% Inf_atMostLessThan
tff(fact_2447_split__comp__eq,axiom,
    ! [C: $tType,D: $tType,E: $tType,B: $tType,F: fun(E,fun(C,D)),G: fun(B,E)] : aa(fun(B,E),fun(product_prod(B,C),D),aTP_Lamp_iq(fun(E,fun(C,D)),fun(fun(B,E),fun(product_prod(B,C),D)),F),G) = aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),aa(fun(B,E),fun(B,fun(C,D)),aTP_Lamp_ir(fun(E,fun(C,D)),fun(fun(B,E),fun(B,fun(C,D))),F),G)) ).

% split_comp_eq
tff(fact_2448_case__prod__beta_H,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,fun(C,D)),X: product_prod(B,C)] : aa(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F),X) = aa(C,D,aa(B,fun(C,D),F,aa(product_prod(B,C),B,product_fst(B,C),X)),aa(product_prod(B,C),C,product_snd(B,C),X)) ).

% case_prod_beta'
tff(fact_2449_case__prod__unfold,axiom,
    ! [D: $tType,C: $tType,B: $tType,X: fun(B,fun(C,D)),Xa3: product_prod(B,C)] : aa(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),X),Xa3) = aa(C,D,aa(B,fun(C,D),X,aa(product_prod(B,C),B,product_fst(B,C),Xa3)),aa(product_prod(B,C),C,product_snd(B,C),Xa3)) ).

% case_prod_unfold
tff(fact_2450_Product__Type_OCollect__case__prodD,axiom,
    ! [C: $tType,B: $tType,X2: product_prod(B,C),A4: fun(B,fun(C,$o))] :
      ( member(product_prod(B,C),X2,aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),A4)))
     => aa(C,$o,aa(B,fun(C,$o),A4,aa(product_prod(B,C),B,product_fst(B,C),X2)),aa(product_prod(B,C),C,product_snd(B,C),X2)) ) ).

% Product_Type.Collect_case_prodD
tff(fact_2451_case__prod__beta,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,fun(D,B)),P3: product_prod(C,D)] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),F),P3) = aa(D,B,aa(C,fun(D,B),F,aa(product_prod(C,D),C,product_fst(C,D),P3)),aa(product_prod(C,D),D,product_snd(C,D),P3)) ).

% case_prod_beta
tff(fact_2452_split__beta,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,fun(D,B)),Prod: product_prod(C,D)] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),F),Prod) = aa(D,B,aa(C,fun(D,B),F,aa(product_prod(C,D),C,product_fst(C,D),Prod)),aa(product_prod(C,D),D,product_snd(C,D),Prod)) ).

% split_beta
tff(fact_2453_effect__heapI,axiom,
    ! [B: $tType,N: nat,F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B] :
      ( ( N = aa(product_prod(heap_ext(product_unit),nat),nat,product_snd(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
     => ( ( H2 = aa(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit),product_fst(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
       => ( ( R = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),B,product_fst(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha)) )
         => heap_Time_effect(B,heap_Time_heap(B,F),Ha,H2,R,N) ) ) ) ).

% effect_heapI
tff(fact_2454_effect__heapE,axiom,
    ! [B: $tType,F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,heap_Time_heap(B,F),Ha,H2,R,N)
     => ~ ( ( H2 = aa(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit),product_fst(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
         => ( ( N = aa(product_prod(heap_ext(product_unit),nat),nat,product_snd(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
           => ( R != aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),B,product_fst(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha)) ) ) ) ) ).

% effect_heapE
tff(fact_2455_effect__guardI,axiom,
    ! [B: $tType,P: fun(heap_ext(product_unit),$o),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),N: nat,R: B] :
      ( aa(heap_ext(product_unit),$o,P,Ha)
     => ( ( H2 = aa(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit),product_fst(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
       => ( ( N = aa(product_prod(heap_ext(product_unit),nat),nat,product_snd(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
         => ( ( R = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),B,product_fst(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha)) )
           => heap_Time_effect(B,heap_Time_guard(B,P,F),Ha,H2,R,N) ) ) ) ) ).

% effect_guardI
tff(fact_2456_effect__guardE,axiom,
    ! [B: $tType,P: fun(heap_ext(product_unit),$o),F: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,heap_Time_guard(B,P,F),Ha,H2,R,N)
     => ~ ( ( H2 = aa(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit),product_fst(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
         => ( ( N = aa(product_prod(heap_ext(product_unit),nat),nat,product_snd(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha))) )
           => ( ( R = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),B,product_fst(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),F,Ha)) )
             => ~ aa(heap_ext(product_unit),$o,P,Ha) ) ) ) ) ).

% effect_guardE
tff(fact_2457_effectE,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
      ( heap_Time_effect(B,C2,Ha,H2,R,N)
     => ~ ( ( R = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),B,product_fst(B,product_prod(heap_ext(product_unit),nat)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(B,product_prod(heap_ext(product_unit),nat)),the2(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha))) )
         => ( ( H2 = aa(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit),product_fst(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(B,product_prod(heap_ext(product_unit),nat)),the2(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha)))) )
           => ( ( N = aa(product_prod(heap_ext(product_unit),nat),nat,product_snd(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(B,product_prod(heap_ext(product_unit),nat)),the2(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha)))) )
             => ~ heap_Time_success(B,C2,Ha) ) ) ) ) ).

% effectE
tff(fact_2458_prod__eq__iff,axiom,
    ! [C: $tType,B: $tType,S: product_prod(B,C),T2: product_prod(B,C)] :
      ( ( S = T2 )
    <=> ( ( aa(product_prod(B,C),B,product_fst(B,C),S) = aa(product_prod(B,C),B,product_fst(B,C),T2) )
        & ( aa(product_prod(B,C),C,product_snd(B,C),S) = aa(product_prod(B,C),C,product_snd(B,C),T2) ) ) ) ).

% prod_eq_iff
tff(fact_2459_prod__eqI,axiom,
    ! [C: $tType,B: $tType,P3: product_prod(B,C),Q3: product_prod(B,C)] :
      ( ( aa(product_prod(B,C),B,product_fst(B,C),P3) = aa(product_prod(B,C),B,product_fst(B,C),Q3) )
     => ( ( aa(product_prod(B,C),C,product_snd(B,C),P3) = aa(product_prod(B,C),C,product_snd(B,C),Q3) )
       => ( P3 = Q3 ) ) ) ).

% prod_eqI
tff(fact_2460_prod_Oexpand,axiom,
    ! [C: $tType,B: $tType,Prod: product_prod(B,C),Prod2: product_prod(B,C)] :
      ( ( ( aa(product_prod(B,C),B,product_fst(B,C),Prod) = aa(product_prod(B,C),B,product_fst(B,C),Prod2) )
        & ( aa(product_prod(B,C),C,product_snd(B,C),Prod) = aa(product_prod(B,C),C,product_snd(B,C),Prod2) ) )
     => ( Prod = Prod2 ) ) ).

% prod.expand
tff(fact_2461_All__prod__contract,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o))] :
      ( ! [A7: B,X_1: C] : aa(C,$o,aa(B,fun(C,$o),P,A7),X_1)
    <=> ! [Z4: product_prod(B,C)] : aa(C,$o,aa(B,fun(C,$o),P,aa(product_prod(B,C),B,product_fst(B,C),Z4)),aa(product_prod(B,C),C,product_snd(B,C),Z4)) ) ).

% All_prod_contract
tff(fact_2462_Ex__prod__contract,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o))] :
      ( ? [A7: B,X_1: C] : aa(C,$o,aa(B,fun(C,$o),P,A7),X_1)
    <=> ? [Z4: product_prod(B,C)] : aa(C,$o,aa(B,fun(C,$o),P,aa(product_prod(B,C),B,product_fst(B,C),Z4)),aa(product_prod(B,C),C,product_snd(B,C),Z4)) ) ).

% Ex_prod_contract
tff(fact_2463_prod_Osplit__sel,axiom,
    ! [B: $tType,D: $tType,C: $tType,P: fun(B,$o),F: fun(C,fun(D,B)),Prod: product_prod(C,D)] :
      ( aa(B,$o,P,aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),F),Prod))
    <=> ( ( Prod = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(product_prod(C,D),C,product_fst(C,D),Prod)),aa(product_prod(C,D),D,product_snd(C,D),Prod)) )
       => aa(B,$o,P,aa(D,B,aa(C,fun(D,B),F,aa(product_prod(C,D),C,product_fst(C,D),Prod)),aa(product_prod(C,D),D,product_snd(C,D),Prod))) ) ) ).

% prod.split_sel
tff(fact_2464_prod_Osplit__sel__asm,axiom,
    ! [B: $tType,D: $tType,C: $tType,P: fun(B,$o),F: fun(C,fun(D,B)),Prod: product_prod(C,D)] :
      ( aa(B,$o,P,aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),F),Prod))
    <=> ~ ( ( Prod = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(product_prod(C,D),C,product_fst(C,D),Prod)),aa(product_prod(C,D),D,product_snd(C,D),Prod)) )
          & ~ aa(B,$o,P,aa(D,B,aa(C,fun(D,B),F,aa(product_prod(C,D),C,product_fst(C,D),Prod)),aa(product_prod(C,D),D,product_snd(C,D),Prod))) ) ) ).

% prod.split_sel_asm
tff(fact_2465_surjective__pairing,axiom,
    ! [C: $tType,B: $tType,T2: product_prod(B,C)] : T2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(product_prod(B,C),B,product_fst(B,C),T2)),aa(product_prod(B,C),C,product_snd(B,C),T2)) ).

% surjective_pairing
tff(fact_2466_prod_Oexhaust__sel,axiom,
    ! [C: $tType,B: $tType,Prod: product_prod(B,C)] : Prod = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(product_prod(B,C),B,product_fst(B,C),Prod)),aa(product_prod(B,C),C,product_snd(B,C),Prod)) ).

% prod.exhaust_sel
tff(fact_2467_exI__realizer,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o)),Y: B,X2: C] :
      ( aa(C,$o,aa(B,fun(C,$o),P,Y),X2)
     => aa(C,$o,aa(B,fun(C,$o),P,aa(product_prod(C,B),B,product_snd(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y))),aa(product_prod(C,B),C,product_fst(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y))) ) ).

% exI_realizer
tff(fact_2468_conjI__realizer,axiom,
    ! [B: $tType,C: $tType,P: fun(B,$o),P3: B,Q: fun(C,$o),Q3: C] :
      ( aa(B,$o,P,P3)
     => ( aa(C,$o,Q,Q3)
       => ( aa(B,$o,P,aa(product_prod(B,C),B,product_fst(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),P3),Q3)))
          & aa(C,$o,Q,aa(product_prod(B,C),C,product_snd(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),P3),Q3))) ) ) ) ).

% conjI_realizer
tff(fact_2469_execute__bind__success,axiom,
    ! [C: $tType,B: $tType,F: heap_Time_Heap(B),Ha: heap_ext(product_unit),G: fun(B,heap_Time_Heap(C))] :
      ( heap_Time_success(B,F,Ha)
     => ( aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),heap_Time_bind(B,C,F,G)),Ha) = heap_Time_timeFrame(C,aa(product_prod(heap_ext(product_unit),nat),nat,product_snd(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(B,product_prod(heap_ext(product_unit),nat)),the2(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha)))),aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),aa(B,heap_Time_Heap(C),G,aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),B,product_fst(B,product_prod(heap_ext(product_unit),nat)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(B,product_prod(heap_ext(product_unit),nat)),the2(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha))))),aa(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit),product_fst(heap_ext(product_unit),nat),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(heap_ext(product_unit),nat),product_snd(B,product_prod(heap_ext(product_unit),nat)),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(B,product_prod(heap_ext(product_unit),nat)),the2(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),F),Ha)))))) ) ) ).

% execute_bind_success
tff(fact_2470_sndI,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(B,C),Y: B,Z2: C] :
      ( ( X2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y),Z2) )
     => ( aa(product_prod(B,C),C,product_snd(B,C),X2) = Z2 ) ) ).

% sndI
tff(fact_2471_sndE,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(B,C),A3: B,B2: C,P: fun(C,$o)] :
      ( ( X2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2) )
     => ( aa(C,$o,P,aa(product_prod(B,C),C,product_snd(B,C),X2))
       => aa(C,$o,P,B2) ) ) ).

% sndE
tff(fact_2472_snd__eqD,axiom,
    ! [C: $tType,B: $tType,X2: C,Y: B,A3: B] :
      ( ( aa(product_prod(C,B),B,product_snd(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y)) = A3 )
     => ( Y = A3 ) ) ).

% snd_eqD
tff(fact_2473_snd__conv,axiom,
    ! [C: $tType,B: $tType,X1: C,X22: B] : aa(product_prod(C,B),B,product_snd(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X1),X22)) = X22 ).

% snd_conv
tff(fact_2474_Some__Inf,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [A4: set(B)] : aa(B,option(B),some(B),complete_Inf_Inf(B,A4)) = complete_Inf_Inf(option(B),aa(set(B),set(option(B)),image2(B,option(B),some(B)),A4)) ) ).

% Some_Inf
tff(fact_2475_fstI,axiom,
    ! [C: $tType,B: $tType,X2: product_prod(B,C),Y: B,Z2: C] :
      ( ( X2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y),Z2) )
     => ( aa(product_prod(B,C),B,product_fst(B,C),X2) = Y ) ) ).

% fstI
tff(fact_2476_fstE,axiom,
    ! [C: $tType,B: $tType,X2: product_prod(B,C),A3: B,B2: C,P: fun(B,$o)] :
      ( ( X2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2) )
     => ( aa(B,$o,P,aa(product_prod(B,C),B,product_fst(B,C),X2))
       => aa(B,$o,P,A3) ) ) ).

% fstE
tff(fact_2477_fst__eqD,axiom,
    ! [C: $tType,B: $tType,X2: B,Y: C,A3: B] :
      ( ( aa(product_prod(B,C),B,product_fst(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)) = A3 )
     => ( X2 = A3 ) ) ).

% fst_eqD
tff(fact_2478_fst__conv,axiom,
    ! [C: $tType,B: $tType,X1: B,X22: C] : aa(product_prod(B,C),B,product_fst(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X1),X22)) = X1 ).

% fst_conv
tff(fact_2479_snd__fst__flip,axiom,
    ! [B: $tType,C: $tType,Xy: product_prod(C,B)] : aa(product_prod(C,B),B,product_snd(C,B),Xy) = aa(product_prod(C,B),B,aa(fun(product_prod(C,B),product_prod(B,C)),fun(product_prod(C,B),B),aa(fun(product_prod(B,C),B),fun(fun(product_prod(C,B),product_prod(B,C)),fun(product_prod(C,B),B)),comp(product_prod(B,C),B,product_prod(C,B)),product_fst(B,C)),aa(fun(C,fun(B,product_prod(B,C))),fun(product_prod(C,B),product_prod(B,C)),product_case_prod(C,B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))))),Xy) ).

% snd_fst_flip
tff(fact_2480_fst__snd__flip,axiom,
    ! [C: $tType,B: $tType,Xy: product_prod(B,C)] : aa(product_prod(B,C),B,product_fst(B,C),Xy) = aa(product_prod(B,C),B,aa(fun(product_prod(B,C),product_prod(C,B)),fun(product_prod(B,C),B),aa(fun(product_prod(C,B),B),fun(fun(product_prod(B,C),product_prod(C,B)),fun(product_prod(B,C),B)),comp(product_prod(C,B),B,product_prod(B,C)),product_snd(C,B)),aa(fun(B,fun(C,product_prod(C,B))),fun(product_prod(B,C),product_prod(C,B)),product_case_prod(B,C,product_prod(C,B)),aTP_Lamp_it(B,fun(C,product_prod(C,B))))),Xy) ).

% fst_snd_flip
tff(fact_2481_finite__UNION__then__finite,axiom,
    ! [B: $tType,C: $tType,B5: fun(C,set(B)),A4: set(C),A3: C] :
      ( finite_finite2(B,aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(C),set(set(B)),image2(C,set(B),B5),A4)))
     => ( member(C,A3,A4)
       => finite_finite2(B,aa(C,set(B),B5,A3)) ) ) ).

% finite_UNION_then_finite
tff(fact_2482_case__prod__comp,axiom,
    ! [E: $tType,B: $tType,D: $tType,C: $tType,F: fun(E,fun(D,B)),G: fun(C,E),X2: product_prod(C,D)] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),aa(fun(C,E),fun(C,fun(D,B)),aa(fun(E,fun(D,B)),fun(fun(C,E),fun(C,fun(D,B))),comp(E,fun(D,B),C),F),G)),X2) = aa(D,B,aa(E,fun(D,B),F,aa(C,E,G,aa(product_prod(C,D),C,product_fst(C,D),X2))),aa(product_prod(C,D),D,product_snd(C,D),X2)) ).

% case_prod_comp
tff(fact_2483_fn__snd__conv,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,D)] : aTP_Lamp_iu(fun(C,D),fun(product_prod(B,C),D),F) = aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),aTP_Lamp_iv(fun(C,D),fun(B,fun(C,D)),F)) ).

% fn_snd_conv
tff(fact_2484_snd__def,axiom,
    ! [B: $tType,C: $tType,Prod: product_prod(C,B)] : aa(product_prod(C,B),B,product_snd(C,B),Prod) = aa(product_prod(C,B),B,aa(fun(C,fun(B,B)),fun(product_prod(C,B),B),product_case_prod(C,B,B),aTP_Lamp_iw(C,fun(B,B))),Prod) ).

% snd_def
tff(fact_2485_fn__fst__conv,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,D)] : aTP_Lamp_ix(fun(B,D),fun(product_prod(B,C),D),F) = aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),aTP_Lamp_iy(fun(B,D),fun(B,fun(C,D)),F)) ).

% fn_fst_conv
tff(fact_2486_fst__def,axiom,
    ! [C: $tType,B: $tType,Prod: product_prod(B,C)] : aa(product_prod(B,C),B,product_fst(B,C),Prod) = aa(product_prod(B,C),B,aa(fun(B,fun(C,B)),fun(product_prod(B,C),B),product_case_prod(B,C,B),aTP_Lamp_iz(B,fun(C,B))),Prod) ).

% fst_def
tff(fact_2487_Collect__split__mono__strong,axiom,
    ! [C: $tType,B: $tType,X7: set(B),A4: set(product_prod(B,C)),Y7: set(C),P: fun(B,fun(C,$o)),Q: fun(B,fun(C,$o))] :
      ( ( X7 = aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),A4) )
     => ( ( Y7 = aa(set(product_prod(B,C)),set(C),image2(product_prod(B,C),C,product_snd(B,C)),A4) )
       => ( ! [X3: B] :
              ( member(B,X3,X7)
             => ! [Xa4: C] :
                  ( member(C,Xa4,Y7)
                 => ( aa(C,$o,aa(B,fun(C,$o),P,X3),Xa4)
                   => aa(C,$o,aa(B,fun(C,$o),Q,X3),Xa4) ) ) )
         => ( aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),A4),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),P)))
           => aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),A4),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),Q))) ) ) ) ) ).

% Collect_split_mono_strong
tff(fact_2488_Some__Sup,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [A4: set(B)] :
          ( ( A4 != bot_bot(set(B)) )
         => ( aa(B,option(B),some(B),aa(set(B),B,complete_Sup_Sup(B),A4)) = aa(set(option(B)),option(B),complete_Sup_Sup(option(B)),aa(set(B),set(option(B)),image2(B,option(B),some(B)),A4)) ) ) ) ).

% Some_Sup
tff(fact_2489_Inf__option__def,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [A4: set(option(B))] :
          complete_Inf_Inf(option(B),A4) = $ite(member(option(B),none(B),A4),none(B),aa(B,option(B),some(B),complete_Inf_Inf(B,these(B,A4)))) ) ).

% Inf_option_def
tff(fact_2490_Some__INF,axiom,
    ! [B: $tType,C: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [F: fun(C,B),A4: set(C)] : aa(B,option(B),some(B),complete_Inf_Inf(B,aa(set(C),set(B),image2(C,B,F),A4))) = complete_Inf_Inf(option(B),aa(set(C),set(option(B)),image2(C,option(B),aTP_Lamp_ja(fun(C,B),fun(C,option(B)),F)),A4)) ) ).

% Some_INF
tff(fact_2491_INF__image,axiom,
    ! [C: $tType,B: $tType,D: $tType] :
      ( complete_Inf(B)
     => ! [G: fun(C,B),F: fun(D,C),A4: set(D)] : complete_Inf_Inf(B,aa(set(C),set(B),image2(C,B,G),aa(set(D),set(C),image2(D,C,F),A4))) = complete_Inf_Inf(B,aa(set(D),set(B),image2(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),A4)) ) ).

% INF_image
tff(fact_2492_SUP__image,axiom,
    ! [C: $tType,B: $tType,D: $tType] :
      ( complete_Sup(B)
     => ! [G: fun(C,B),F: fun(D,C),A4: set(D)] : aa(set(B),B,complete_Sup_Sup(B),aa(set(C),set(B),image2(C,B,G),aa(set(D),set(C),image2(D,C,F),A4))) = aa(set(B),B,complete_Sup_Sup(B),aa(set(D),set(B),image2(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),A4)) ) ).

% SUP_image
tff(fact_2493_in__snd__imageE,axiom,
    ! [B: $tType,C: $tType,Y: B,S2: set(product_prod(C,B))] :
      ( member(B,Y,aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),S2))
     => ~ ! [X3: C] : ~ member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X3),Y),S2) ) ).

% in_snd_imageE
tff(fact_2494_in__fst__imageE,axiom,
    ! [C: $tType,B: $tType,X2: B,S2: set(product_prod(B,C))] :
      ( member(B,X2,aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),S2))
     => ~ ! [Y4: C] : ~ member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y4),S2) ) ).

% in_fst_imageE
tff(fact_2495_Some__SUP,axiom,
    ! [C: $tType,B: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [A4: set(B),F: fun(B,C)] :
          ( ( A4 != bot_bot(set(B)) )
         => ( aa(C,option(C),some(C),aa(set(C),C,complete_Sup_Sup(C),aa(set(B),set(C),image2(B,C,F),A4))) = aa(set(option(C)),option(C),complete_Sup_Sup(option(C)),aa(set(B),set(option(C)),image2(B,option(C),aTP_Lamp_jb(fun(B,C),fun(B,option(C)),F)),A4)) ) ) ) ).

% Some_SUP
tff(fact_2496_finite__range__prod,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,product_prod(B,D))] :
      ( finite_finite2(B,aa(set(C),set(B),image2(C,B,aa(fun(C,product_prod(B,D)),fun(C,B),aa(fun(product_prod(B,D),B),fun(fun(C,product_prod(B,D)),fun(C,B)),comp(product_prod(B,D),B,C),product_fst(B,D)),F)),top_top(set(C))))
     => ( finite_finite2(D,aa(set(C),set(D),image2(C,D,aa(fun(C,product_prod(B,D)),fun(C,D),aa(fun(product_prod(B,D),D),fun(fun(C,product_prod(B,D)),fun(C,D)),comp(product_prod(B,D),D,C),product_snd(B,D)),F)),top_top(set(C))))
       => finite_finite2(product_prod(B,D),aa(set(C),set(product_prod(B,D)),image2(C,product_prod(B,D),F),top_top(set(C)))) ) ) ).

% finite_range_prod
tff(fact_2497_UN__atMost__UNIV,axiom,
    aa(set(set(nat)),set(nat),complete_Sup_Sup(set(nat)),aa(set(nat),set(set(nat)),image2(nat,set(nat),set_ord_atMost(nat)),top_top(set(nat)))) = top_top(set(nat)) ).

% UN_atMost_UNIV
tff(fact_2498_UN__lessThan__UNIV,axiom,
    aa(set(set(nat)),set(nat),complete_Sup_Sup(set(nat)),aa(set(nat),set(set(nat)),image2(nat,set(nat),set_ord_lessThan(nat)),top_top(set(nat)))) = top_top(set(nat)) ).

% UN_lessThan_UNIV
tff(fact_2499_Sup__option__def,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [A4: set(option(B))] :
          aa(set(option(B)),option(B),complete_Sup_Sup(option(B)),A4) = $ite(
            ( ( A4 = bot_bot(set(option(B))) )
            | ( A4 = aa(set(option(B)),set(option(B)),insert2(option(B),none(B)),bot_bot(set(option(B)))) ) ),
            none(B),
            aa(B,option(B),some(B),aa(set(B),B,complete_Sup_Sup(B),these(B,A4))) ) ) ).

% Sup_option_def
tff(fact_2500_snd__image__mp,axiom,
    ! [C: $tType,B: $tType,A4: set(product_prod(C,B)),B5: set(B),X2: C,Y: B] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),A4)),B5)
     => ( member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y),A4)
       => member(B,Y,B5) ) ) ).

% snd_image_mp
tff(fact_2501_fst__image__mp,axiom,
    ! [C: $tType,B: $tType,A4: set(product_prod(B,C)),B5: set(B),X2: B,Y: C] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),A4)),B5)
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),A4)
       => member(B,X2,B5) ) ) ).

% fst_image_mp
tff(fact_2502_prod_OUnion__comp,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [B5: set(set(B)),G: fun(B,C)] :
          ( ! [X3: set(B)] :
              ( member(set(B),X3,B5)
             => finite_finite2(B,X3) )
         => ( ! [A13: set(B)] :
                ( member(set(B),A13,B5)
               => ! [A24: set(B)] :
                    ( member(set(B),A24,B5)
                   => ( ( A13 != A24 )
                     => ! [X3: B] :
                          ( member(B,X3,A13)
                         => ( member(B,X3,A24)
                           => ( aa(B,C,G,X3) = one_one(C) ) ) ) ) ) )
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),B5)) = aa(set(set(B)),C,aa(fun(B,C),fun(set(set(B)),C),aa(fun(fun(B,C),fun(set(B),C)),fun(fun(B,C),fun(set(set(B)),C)),aa(fun(fun(set(B),C),fun(set(set(B)),C)),fun(fun(fun(B,C),fun(set(B),C)),fun(fun(B,C),fun(set(set(B)),C))),comp(fun(set(B),C),fun(set(set(B)),C),fun(B,C)),groups7121269368397514597t_prod(set(B),C)),groups7121269368397514597t_prod(B,C)),G),B5) ) ) ) ) ).

% prod.Union_comp
tff(fact_2503_UN__UN__finite__eq,axiom,
    ! [B: $tType,A4: fun(nat,set(B))] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),aTP_Lamp_jc(fun(nat,set(B)),fun(nat,set(B)),A4)),top_top(set(nat)))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),top_top(set(nat)))) ).

% UN_UN_finite_eq
tff(fact_2504_UN__le__add__shift,axiom,
    ! [B: $tType,M2: fun(nat,set(B)),K: nat,N: nat] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),aa(nat,fun(nat,set(B)),aTP_Lamp_jd(fun(nat,set(B)),fun(nat,fun(nat,set(B))),M2),K)),aa(nat,set(nat),set_ord_atMost(nat),N))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),M2),set_or1337092689740270186AtMost(nat,K,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K)))) ).

% UN_le_add_shift
tff(fact_2505_UN__le__add__shift__strict,axiom,
    ! [B: $tType,M2: fun(nat,set(B)),K: nat,N: nat] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),aa(nat,fun(nat,set(B)),aTP_Lamp_jd(fun(nat,set(B)),fun(nat,fun(nat,set(B))),M2),K)),aa(nat,set(nat),set_ord_lessThan(nat),N))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),M2),set_or7035219750837199246ssThan(nat,K,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K)))) ).

% UN_le_add_shift_strict
tff(fact_2506_rat__sgn__code,axiom,
    ! [P3: rat] : quotient_of(aa(rat,rat,sgn_sgn(rat),P3)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,sgn_sgn(int),aa(product_prod(int,int),int,product_fst(int,int),quotient_of(P3)))),one_one(int)) ).

% rat_sgn_code
tff(fact_2507_bezw__non__0,axiom,
    ! [Y: nat,X2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),Y)
     => ( bezw(X2,Y) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Y,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Y)))),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(product_prod(int,int),int,product_fst(int,int),bezw(Y,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Y)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Y,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Y)))),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),X2),Y))))) ) ) ).

% bezw_non_0
tff(fact_2508_UN__finite__subset,axiom,
    ! [B: $tType,A4: fun(nat,set(B)),C5: set(B)] :
      ( ! [N3: nat] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),set_or7035219750837199246ssThan(nat,zero_zero(nat),N3)))),C5)
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),top_top(set(nat))))),C5) ) ).

% UN_finite_subset
tff(fact_2509_UN__finite2__eq,axiom,
    ! [B: $tType,A4: fun(nat,set(B)),B5: fun(nat,set(B)),K: nat] :
      ( ! [N3: nat] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),set_or7035219750837199246ssThan(nat,zero_zero(nat),N3))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),B5),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N3),K))))
     => ( aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),top_top(set(nat)))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),B5),top_top(set(nat)))) ) ) ).

% UN_finite2_eq
tff(fact_2510_bezw_Oelims,axiom,
    ! [X2: nat,Xa: nat,Y: product_prod(int,int)] :
      ( ( bezw(X2,Xa) = Y )
     => ( Y = $ite(Xa = zero_zero(nat),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),zero_zero(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Xa,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa)))),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(product_prod(int,int),int,product_fst(int,int),bezw(Xa,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Xa,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa)))),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),X2),Xa)))))) ) ) ).

% bezw.elims
tff(fact_2511_bezw_Osimps,axiom,
    ! [X2: nat,Y: nat] :
      bezw(X2,Y) = $ite(Y = zero_zero(nat),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),zero_zero(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Y,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Y)))),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(product_prod(int,int),int,product_fst(int,int),bezw(Y,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Y)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Y,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Y)))),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),X2),Y)))))) ).

% bezw.simps
tff(fact_2512_max__ext__def,axiom,
    ! [B: $tType,X: set(product_prod(B,B))] : max_ext(B,X) = aa(fun(product_prod(set(B),set(B)),$o),set(product_prod(set(B),set(B))),collect(product_prod(set(B),set(B))),aa(fun(set(B),fun(set(B),$o)),fun(product_prod(set(B),set(B)),$o),product_case_prod(set(B),set(B),$o),max_extp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),X)))) ).

% max_ext_def
tff(fact_2513_UN__finite2__subset,axiom,
    ! [B: $tType,A4: fun(nat,set(B)),B5: fun(nat,set(B)),K: nat] :
      ( ! [N3: nat] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),set_or7035219750837199246ssThan(nat,zero_zero(nat),N3)))),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),B5),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N3),K)))))
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),A4),top_top(set(nat))))),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),B5),top_top(set(nat))))) ) ).

% UN_finite2_subset
tff(fact_2514_bezw_Opelims,axiom,
    ! [X2: nat,Xa: nat,Y: product_prod(int,int)] :
      ( ( bezw(X2,Xa) = Y )
     => ( aa(product_prod(nat,nat),$o,accp(product_prod(nat,nat),bezw_rel),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Xa))
       => ~ ( ( Y = $ite(Xa = zero_zero(nat),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),zero_zero(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Xa,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa)))),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(product_prod(int,int),int,product_fst(int,int),bezw(Xa,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),bezw(Xa,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa)))),aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),X2),Xa)))))) )
           => ~ aa(product_prod(nat,nat),$o,accp(product_prod(nat,nat),bezw_rel),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Xa)) ) ) ) ).

% bezw.pelims
tff(fact_2515_snd__diag__id,axiom,
    ! [B: $tType,Z2: B] : aa(B,B,aa(fun(B,product_prod(B,B)),fun(B,B),aa(fun(product_prod(B,B),B),fun(fun(B,product_prod(B,B)),fun(B,B)),comp(product_prod(B,B),B,B),product_snd(B,B)),aTP_Lamp_je(B,product_prod(B,B))),Z2) = aa(B,B,id(B),Z2) ).

% snd_diag_id
tff(fact_2516_fst__diag__id,axiom,
    ! [B: $tType,Z2: B] : aa(B,B,aa(fun(B,product_prod(B,B)),fun(B,B),aa(fun(product_prod(B,B),B),fun(fun(B,product_prod(B,B)),fun(B,B)),comp(product_prod(B,B),B,B),product_fst(B,B)),aTP_Lamp_je(B,product_prod(B,B))),Z2) = aa(B,B,id(B),Z2) ).

% fst_diag_id
tff(fact_2517_size__prod__simp,axiom,
    ! [B: $tType,C: $tType,F: fun(B,nat),G: fun(C,nat),P3: product_prod(B,C)] : basic_BNF_size_prod(B,C,F,G,P3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,F,aa(product_prod(B,C),B,product_fst(B,C),P3))),aa(C,nat,G,aa(product_prod(B,C),C,product_snd(B,C),P3)))),aa(nat,nat,suc,zero_zero(nat))) ).

% size_prod_simp
tff(fact_2518_fst__diag__snd,axiom,
    ! [C: $tType,B: $tType] : aa(fun(product_prod(B,C),product_prod(C,C)),fun(product_prod(B,C),C),aa(fun(product_prod(C,C),C),fun(fun(product_prod(B,C),product_prod(C,C)),fun(product_prod(B,C),C)),comp(product_prod(C,C),C,product_prod(B,C)),product_fst(C,C)),aa(fun(product_prod(B,C),C),fun(product_prod(B,C),product_prod(C,C)),aa(fun(C,product_prod(C,C)),fun(fun(product_prod(B,C),C),fun(product_prod(B,C),product_prod(C,C))),comp(C,product_prod(C,C),product_prod(B,C)),aTP_Lamp_jf(C,product_prod(C,C))),product_snd(B,C))) = product_snd(B,C) ).

% fst_diag_snd
tff(fact_2519_snd__diag__fst,axiom,
    ! [C: $tType,B: $tType] : aa(fun(product_prod(B,C),product_prod(B,B)),fun(product_prod(B,C),B),aa(fun(product_prod(B,B),B),fun(fun(product_prod(B,C),product_prod(B,B)),fun(product_prod(B,C),B)),comp(product_prod(B,B),B,product_prod(B,C)),product_snd(B,B)),aa(fun(product_prod(B,C),B),fun(product_prod(B,C),product_prod(B,B)),aa(fun(B,product_prod(B,B)),fun(fun(product_prod(B,C),B),fun(product_prod(B,C),product_prod(B,B))),comp(B,product_prod(B,B),product_prod(B,C)),aTP_Lamp_je(B,product_prod(B,B))),product_fst(B,C))) = product_fst(B,C) ).

% snd_diag_fst
tff(fact_2520_None__in__Inf,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [A4: set(option(B))] :
          ( member(option(B),none(B),A4)
         => ( complete_Inf_Inf(option(B),A4) = none(B) ) ) ) ).

% None_in_Inf
tff(fact_2521_empty__Sup,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ( aa(set(option(B)),option(B),complete_Sup_Sup(option(B)),bot_bot(set(option(B)))) = none(B) ) ) ).

% empty_Sup
tff(fact_2522_singleton__None__Sup,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ( aa(set(option(B)),option(B),complete_Sup_Sup(option(B)),aa(set(option(B)),set(option(B)),insert2(option(B),none(B)),bot_bot(set(option(B))))) = none(B) ) ) ).

% singleton_None_Sup
tff(fact_2523_INF__INT__eq2,axiom,
    ! [B: $tType,C: $tType,D: $tType,R: fun(D,set(product_prod(B,C))),S2: set(D),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),complete_Inf_Inf(fun(B,fun(C,$o)),aa(set(D),set(fun(B,fun(C,$o))),image2(D,fun(B,fun(C,$o)),aTP_Lamp_jg(fun(D,set(product_prod(B,C))),fun(D,fun(B,fun(C,$o))),R)),S2)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),complete_Inf_Inf(set(product_prod(B,C)),aa(set(D),set(set(product_prod(B,C))),image2(D,set(product_prod(B,C)),R),S2))) ) ).

% INF_INT_eq2
tff(fact_2524_INF__Int__eq2,axiom,
    ! [C: $tType,B: $tType,S2: set(set(product_prod(B,C))),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),complete_Inf_Inf(fun(B,fun(C,$o)),aa(set(set(product_prod(B,C))),set(fun(B,fun(C,$o))),image2(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o)))),S2)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),complete_Inf_Inf(set(product_prod(B,C)),S2)) ) ).

% INF_Int_eq2
tff(fact_2525_SUP__UN__eq2,axiom,
    ! [B: $tType,C: $tType,D: $tType,R: fun(D,set(product_prod(B,C))),S2: set(D),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(set(fun(B,fun(C,$o))),fun(B,fun(C,$o)),complete_Sup_Sup(fun(B,fun(C,$o))),aa(set(D),set(fun(B,fun(C,$o))),image2(D,fun(B,fun(C,$o)),aTP_Lamp_jg(fun(D,set(product_prod(B,C))),fun(D,fun(B,fun(C,$o))),R)),S2)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),aa(set(D),set(set(product_prod(B,C))),image2(D,set(product_prod(B,C)),R),S2))) ) ).

% SUP_UN_eq2
tff(fact_2526_SUP__Sup__eq2,axiom,
    ! [C: $tType,B: $tType,S2: set(set(product_prod(B,C))),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(set(fun(B,fun(C,$o))),fun(B,fun(C,$o)),complete_Sup_Sup(fun(B,fun(C,$o))),aa(set(set(product_prod(B,C))),set(fun(B,fun(C,$o))),image2(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o)))),S2)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),S2)) ) ).

% SUP_Sup_eq2
tff(fact_2527_Inf__INT__eq2,axiom,
    ! [C: $tType,B: $tType,S2: set(fun(B,fun(C,$o))),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),complete_Inf_Inf(fun(B,fun(C,$o)),S2),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),complete_Inf_Inf(set(product_prod(B,C)),aa(set(fun(product_prod(B,C),$o)),set(set(product_prod(B,C))),image2(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C))),aa(set(fun(B,fun(C,$o))),set(fun(product_prod(B,C),$o)),image2(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o)),S2)))) ) ).

% Inf_INT_eq2
tff(fact_2528_Sup__SUP__eq2,axiom,
    ! [C: $tType,B: $tType,S2: set(fun(B,fun(C,$o))),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(set(fun(B,fun(C,$o))),fun(B,fun(C,$o)),complete_Sup_Sup(fun(B,fun(C,$o))),S2),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),aa(set(fun(product_prod(B,C),$o)),set(set(product_prod(B,C))),image2(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C))),aa(set(fun(B,fun(C,$o))),set(fun(product_prod(B,C),$o)),image2(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o)),S2)))) ) ).

% Sup_SUP_eq2
tff(fact_2529_fst__diag__fst,axiom,
    ! [C: $tType,B: $tType] : aa(fun(product_prod(B,C),product_prod(B,B)),fun(product_prod(B,C),B),aa(fun(product_prod(B,B),B),fun(fun(product_prod(B,C),product_prod(B,B)),fun(product_prod(B,C),B)),comp(product_prod(B,B),B,product_prod(B,C)),product_fst(B,B)),aa(fun(product_prod(B,C),B),fun(product_prod(B,C),product_prod(B,B)),aa(fun(B,product_prod(B,B)),fun(fun(product_prod(B,C),B),fun(product_prod(B,C),product_prod(B,B))),comp(B,product_prod(B,B),product_prod(B,C)),aTP_Lamp_je(B,product_prod(B,B))),product_fst(B,C))) = product_fst(B,C) ).

% fst_diag_fst
tff(fact_2530_snd__diag__snd,axiom,
    ! [C: $tType,B: $tType] : aa(fun(product_prod(B,C),product_prod(C,C)),fun(product_prod(B,C),C),aa(fun(product_prod(C,C),C),fun(fun(product_prod(B,C),product_prod(C,C)),fun(product_prod(B,C),C)),comp(product_prod(C,C),C,product_prod(B,C)),product_snd(C,C)),aa(fun(product_prod(B,C),C),fun(product_prod(B,C),product_prod(C,C)),aa(fun(C,product_prod(C,C)),fun(fun(product_prod(B,C),C),fun(product_prod(B,C),product_prod(C,C))),comp(C,product_prod(C,C),product_prod(B,C)),aTP_Lamp_jf(C,product_prod(C,C))),product_snd(B,C))) = product_snd(B,C) ).

% snd_diag_snd
tff(fact_2531_BNF__Greatest__Fixpoint_Osubst__Pair,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o)),X2: B,Y: C,A3: product_prod(B,C)] :
      ( aa(C,$o,aa(B,fun(C,$o),P,X2),Y)
     => ( ( A3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y) )
       => aa(C,$o,aa(B,fun(C,$o),P,aa(product_prod(B,C),B,product_fst(B,C),A3)),aa(product_prod(B,C),C,product_snd(B,C),A3)) ) ) ).

% BNF_Greatest_Fixpoint.subst_Pair
tff(fact_2532_normalize__def,axiom,
    ! [P3: product_prod(int,int)] :
      normalize(P3) = $ite(
        aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),aa(product_prod(int,int),int,product_snd(int,int),P3)),
        $let(
          a2: int,
          a2:= aa(int,int,aa(int,fun(int,int),gcd_gcd(int),aa(product_prod(int,int),int,product_fst(int,int),P3)),aa(product_prod(int,int),int,product_snd(int,int),P3)),
          aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(product_prod(int,int),int,product_fst(int,int),P3)),a2)),aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(product_prod(int,int),int,product_snd(int,int),P3)),a2)) ),
        $ite(
          aa(product_prod(int,int),int,product_snd(int,int),P3) = zero_zero(int),
          aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)),
          $let(
            a2: int,
            a2:= aa(int,int,uminus_uminus(int),aa(int,int,aa(int,fun(int,int),gcd_gcd(int),aa(product_prod(int,int),int,product_fst(int,int),P3)),aa(product_prod(int,int),int,product_snd(int,int),P3))),
            aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(product_prod(int,int),int,product_fst(int,int),P3)),a2)),aa(int,int,aa(int,fun(int,int),divide_divide(int),aa(product_prod(int,int),int,product_snd(int,int),P3)),a2)) ) ) ) ).

% normalize_def
tff(fact_2533_range__prod,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(D,product_prod(B,C))] : aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),aa(set(D),set(product_prod(B,C)),image2(D,product_prod(B,C),F),top_top(set(D)))),product_Sigma(B,C,aa(set(D),set(B),image2(D,B,aa(fun(D,product_prod(B,C)),fun(D,B),aa(fun(product_prod(B,C),B),fun(fun(D,product_prod(B,C)),fun(D,B)),comp(product_prod(B,C),B,D),product_fst(B,C)),F)),top_top(set(D))),aTP_Lamp_jh(fun(D,product_prod(B,C)),fun(B,set(C)),F))) ).

% range_prod
tff(fact_2534_fun_Oin__rel,axiom,
    ! [C: $tType,D: $tType,B: $tType,R4: fun(C,fun(D,$o)),A3: fun(B,C),B2: fun(B,D)] :
      ( aa(fun(B,D),$o,aa(fun(B,C),fun(fun(B,D),$o),bNF_rel_fun(B,B,C,D,fequal(B),R4),A3),B2)
    <=> ? [Z4: fun(B,product_prod(C,D))] :
          ( member(fun(B,product_prod(C,D)),Z4,aa(fun(fun(B,product_prod(C,D)),$o),set(fun(B,product_prod(C,D))),collect(fun(B,product_prod(C,D))),aTP_Lamp_ji(fun(C,fun(D,$o)),fun(fun(B,product_prod(C,D)),$o),R4)))
          & ( aa(fun(B,product_prod(C,D)),fun(B,C),aa(fun(product_prod(C,D),C),fun(fun(B,product_prod(C,D)),fun(B,C)),comp(product_prod(C,D),C,B),product_fst(C,D)),Z4) = A3 )
          & ( aa(fun(B,product_prod(C,D)),fun(B,D),aa(fun(product_prod(C,D),D),fun(fun(B,product_prod(C,D)),fun(B,D)),comp(product_prod(C,D),D,B),product_snd(C,D)),Z4) = B2 ) ) ) ).

% fun.in_rel
tff(fact_2535_apfst__apsnd,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,F: fun(D,B),G: fun(E,C),X2: product_prod(D,E)] : aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,F),aa(product_prod(D,E),product_prod(D,C),aa(fun(E,C),fun(product_prod(D,E),product_prod(D,C)),product_apsnd(E,C,D),G),X2)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,F,aa(product_prod(D,E),D,product_fst(D,E),X2))),aa(E,C,G,aa(product_prod(D,E),E,product_snd(D,E),X2))) ).

% apfst_apsnd
tff(fact_2536_apsnd__apfst,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,F: fun(D,C),G: fun(E,B),X2: product_prod(E,D)] : aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),F),aa(product_prod(E,D),product_prod(B,D),product_apfst(E,B,D,G),X2)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(E,B,G,aa(product_prod(E,D),E,product_fst(E,D),X2))),aa(D,C,F,aa(product_prod(E,D),D,product_snd(E,D),X2))) ).

% apsnd_apfst
tff(fact_2537_eq__snd__iff,axiom,
    ! [C: $tType,B: $tType,B2: B,P3: product_prod(C,B)] :
      ( ( B2 = aa(product_prod(C,B),B,product_snd(C,B),P3) )
    <=> ? [A7: C] : P3 = aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A7),B2) ) ).

% eq_snd_iff
tff(fact_2538_SigmaI,axiom,
    ! [C: $tType,B: $tType,A3: B,A4: set(B),B2: C,B5: fun(B,set(C))] :
      ( member(B,A3,A4)
     => ( member(C,B2,aa(B,set(C),B5,A3))
       => member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),product_Sigma(B,C,A4,B5)) ) ) ).

% SigmaI
tff(fact_2539_mem__Sigma__iff,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,A4: set(B),B5: fun(B,set(C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),product_Sigma(B,C,A4,B5))
    <=> ( member(B,A3,A4)
        & member(C,B2,aa(B,set(C),B5,A3)) ) ) ).

% mem_Sigma_iff
tff(fact_2540_gcd__add1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [M: B,N: B] : aa(B,B,aa(B,fun(B,B),gcd_gcd(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),M),N)),N) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),M),N) ) ).

% gcd_add1
tff(fact_2541_gcd__add2,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [M: B,N: B] : aa(B,B,aa(B,fun(B,B),gcd_gcd(B),M),aa(B,B,aa(B,fun(B,B),plus_plus(B),M),N)) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),M),N) ) ).

% gcd_add2
tff(fact_2542_gcd_Obottom__left__bottom,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),gcd_gcd(B),one_one(B)),A3) = one_one(B) ) ).

% gcd.bottom_left_bottom
tff(fact_2543_gcd_Obottom__right__bottom,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),one_one(B)) = one_one(B) ) ).

% gcd.bottom_right_bottom
tff(fact_2544_apfst__conv,axiom,
    ! [D: $tType,B: $tType,C: $tType,F: fun(D,B),X2: D,Y: C] : aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,F),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),X2),Y)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,F,X2)),Y) ).

% apfst_conv
tff(fact_2545_apfst__eq__conv,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,B),X2: product_prod(D,C),G: fun(D,B)] :
      ( ( aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,F),X2) = aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,G),X2) )
    <=> ( aa(D,B,F,aa(product_prod(D,C),D,product_fst(D,C),X2)) = aa(D,B,G,aa(product_prod(D,C),D,product_fst(D,C),X2)) ) ) ).

% apfst_eq_conv
tff(fact_2546_fst__apfst,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,B),X2: product_prod(D,C)] : aa(product_prod(B,C),B,product_fst(B,C),aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,F),X2)) = aa(D,B,F,aa(product_prod(D,C),D,product_fst(D,C),X2)) ).

% fst_apfst
tff(fact_2547_snd__apfst,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(D,C),X2: product_prod(D,B)] : aa(product_prod(C,B),B,product_snd(C,B),aa(product_prod(D,B),product_prod(C,B),product_apfst(D,C,B,F),X2)) = aa(product_prod(D,B),B,product_snd(D,B),X2) ).

% snd_apfst
tff(fact_2548_Collect__case__prod,axiom,
    ! [B: $tType,C: $tType,P: fun(B,$o),Q: fun(C,$o)] : aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(fun(C,$o),fun(B,fun(C,$o)),aTP_Lamp_jj(fun(B,$o),fun(fun(C,$o),fun(B,fun(C,$o))),P),Q))) = product_Sigma(B,C,aa(fun(B,$o),set(B),collect(B),P),aTP_Lamp_jk(fun(C,$o),fun(B,set(C)),Q)) ).

% Collect_case_prod
tff(fact_2549_is__unit__gcd__iff,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2),one_one(B))
        <=> ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2) = one_one(B) ) ) ) ).

% is_unit_gcd_iff
tff(fact_2550_Sigma__empty1,axiom,
    ! [C: $tType,B: $tType,B5: fun(B,set(C))] : product_Sigma(B,C,bot_bot(set(B)),B5) = bot_bot(set(product_prod(B,C))) ).

% Sigma_empty1
tff(fact_2551_Sigma__empty2,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] : product_Sigma(B,C,A4,aTP_Lamp_jl(B,set(C))) = bot_bot(set(product_prod(B,C))) ).

% Sigma_empty2
tff(fact_2552_Times__empty,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ( product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)) = bot_bot(set(product_prod(B,C))) )
    <=> ( ( A4 = bot_bot(set(B)) )
        | ( B5 = bot_bot(set(C)) ) ) ) ).

% Times_empty
tff(fact_2553_Sigma__UNIV__cancel,axiom,
    ! [C: $tType,B: $tType,A4: set(B),X7: set(C)] : aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),minus_minus(set(product_prod(B,C))),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),X7))),product_Sigma(B,C,A4,aTP_Lamp_jn(B,set(C)))) = bot_bot(set(product_prod(B,C))) ).

% Sigma_UNIV_cancel
tff(fact_2554_Compl__Times__UNIV2,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] : aa(set(product_prod(B,C)),set(product_prod(B,C)),uminus_uminus(set(product_prod(B,C))),product_Sigma(B,C,A4,aTP_Lamp_jn(B,set(C)))) = product_Sigma(B,C,aa(set(B),set(B),uminus_uminus(set(B)),A4),aTP_Lamp_jn(B,set(C))) ).

% Compl_Times_UNIV2
tff(fact_2555_Compl__Times__UNIV1,axiom,
    ! [B: $tType,C: $tType,A4: set(C)] : aa(set(product_prod(B,C)),set(product_prod(B,C)),uminus_uminus(set(product_prod(B,C))),product_Sigma(B,C,top_top(set(B)),aTP_Lamp_jm(set(C),fun(B,set(C)),A4))) = product_Sigma(B,C,top_top(set(B)),aTP_Lamp_jo(set(C),fun(B,set(C)),A4)) ).

% Compl_Times_UNIV1
tff(fact_2556_snd__comp__apfst,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,D)] : aa(fun(product_prod(B,C),product_prod(D,C)),fun(product_prod(B,C),C),aa(fun(product_prod(D,C),C),fun(fun(product_prod(B,C),product_prod(D,C)),fun(product_prod(B,C),C)),comp(product_prod(D,C),C,product_prod(B,C)),product_snd(D,C)),product_apfst(B,D,C,F)) = product_snd(B,C) ).

% snd_comp_apfst
tff(fact_2557_UNIV__Times__UNIV,axiom,
    ! [C: $tType,B: $tType] : product_Sigma(B,C,top_top(set(B)),aTP_Lamp_jn(B,set(C))) = top_top(set(product_prod(B,C))) ).

% UNIV_Times_UNIV
tff(fact_2558_apfst__id,axiom,
    ! [C: $tType,B: $tType] : product_apfst(B,B,C,id(B)) = id(product_prod(B,C)) ).

% apfst_id
tff(fact_2559_pairself__image__cart,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),A4: set(C),B5: set(C)] : aa(set(product_prod(C,C)),set(product_prod(B,B)),image2(product_prod(C,C),product_prod(B,B),pairself(C,B,F)),product_Sigma(C,C,A4,aTP_Lamp_jp(set(C),fun(C,set(C)),B5))) = product_Sigma(B,B,aa(set(C),set(B),image2(C,B,F),A4),aa(set(C),fun(B,set(B)),aTP_Lamp_jq(fun(C,B),fun(set(C),fun(B,set(B))),F),B5)) ).

% pairself_image_cart
tff(fact_2560_fst__image__times,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5))) = $ite(B5 = bot_bot(set(C)),bot_bot(set(B)),A4) ).

% fst_image_times
tff(fact_2561_snd__image__times,axiom,
    ! [C: $tType,B: $tType,A4: set(C),B5: set(B)] :
      aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),product_Sigma(C,B,A4,aTP_Lamp_jr(set(B),fun(C,set(B)),B5))) = $ite(A4 = bot_bot(set(C)),bot_bot(set(B)),B5) ).

% snd_image_times
tff(fact_2562_fst__comp__apfst,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,D)] : aa(fun(product_prod(B,C),product_prod(D,C)),fun(product_prod(B,C),D),aa(fun(product_prod(D,C),D),fun(fun(product_prod(B,C),product_prod(D,C)),fun(product_prod(B,C),D)),comp(product_prod(D,C),D,product_prod(B,C)),product_fst(D,C)),product_apfst(B,D,C,F)) = aa(fun(product_prod(B,C),B),fun(product_prod(B,C),D),aa(fun(B,D),fun(fun(product_prod(B,C),B),fun(product_prod(B,C),D)),comp(B,D,product_prod(B,C)),F),product_fst(B,C)) ).

% fst_comp_apfst
tff(fact_2563_fun_Omap__transfer,axiom,
    ! [B: $tType,C: $tType,F4: $tType,E: $tType,D: $tType,Rb2: fun(B,fun(D,$o)),Sd: fun(C,fun(E,$o))] : aa(fun(fun(D,E),fun(fun(F4,D),fun(F4,E))),$o,aa(fun(fun(B,C),fun(fun(F4,B),fun(F4,C))),fun(fun(fun(D,E),fun(fun(F4,D),fun(F4,E))),$o),bNF_rel_fun(fun(B,C),fun(D,E),fun(fun(F4,B),fun(F4,C)),fun(fun(F4,D),fun(F4,E)),bNF_rel_fun(B,D,C,E,Rb2,Sd),bNF_rel_fun(fun(F4,B),fun(F4,D),fun(F4,C),fun(F4,E),bNF_rel_fun(F4,F4,B,D,fequal(F4),Rb2),bNF_rel_fun(F4,F4,C,E,fequal(F4),Sd))),comp(B,C,F4)),comp(D,E,F4)) ).

% fun.map_transfer
tff(fact_2564_comp__transfer,axiom,
    ! [B: $tType,C: $tType,F4: $tType,G2: $tType,E: $tType,D: $tType,B5: fun(B,fun(D,$o)),C5: fun(C,fun(E,$o)),A4: fun(F4,fun(G2,$o))] : aa(fun(fun(D,E),fun(fun(G2,D),fun(G2,E))),$o,aa(fun(fun(B,C),fun(fun(F4,B),fun(F4,C))),fun(fun(fun(D,E),fun(fun(G2,D),fun(G2,E))),$o),bNF_rel_fun(fun(B,C),fun(D,E),fun(fun(F4,B),fun(F4,C)),fun(fun(G2,D),fun(G2,E)),bNF_rel_fun(B,D,C,E,B5,C5),bNF_rel_fun(fun(F4,B),fun(G2,D),fun(F4,C),fun(G2,E),bNF_rel_fun(F4,G2,B,D,A4,B5),bNF_rel_fun(F4,G2,C,E,A4,C5))),comp(B,C,F4)),comp(D,E,G2)) ).

% comp_transfer
tff(fact_2565_power__transfer,axiom,
    ! [B: $tType,C: $tType] :
      ( ( power(C)
        & power(B) )
     => ! [R4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),R4,one_one(B)),one_one(C))
         => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),R4,bNF_rel_fun(B,C,B,C,R4,R4)),times_times(B)),times_times(C))
           => aa(fun(C,fun(nat,C)),$o,aa(fun(B,fun(nat,B)),fun(fun(C,fun(nat,C)),$o),bNF_rel_fun(B,C,fun(nat,B),fun(nat,C),R4,bNF_rel_fun(nat,nat,B,C,fequal(nat),R4)),power_power(B)),power_power(C)) ) ) ) ).

% power_transfer
tff(fact_2566_times__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),times_times(int)),times_times(int)) ).

% times_integer.rsp
tff(fact_2567_times__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),times_times(nat)),times_times(nat)) ).

% times_natural.rsp
tff(fact_2568_Times__eq__cancel2,axiom,
    ! [B: $tType,C: $tType,X2: B,C5: set(B),A4: set(C),B5: set(C)] :
      ( member(B,X2,C5)
     => ( ( product_Sigma(C,B,A4,aTP_Lamp_jr(set(B),fun(C,set(B)),C5)) = product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),C5)) )
      <=> ( A4 = B5 ) ) ) ).

% Times_eq_cancel2
tff(fact_2569_Sigma__cong,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(B),C5: fun(B,set(C)),D4: fun(B,set(C))] :
      ( ( A4 = B5 )
     => ( ! [X3: B] :
            ( member(B,X3,B5)
           => ( aa(B,set(C),C5,X3) = aa(B,set(C),D4,X3) ) )
       => ( product_Sigma(B,C,A4,C5) = product_Sigma(B,C,B5,D4) ) ) ) ).

% Sigma_cong
tff(fact_2570_divide__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),divide_divide(nat)),divide_divide(nat)) ).

% divide_natural.rsp
tff(fact_2571_divide__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),divide_divide(int)),divide_divide(int)) ).

% divide_integer.rsp
tff(fact_2572_or__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se1065995026697491101ons_or(nat)),bit_se1065995026697491101ons_or(nat)) ).

% or_natural.rsp
tff(fact_2573_or__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se1065995026697491101ons_or(int)),bit_se1065995026697491101ons_or(int)) ).

% or_integer.rsp
tff(fact_2574_set__bit__integer_Orsp,axiom,
    aa(fun(nat,fun(int,int)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(int,int)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(int,int),fequal(nat),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se5668285175392031749et_bit(int)),bit_se5668285175392031749et_bit(int)) ).

% set_bit_integer.rsp
tff(fact_2575_set__bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se5668285175392031749et_bit(nat)),bit_se5668285175392031749et_bit(nat)) ).

% set_bit_natural.rsp
tff(fact_2576_xor__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se5824344971392196577ns_xor(int)),bit_se5824344971392196577ns_xor(int)) ).

% xor_integer.rsp
tff(fact_2577_xor__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se5824344971392196577ns_xor(nat)),bit_se5824344971392196577ns_xor(nat)) ).

% xor_natural.rsp
tff(fact_2578_and__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se5824344872417868541ns_and(int)),bit_se5824344872417868541ns_and(int)) ).

% and_integer.rsp
tff(fact_2579_and__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se5824344872417868541ns_and(nat)),bit_se5824344872417868541ns_and(nat)) ).

% and_natural.rsp
tff(fact_2580_modulo__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),modulo_modulo(int)),modulo_modulo(int)) ).

% modulo_integer.rsp
tff(fact_2581_modulo__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),modulo_modulo(nat)),modulo_modulo(nat)) ).

% modulo_natural.rsp
tff(fact_2582_less__integer_Orsp,axiom,
    aa(fun(int,fun(int,$o)),$o,aa(fun(int,fun(int,$o)),fun(fun(int,fun(int,$o)),$o),bNF_rel_fun(int,int,fun(int,$o),fun(int,$o),fequal(int),bNF_rel_fun(int,int,$o,$o,fequal(int),fequal($o))),ord_less(int)),ord_less(int)) ).

% less_integer.rsp
tff(fact_2583_less__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,$o)),$o,aa(fun(nat,fun(nat,$o)),fun(fun(nat,fun(nat,$o)),$o),bNF_rel_fun(nat,nat,fun(nat,$o),fun(nat,$o),fequal(nat),bNF_rel_fun(nat,nat,$o,$o,fequal(nat),fequal($o))),ord_less(nat)),ord_less(nat)) ).

% less_natural.rsp
tff(fact_2584_unset__bit__integer_Orsp,axiom,
    aa(fun(nat,fun(int,int)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(int,int)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(int,int),fequal(nat),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se2638667681897837118et_bit(int)),bit_se2638667681897837118et_bit(int)) ).

% unset_bit_integer.rsp
tff(fact_2585_take__bit__integer_Orsp,axiom,
    aa(fun(nat,fun(int,int)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(int,int)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(int,int),fequal(nat),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se2584673776208193580ke_bit(int)),bit_se2584673776208193580ke_bit(int)) ).

% take_bit_integer.rsp
tff(fact_2586_flip__bit__integer_Orsp,axiom,
    aa(fun(nat,fun(int,int)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(int,int)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(int,int),fequal(nat),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se8732182000553998342ip_bit(int)),bit_se8732182000553998342ip_bit(int)) ).

% flip_bit_integer.rsp
tff(fact_2587_flip__bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se8732182000553998342ip_bit(nat)),bit_se8732182000553998342ip_bit(nat)) ).

% flip_bit_natural.rsp
tff(fact_2588_push__bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se4730199178511100633sh_bit(nat)),bit_se4730199178511100633sh_bit(nat)) ).

% push_bit_natural.rsp
tff(fact_2589_push__bit__integer_Orsp,axiom,
    aa(fun(nat,fun(int,int)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(int,int)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(int,int),fequal(nat),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se4730199178511100633sh_bit(int)),bit_se4730199178511100633sh_bit(int)) ).

% push_bit_integer.rsp
tff(fact_2590_plus__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),plus_plus(int)),plus_plus(int)) ).

% plus_integer.rsp
tff(fact_2591_plus__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),plus_plus(nat)),plus_plus(nat)) ).

% plus_natural.rsp
tff(fact_2592_drop__bit__integer_Orsp,axiom,
    aa(fun(nat,fun(int,int)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(int,int)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(int,int),fequal(nat),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),bit_se4197421643247451524op_bit(int)),bit_se4197421643247451524op_bit(int)) ).

% drop_bit_integer.rsp
tff(fact_2593_minus__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),minus_minus(nat)),minus_minus(nat)) ).

% minus_natural.rsp
tff(fact_2594_minus__integer_Orsp,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(int,fun(int,int)),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(int,int,fun(int,int),fun(int,int),fequal(int),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int))),minus_minus(int)),minus_minus(int)) ).

% minus_integer.rsp
tff(fact_2595_less__eq__integer_Orsp,axiom,
    aa(fun(int,fun(int,$o)),$o,aa(fun(int,fun(int,$o)),fun(fun(int,fun(int,$o)),$o),bNF_rel_fun(int,int,fun(int,$o),fun(int,$o),fequal(int),bNF_rel_fun(int,int,$o,$o,fequal(int),fequal($o))),ord_less_eq(int)),ord_less_eq(int)) ).

% less_eq_integer.rsp
tff(fact_2596_less__eq__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,$o)),$o,aa(fun(nat,fun(nat,$o)),fun(fun(nat,fun(nat,$o)),$o),bNF_rel_fun(nat,nat,fun(nat,$o),fun(nat,$o),fequal(nat),bNF_rel_fun(nat,nat,$o,$o,fequal(nat),fequal($o))),ord_less_eq(nat)),ord_less_eq(nat)) ).

% less_eq_natural.rsp
tff(fact_2597_SigmaE,axiom,
    ! [B: $tType,C: $tType,C2: product_prod(B,C),A4: set(B),B5: fun(B,set(C))] :
      ( member(product_prod(B,C),C2,product_Sigma(B,C,A4,B5))
     => ~ ! [X3: B] :
            ( member(B,X3,A4)
           => ! [Y4: C] :
                ( member(C,Y4,aa(B,set(C),B5,X3))
               => ( C2 != aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4) ) ) ) ) ).

% SigmaE
tff(fact_2598_SigmaD1,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,A4: set(B),B5: fun(B,set(C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),product_Sigma(B,C,A4,B5))
     => member(B,A3,A4) ) ).

% SigmaD1
tff(fact_2599_SigmaD2,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,A4: set(B),B5: fun(B,set(C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),product_Sigma(B,C,A4,B5))
     => member(C,B2,aa(B,set(C),B5,A3)) ) ).

% SigmaD2
tff(fact_2600_SigmaE2,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,A4: set(B),B5: fun(B,set(C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),product_Sigma(B,C,A4,B5))
     => ~ ( member(B,A3,A4)
         => ~ member(C,B2,aa(B,set(C),B5,A3)) ) ) ).

% SigmaE2
tff(fact_2601_Suc_Orsp,axiom,
    aa(fun(nat,nat),$o,aa(fun(nat,nat),fun(fun(nat,nat),$o),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat)),suc),suc) ).

% Suc.rsp
tff(fact_2602_sub_Orsp,axiom,
    aa(fun(num,fun(num,int)),$o,aa(fun(num,fun(num,int)),fun(fun(num,fun(num,int)),$o),bNF_rel_fun(num,num,fun(num,int),fun(num,int),fequal(num),bNF_rel_fun(num,num,int,int,fequal(num),fequal(int))),aTP_Lamp_hm(num,fun(num,int))),aTP_Lamp_hm(num,fun(num,int))) ).

% sub.rsp
tff(fact_2603_transfer__rule__numeral,axiom,
    ! [B: $tType,C: $tType] :
      ( ( monoid_add(C)
        & semiring_numeral(C)
        & monoid_add(B)
        & semiring_numeral(B) )
     => ! [R4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),R4,zero_zero(B)),zero_zero(C))
         => ( aa(C,$o,aa(B,fun(C,$o),R4,one_one(B)),one_one(C))
           => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),R4,bNF_rel_fun(B,C,B,C,R4,R4)),plus_plus(B)),plus_plus(C))
             => aa(fun(num,C),$o,aa(fun(num,B),fun(fun(num,C),$o),bNF_rel_fun(num,num,B,C,fequal(num),R4),numeral_numeral(B)),numeral_numeral(C)) ) ) ) ) ).

% transfer_rule_numeral
tff(fact_2604_uminus__integer_Orsp,axiom,
    aa(fun(int,int),$o,aa(fun(int,int),fun(fun(int,int),$o),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int)),uminus_uminus(int)),uminus_uminus(int)) ).

% uminus_integer.rsp
tff(fact_2605_integer__of__natural_Orsp,axiom,
    aa(fun(nat,int),$o,aa(fun(nat,int),fun(fun(nat,int),$o),bNF_rel_fun(nat,nat,int,int,fequal(nat),fequal(int)),semiring_1_of_nat(int)),semiring_1_of_nat(int)) ).

% integer_of_natural.rsp
tff(fact_2606_Sigma__Diff__distrib1,axiom,
    ! [C: $tType,B: $tType,I4: set(B),J4: set(B),C5: fun(B,set(C))] : product_Sigma(B,C,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),I4),J4),C5) = aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),minus_minus(set(product_prod(B,C))),product_Sigma(B,C,I4,C5)),product_Sigma(B,C,J4,C5)) ).

% Sigma_Diff_distrib1
tff(fact_2607_natural__of__integer_Orsp,axiom,
    aa(fun(int,nat),$o,aa(fun(int,nat),fun(fun(int,nat),$o),bNF_rel_fun(int,int,nat,nat,fequal(int),fequal(nat)),nat2),nat2) ).

% natural_of_integer.rsp
tff(fact_2608_abs__integer_Orsp,axiom,
    aa(fun(int,int),$o,aa(fun(int,int),fun(fun(int,int),$o),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int)),abs_abs(int)),abs_abs(int)) ).

% abs_integer.rsp
tff(fact_2609_bit__integer_Orsp,axiom,
    aa(fun(int,fun(nat,$o)),$o,aa(fun(int,fun(nat,$o)),fun(fun(int,fun(nat,$o)),$o),bNF_rel_fun(int,int,fun(nat,$o),fun(nat,$o),fequal(int),fequal(fun(nat,$o))),bit_se5641148757651400278ts_bit(int)),bit_se5641148757651400278ts_bit(int)) ).

% bit_integer.rsp
tff(fact_2610_not__integer_Orsp,axiom,
    aa(fun(int,int),$o,aa(fun(int,int),fun(fun(int,int),$o),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int)),bit_ri4277139882892585799ns_not(int)),bit_ri4277139882892585799ns_not(int)) ).

% not_integer.rsp
tff(fact_2611_sgn__integer_Orsp,axiom,
    aa(fun(int,int),$o,aa(fun(int,int),fun(fun(int,int),$o),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int)),sgn_sgn(int)),sgn_sgn(int)) ).

% sgn_integer.rsp
tff(fact_2612_mask__integer_Orsp,axiom,
    aa(fun(nat,int),$o,aa(fun(nat,int),fun(fun(nat,int),$o),bNF_rel_fun(nat,nat,int,int,fequal(nat),fequal(int)),bit_se2239418461657761734s_mask(int)),bit_se2239418461657761734s_mask(int)) ).

% mask_integer.rsp
tff(fact_2613_mask__natural_Orsp,axiom,
    aa(fun(nat,nat),$o,aa(fun(nat,nat),fun(fun(nat,nat),$o),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat)),bit_se2239418461657761734s_mask(nat)),bit_se2239418461657761734s_mask(nat)) ).

% mask_natural.rsp
tff(fact_2614_transfer__rule__of__int,axiom,
    ! [B: $tType,C: $tType] :
      ( ( ring_1(C)
        & ring_1(B) )
     => ! [R4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),R4,zero_zero(B)),zero_zero(C))
         => ( aa(C,$o,aa(B,fun(C,$o),R4,one_one(B)),one_one(C))
           => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),R4,bNF_rel_fun(B,C,B,C,R4,R4)),plus_plus(B)),plus_plus(C))
             => ( aa(fun(C,C),$o,aa(fun(B,B),fun(fun(C,C),$o),bNF_rel_fun(B,C,B,C,R4,R4),uminus_uminus(B)),uminus_uminus(C))
               => aa(fun(int,C),$o,aa(fun(int,B),fun(fun(int,C),$o),bNF_rel_fun(int,int,B,C,fequal(int),R4),ring_1_of_int(B)),ring_1_of_int(C)) ) ) ) ) ) ).

% transfer_rule_of_int
tff(fact_2615_fun_Orel__map_I1_J,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,Sb: fun(C,fun(D,$o)),I: fun(E,C),X2: fun(B,E),Y: fun(B,D)] :
      ( aa(fun(B,D),$o,aa(fun(B,C),fun(fun(B,D),$o),bNF_rel_fun(B,B,C,D,fequal(B),Sb),aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),I),X2)),Y)
    <=> aa(fun(B,D),$o,aa(fun(B,E),fun(fun(B,D),$o),bNF_rel_fun(B,B,E,D,fequal(B),aa(fun(E,C),fun(E,fun(D,$o)),aTP_Lamp_js(fun(C,fun(D,$o)),fun(fun(E,C),fun(E,fun(D,$o))),Sb),I)),X2),Y) ) ).

% fun.rel_map(1)
tff(fact_2616_fun_Orel__map_I2_J,axiom,
    ! [C: $tType,D: $tType,E: $tType,B: $tType,Sa: fun(C,fun(D,$o)),X2: fun(B,C),G: fun(E,D),Y: fun(B,E)] :
      ( aa(fun(B,D),$o,aa(fun(B,C),fun(fun(B,D),$o),bNF_rel_fun(B,B,C,D,fequal(B),Sa),X2),aa(fun(B,E),fun(B,D),aa(fun(E,D),fun(fun(B,E),fun(B,D)),comp(E,D,B),G),Y))
    <=> aa(fun(B,E),$o,aa(fun(B,C),fun(fun(B,E),$o),bNF_rel_fun(B,B,C,E,fequal(B),aa(fun(E,D),fun(C,fun(E,$o)),aTP_Lamp_jt(fun(C,fun(D,$o)),fun(fun(E,D),fun(C,fun(E,$o))),Sa),G)),X2),Y) ) ).

% fun.rel_map(2)
tff(fact_2617_times__eq__iff,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C),C5: set(B),D4: set(C)] :
      ( ( product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)) = product_Sigma(B,C,C5,aTP_Lamp_jm(set(C),fun(B,set(C)),D4)) )
    <=> ( ( ( A4 = C5 )
          & ( B5 = D4 ) )
        | ( ( ( A4 = bot_bot(set(B)) )
            | ( B5 = bot_bot(set(C)) ) )
          & ( ( C5 = bot_bot(set(B)) )
            | ( D4 = bot_bot(set(C)) ) ) ) ) ) ).

% times_eq_iff
tff(fact_2618_dup_Orsp,axiom,
    aa(fun(int,int),$o,aa(fun(int,int),fun(fun(int,int),$o),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int)),aTP_Lamp_hf(int,int)),aTP_Lamp_hf(int,int)) ).

% dup.rsp
tff(fact_2619_Sigma__Diff__distrib2,axiom,
    ! [C: $tType,B: $tType,I4: set(B),A4: fun(B,set(C)),B5: fun(B,set(C))] : product_Sigma(B,C,I4,aa(fun(B,set(C)),fun(B,set(C)),aTP_Lamp_ju(fun(B,set(C)),fun(fun(B,set(C)),fun(B,set(C))),A4),B5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),minus_minus(set(product_prod(B,C))),product_Sigma(B,C,I4,A4)),product_Sigma(B,C,I4,B5)) ).

% Sigma_Diff_distrib2
tff(fact_2620_Times__Diff__distrib1,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(B),C5: set(C)] : product_Sigma(B,C,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5),aTP_Lamp_jm(set(C),fun(B,set(C)),C5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),minus_minus(set(product_prod(B,C))),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))),product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))) ).

% Times_Diff_distrib1
tff(fact_2621_Sigma__Union,axiom,
    ! [C: $tType,B: $tType,X7: set(set(B)),B5: fun(B,set(C))] : product_Sigma(B,C,aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),X7),B5) = aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),aa(set(set(B)),set(set(product_prod(B,C))),image2(set(B),set(product_prod(B,C)),aTP_Lamp_jv(fun(B,set(C)),fun(set(B),set(product_prod(B,C))),B5)),X7)) ).

% Sigma_Union
tff(fact_2622_Collect__case__prod__Sigma,axiom,
    ! [C: $tType,B: $tType,P: fun(B,$o),Q: fun(B,fun(C,$o))] : aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aTP_Lamp_jw(fun(B,$o),fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),P),Q))) = product_Sigma(B,C,aa(fun(B,$o),set(B),collect(B),P),aTP_Lamp_jx(fun(B,fun(C,$o)),fun(B,set(C)),Q)) ).

% Collect_case_prod_Sigma
tff(fact_2623_apfst__compose,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,F: fun(D,B),G: fun(E,D),X2: product_prod(E,C)] : aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,F),aa(product_prod(E,C),product_prod(D,C),product_apfst(E,D,C,G),X2)) = aa(product_prod(E,C),product_prod(B,C),product_apfst(E,B,C,aa(fun(E,D),fun(E,B),aa(fun(D,B),fun(fun(E,D),fun(E,B)),comp(D,B,E),F),G)),X2) ).

% apfst_compose
tff(fact_2624_apsnd__apfst__commute,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,F: fun(D,C),G: fun(E,B),P3: product_prod(E,D)] : aa(product_prod(B,D),product_prod(B,C),aa(fun(D,C),fun(product_prod(B,D),product_prod(B,C)),product_apsnd(D,C,B),F),aa(product_prod(E,D),product_prod(B,D),product_apfst(E,B,D,G),P3)) = aa(product_prod(E,C),product_prod(B,C),product_apfst(E,B,C,G),aa(product_prod(E,D),product_prod(E,C),aa(fun(D,C),fun(product_prod(E,D),product_prod(E,C)),product_apsnd(D,C,E),F),P3)) ).

% apsnd_apfst_commute
tff(fact_2625_gcd__add__mult,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [M: B,K: B,N: B] : aa(B,B,aa(B,fun(B,B),gcd_gcd(B),M),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),K),M)),N)) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),M),N) ) ).

% gcd_add_mult
tff(fact_2626_Sigma__mono,axiom,
    ! [C: $tType,B: $tType,A4: set(B),C5: set(B),B5: fun(B,set(C)),D4: fun(B,set(C))] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),C5)
     => ( ! [X3: B] :
            ( member(B,X3,A4)
           => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(B,set(C),B5,X3)),aa(B,set(C),D4,X3)) )
       => aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),product_Sigma(B,C,A4,B5)),product_Sigma(B,C,C5,D4)) ) ) ).

% Sigma_mono
tff(fact_2627_bezout__int,axiom,
    ! [X2: int,Y: int] :
    ? [U2: int,V4: int] : aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),U2),X2)),aa(int,int,aa(int,fun(int,int),times_times(int),V4),Y)) = aa(int,int,aa(int,fun(int,int),gcd_gcd(int),X2),Y) ).

% bezout_int
tff(fact_2628_Times__subset__cancel2,axiom,
    ! [B: $tType,C: $tType,X2: B,C5: set(B),A4: set(C),B5: set(C)] :
      ( member(B,X2,C5)
     => ( aa(set(product_prod(C,B)),$o,aa(set(product_prod(C,B)),fun(set(product_prod(C,B)),$o),ord_less_eq(set(product_prod(C,B))),product_Sigma(C,B,A4,aTP_Lamp_jr(set(B),fun(C,set(B)),C5))),product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),C5)))
      <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),A4),B5) ) ) ).

% Times_subset_cancel2
tff(fact_2629_UN__Times__distrib,axiom,
    ! [D: $tType,C: $tType,B: $tType,E: $tType,E4: fun(D,set(B)),F5: fun(E,set(C)),A4: set(D),B5: set(E)] : aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),aa(set(product_prod(D,E)),set(set(product_prod(B,C))),image2(product_prod(D,E),set(product_prod(B,C)),aa(fun(D,fun(E,set(product_prod(B,C)))),fun(product_prod(D,E),set(product_prod(B,C))),product_case_prod(D,E,set(product_prod(B,C))),aa(fun(E,set(C)),fun(D,fun(E,set(product_prod(B,C)))),aTP_Lamp_jz(fun(D,set(B)),fun(fun(E,set(C)),fun(D,fun(E,set(product_prod(B,C))))),E4),F5))),product_Sigma(D,E,A4,aTP_Lamp_ka(set(E),fun(D,set(E)),B5)))) = product_Sigma(B,C,aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(D),set(set(B)),image2(D,set(B),E4),A4)),aa(set(E),fun(B,set(C)),aTP_Lamp_kb(fun(E,set(C)),fun(set(E),fun(B,set(C))),F5),B5)) ).

% UN_Times_distrib
tff(fact_2630_mem__Times__iff,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(B,C),A4: set(B),B5: set(C)] :
      ( member(product_prod(B,C),X2,product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))
    <=> ( member(B,aa(product_prod(B,C),B,product_fst(B,C),X2),A4)
        & member(C,aa(product_prod(B,C),C,product_snd(B,C),X2),B5) ) ) ).

% mem_Times_iff
tff(fact_2631_in__prod__fst__sndI,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(B,C),A4: set(B),B5: set(C)] :
      ( member(B,aa(product_prod(B,C),B,product_fst(B,C),X2),A4)
     => ( member(C,aa(product_prod(B,C),C,product_snd(B,C),X2),B5)
       => member(product_prod(B,C),X2,product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5))) ) ) ).

% in_prod_fst_sndI
tff(fact_2632_swap__product,axiom,
    ! [B: $tType,C: $tType,A4: set(C),B5: set(B)] : aa(set(product_prod(C,B)),set(product_prod(B,C)),image2(product_prod(C,B),product_prod(B,C),aa(fun(C,fun(B,product_prod(B,C))),fun(product_prod(C,B),product_prod(B,C)),product_case_prod(C,B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))))),product_Sigma(C,B,A4,aTP_Lamp_jr(set(B),fun(C,set(B)),B5))) = product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),A4)) ).

% swap_product
tff(fact_2633_Sigma__empty__iff,axiom,
    ! [B: $tType,C: $tType,I4: set(B),X7: fun(B,set(C))] :
      ( ( product_Sigma(B,C,I4,X7) = bot_bot(set(product_prod(B,C))) )
    <=> ! [X4: B] :
          ( member(B,X4,I4)
         => ( aa(B,set(C),X7,X4) = bot_bot(set(C)) ) ) ) ).

% Sigma_empty_iff
tff(fact_2634_gcd__mult__unit2,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),B2),aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3)) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),B2),C2) ) ) ) ).

% gcd_mult_unit2
tff(fact_2635_gcd__mult__unit1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),A3)),C2) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),B2),C2) ) ) ) ).

% gcd_mult_unit1
tff(fact_2636_gcd__div__unit1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),C2) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),B2),C2) ) ) ) ).

% gcd_div_unit1
tff(fact_2637_gcd__div__unit2,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),B2),aa(B,B,aa(B,fun(B,B),divide_divide(B),C2),A3)) = aa(B,B,aa(B,fun(B,B),gcd_gcd(B),B2),C2) ) ) ) ).

% gcd_div_unit2
tff(fact_2638_less__int_Otransfer,axiom,
    aa(fun(int,fun(int,$o)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),fun(fun(int,fun(int,$o)),$o),bNF_rel_fun(product_prod(nat,nat),int,fun(product_prod(nat,nat),$o),fun(int,$o),pcr_int,bNF_rel_fun(product_prod(nat,nat),int,$o,$o,pcr_int,fequal($o))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o))))),ord_less(int)) ).

% less_int.transfer
tff(fact_2639_less__eq__int_Otransfer,axiom,
    aa(fun(int,fun(int,$o)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),fun(fun(int,fun(int,$o)),$o),bNF_rel_fun(product_prod(nat,nat),int,fun(product_prod(nat,nat),$o),fun(int,$o),pcr_int,bNF_rel_fun(product_prod(nat,nat),int,$o,$o,pcr_int,fequal($o))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o))))),ord_less_eq(int)) ).

% less_eq_int.transfer
tff(fact_2640_plus__int_Otransfer,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(product_prod(nat,nat),int,fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),pcr_int,bNF_rel_fun(product_prod(nat,nat),int,product_prod(nat,nat),int,pcr_int,pcr_int)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cr(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))),plus_plus(int)) ).

% plus_int.transfer
tff(fact_2641_minus__int_Otransfer,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(product_prod(nat,nat),int,fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),pcr_int,bNF_rel_fun(product_prod(nat,nat),int,product_prod(nat,nat),int,pcr_int,pcr_int)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_ct(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))),minus_minus(int)) ).

% minus_int.transfer
tff(fact_2642_times__subset__iff,axiom,
    ! [B: $tType,C: $tType,A4: set(B),C5: set(C),B5: set(B),D4: set(C)] :
      ( aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))),product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),D4)))
    <=> ( ( A4 = bot_bot(set(B)) )
        | ( C5 = bot_bot(set(C)) )
        | ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
          & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),C5),D4) ) ) ) ).

% times_subset_iff
tff(fact_2643_image__paired__Times,axiom,
    ! [D: $tType,C: $tType,B: $tType,E: $tType,F: fun(D,B),G: fun(E,C),A4: set(D),B5: set(E)] : aa(set(product_prod(D,E)),set(product_prod(B,C)),image2(product_prod(D,E),product_prod(B,C),aa(fun(D,fun(E,product_prod(B,C))),fun(product_prod(D,E),product_prod(B,C)),product_case_prod(D,E,product_prod(B,C)),aa(fun(E,C),fun(D,fun(E,product_prod(B,C))),aTP_Lamp_kc(fun(D,B),fun(fun(E,C),fun(D,fun(E,product_prod(B,C)))),F),G))),product_Sigma(D,E,A4,aTP_Lamp_ka(set(E),fun(D,set(E)),B5))) = product_Sigma(B,C,aa(set(D),set(B),image2(D,B,F),A4),aa(set(E),fun(B,set(C)),aTP_Lamp_kd(fun(E,C),fun(set(E),fun(B,set(C))),G),B5)) ).

% image_paired_Times
tff(fact_2644_fst__image__Sigma,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: fun(B,set(C))] : aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),product_Sigma(B,C,A4,B5)) = aa(fun(B,$o),set(B),collect(B),aa(fun(B,set(C)),fun(B,$o),aTP_Lamp_ke(set(B),fun(fun(B,set(C)),fun(B,$o)),A4),B5)) ).

% fst_image_Sigma
tff(fact_2645_Sigma__def,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: fun(B,set(C))] : product_Sigma(B,C,A4,B5) = aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),aa(set(B),set(set(product_prod(B,C))),image2(B,set(product_prod(B,C)),aTP_Lamp_kg(fun(B,set(C)),fun(B,set(product_prod(B,C))),B5)),A4)) ).

% Sigma_def
tff(fact_2646_times__int_Otransfer,axiom,
    aa(fun(int,fun(int,int)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(fun(int,fun(int,int)),$o),bNF_rel_fun(product_prod(nat,nat),int,fun(product_prod(nat,nat),product_prod(nat,nat)),fun(int,int),pcr_int,bNF_rel_fun(product_prod(nat,nat),int,product_prod(nat,nat),int,pcr_int,pcr_int)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cv(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))),times_times(int)) ).

% times_int.transfer
tff(fact_2647_num__of__integer_Orsp,axiom,
    aa(fun(int,num),$o,aa(fun(int,num),fun(fun(int,num),$o),bNF_rel_fun(int,int,num,num,fequal(int),fequal(num)),aa(fun(int,nat),fun(int,num),aa(fun(nat,num),fun(fun(int,nat),fun(int,num)),comp(nat,num,int),num_of_nat),nat2)),aa(fun(int,nat),fun(int,num),aa(fun(nat,num),fun(fun(int,nat),fun(int,num)),comp(nat,num,int),num_of_nat),nat2)) ).

% num_of_integer.rsp
tff(fact_2648_snd__image__Sigma,axiom,
    ! [B: $tType,C: $tType,A4: set(C),B5: fun(C,set(B))] : aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),product_Sigma(C,B,A4,B5)) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(C),set(set(B)),image2(C,set(B),B5),A4)) ).

% snd_image_Sigma
tff(fact_2649_subset__fst__snd,axiom,
    ! [C: $tType,B: $tType,A4: set(product_prod(B,C))] : aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),A4),product_Sigma(B,C,aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),A4),aTP_Lamp_kh(set(product_prod(B,C)),fun(B,set(C)),A4))) ).

% subset_fst_snd
tff(fact_2650_int__transfer,axiom,
    aa(fun(nat,int),$o,aa(fun(nat,product_prod(nat,nat)),fun(fun(nat,int),$o),bNF_rel_fun(nat,nat,product_prod(nat,nat),int,fequal(nat),pcr_int),aTP_Lamp_ki(nat,product_prod(nat,nat))),semiring_1_of_nat(int)) ).

% int_transfer
tff(fact_2651_uminus__int_Otransfer,axiom,
    aa(fun(int,int),$o,aa(fun(product_prod(nat,nat),product_prod(nat,nat)),fun(fun(int,int),$o),bNF_rel_fun(product_prod(nat,nat),int,product_prod(nat,nat),int,pcr_int,pcr_int),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_bo(nat,fun(nat,product_prod(nat,nat))))),uminus_uminus(int)) ).

% uminus_int.transfer
tff(fact_2652_eq__fst__iff,axiom,
    ! [B: $tType,C: $tType,A3: B,P3: product_prod(B,C)] :
      ( ( A3 = aa(product_prod(B,C),B,product_fst(B,C),P3) )
    <=> ? [B7: C] : P3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B7) ) ).

% eq_fst_iff
tff(fact_2653_transfer__rule__of__nat,axiom,
    ! [B: $tType,C: $tType] :
      ( ( semiring_1(C)
        & semiring_1(B) )
     => ! [R4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),R4,zero_zero(B)),zero_zero(C))
         => ( aa(C,$o,aa(B,fun(C,$o),R4,one_one(B)),one_one(C))
           => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),R4,bNF_rel_fun(B,C,B,C,R4,R4)),plus_plus(B)),plus_plus(C))
             => aa(fun(nat,C),$o,aa(fun(nat,B),fun(fun(nat,C),$o),bNF_rel_fun(nat,nat,B,C,fequal(nat),R4),semiring_1_of_nat(B)),semiring_1_of_nat(C)) ) ) ) ) ).

% transfer_rule_of_nat
tff(fact_2654_transfer__rule__of__bool,axiom,
    ! [B: $tType,C: $tType] :
      ( ( zero_neq_one(C)
        & zero_neq_one(B) )
     => ! [R4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),R4,zero_zero(B)),zero_zero(C))
         => ( aa(C,$o,aa(B,fun(C,$o),R4,one_one(B)),one_one(C))
           => aa(fun($o,C),$o,aa(fun($o,B),fun(fun($o,C),$o),bNF_rel_fun($o,$o,B,C,fequal($o),R4),zero_neq_one_of_bool(B)),zero_neq_one_of_bool(C)) ) ) ) ).

% transfer_rule_of_bool
tff(fact_2655_plus__rat_Otransfer,axiom,
    aa(fun(rat,fun(rat,rat)),$o,aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),fun(fun(rat,fun(rat,rat)),$o),bNF_rel_fun(product_prod(int,int),rat,fun(product_prod(int,int),product_prod(int,int)),fun(rat,rat),pcr_rat,bNF_rel_fun(product_prod(int,int),rat,product_prod(int,int),rat,pcr_rat,pcr_rat)),aTP_Lamp_kj(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))),plus_plus(rat)) ).

% plus_rat.transfer
tff(fact_2656_inverse__rat_Otransfer,axiom,
    aa(fun(rat,rat),$o,aa(fun(product_prod(int,int),product_prod(int,int)),fun(fun(rat,rat),$o),bNF_rel_fun(product_prod(int,int),rat,product_prod(int,int),rat,pcr_rat,pcr_rat),aTP_Lamp_kk(product_prod(int,int),product_prod(int,int))),inverse_inverse(rat)) ).

% inverse_rat.transfer
tff(fact_2657_Id__on__def,axiom,
    ! [B: $tType,A4: set(B)] : id_on(B,A4) = aa(set(set(product_prod(B,B))),set(product_prod(B,B)),complete_Sup_Sup(set(product_prod(B,B))),aa(set(B),set(set(product_prod(B,B))),image2(B,set(product_prod(B,B)),aTP_Lamp_kl(B,set(product_prod(B,B)))),A4)) ).

% Id_on_def
tff(fact_2658_times__rat_Otransfer,axiom,
    aa(fun(rat,fun(rat,rat)),$o,aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),fun(fun(rat,fun(rat,rat)),$o),bNF_rel_fun(product_prod(int,int),rat,fun(product_prod(int,int),product_prod(int,int)),fun(rat,rat),pcr_rat,bNF_rel_fun(product_prod(int,int),rat,product_prod(int,int),rat,pcr_rat,pcr_rat)),aTP_Lamp_km(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))),times_times(rat)) ).

% times_rat.transfer
tff(fact_2659_gcd__1__nat,axiom,
    ! [M: nat] : aa(nat,nat,aa(nat,fun(nat,nat),gcd_gcd(nat),M),one_one(nat)) = one_one(nat) ).

% gcd_1_nat
tff(fact_2660_Id__onI,axiom,
    ! [B: $tType,A3: B,A4: set(B)] :
      ( member(B,A3,A4)
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3),id_on(B,A4)) ) ).

% Id_onI
tff(fact_2661_unset__bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se2638667681897837118et_bit(nat)),bit_se2638667681897837118et_bit(nat)) ).

% unset_bit_natural.rsp
tff(fact_2662_take__bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se2584673776208193580ke_bit(nat)),bit_se2584673776208193580ke_bit(nat)) ).

% take_bit_natural.rsp
tff(fact_2663_bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,$o)),$o,aa(fun(nat,fun(nat,$o)),fun(fun(nat,fun(nat,$o)),$o),bNF_rel_fun(nat,nat,fun(nat,$o),fun(nat,$o),fequal(nat),fequal(fun(nat,$o))),bit_se5641148757651400278ts_bit(nat)),bit_se5641148757651400278ts_bit(nat)) ).

% bit_natural.rsp
tff(fact_2664_drop__bit__natural_Orsp,axiom,
    aa(fun(nat,fun(nat,nat)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(nat,nat)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(nat,nat),fequal(nat),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat))),bit_se4197421643247451524op_bit(nat)),bit_se4197421643247451524op_bit(nat)) ).

% drop_bit_natural.rsp
tff(fact_2665_Id__on__iff,axiom,
    ! [B: $tType,X2: B,Y: B,A4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),id_on(B,A4))
    <=> ( ( X2 = Y )
        & member(B,X2,A4) ) ) ).

% Id_on_iff
tff(fact_2666_Id__on__eqI,axiom,
    ! [B: $tType,A3: B,B2: B,A4: set(B)] :
      ( ( A3 = B2 )
     => ( member(B,A3,A4)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),id_on(B,A4)) ) ) ).

% Id_on_eqI
tff(fact_2667_Id__onE,axiom,
    ! [B: $tType,C2: product_prod(B,B),A4: set(B)] :
      ( member(product_prod(B,B),C2,id_on(B,A4))
     => ~ ! [X3: B] :
            ( member(B,X3,A4)
           => ( C2 != aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3) ) ) ) ).

% Id_onE
tff(fact_2668_bezout__nat,axiom,
    ! [A3: nat,B2: nat] :
      ( ( A3 != zero_zero(nat) )
     => ? [X3: nat,Y4: nat] : aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),A3),X3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),B2),Y4)),aa(nat,nat,aa(nat,fun(nat,nat),gcd_gcd(nat),A3),B2)) ) ).

% bezout_nat
tff(fact_2669_one__rat_Otransfer,axiom,
    aa(rat,$o,aa(product_prod(int,int),fun(rat,$o),pcr_rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),one_one(int))),one_one(rat)) ).

% one_rat.transfer
tff(fact_2670_zero__rat_Otransfer,axiom,
    aa(rat,$o,aa(product_prod(int,int),fun(rat,$o),pcr_rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int))),zero_zero(rat)) ).

% zero_rat.transfer
tff(fact_2671_bezw__aux,axiom,
    ! [X2: nat,Y: nat] : aa(nat,int,semiring_1_of_nat(int),aa(nat,nat,aa(nat,fun(nat,nat),gcd_gcd(nat),X2),Y)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),bezw(X2,Y))),aa(nat,int,semiring_1_of_nat(int),X2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),bezw(X2,Y))),aa(nat,int,semiring_1_of_nat(int),Y))) ).

% bezw_aux
tff(fact_2672_uminus__rat_Otransfer,axiom,
    aa(fun(rat,rat),$o,aa(fun(product_prod(int,int),product_prod(int,int)),fun(fun(rat,rat),$o),bNF_rel_fun(product_prod(int,int),rat,product_prod(int,int),rat,pcr_rat,pcr_rat),aTP_Lamp_kn(product_prod(int,int),product_prod(int,int))),uminus_uminus(rat)) ).

% uminus_rat.transfer
tff(fact_2673_gcd__nat_Opelims,axiom,
    ! [X2: nat,Xa: nat,Y: nat] :
      ( ( aa(nat,nat,aa(nat,fun(nat,nat),gcd_gcd(nat),X2),Xa) = Y )
     => ( aa(product_prod(nat,nat),$o,accp(product_prod(nat,nat),gcd_nat_rel),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Xa))
       => ~ ( ( Y = $ite(Xa = zero_zero(nat),X2,aa(nat,nat,aa(nat,fun(nat,nat),gcd_gcd(nat),Xa),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),X2),Xa))) )
           => ~ aa(product_prod(nat,nat),$o,accp(product_prod(nat,nat),gcd_nat_rel),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Xa)) ) ) ) ).

% gcd_nat.pelims
tff(fact_2674_o__rsp_I1_J,axiom,
    ! [B: $tType,C: $tType,F4: $tType,G2: $tType,E: $tType,D: $tType,R23: fun(B,fun(D,$o)),R32: fun(C,fun(E,$o)),R12: fun(F4,fun(G2,$o))] : aa(fun(fun(D,E),fun(fun(G2,D),fun(G2,E))),$o,aa(fun(fun(B,C),fun(fun(F4,B),fun(F4,C))),fun(fun(fun(D,E),fun(fun(G2,D),fun(G2,E))),$o),bNF_rel_fun(fun(B,C),fun(D,E),fun(fun(F4,B),fun(F4,C)),fun(fun(G2,D),fun(G2,E)),bNF_rel_fun(B,D,C,E,R23,R32),bNF_rel_fun(fun(F4,B),fun(G2,D),fun(F4,C),fun(G2,E),bNF_rel_fun(F4,G2,B,D,R12,R23),bNF_rel_fun(F4,G2,C,E,R12,R32))),comp(B,C,F4)),comp(D,E,G2)) ).

% o_rsp(1)
tff(fact_2675_o__rsp_I2_J,axiom,
    ! [D: $tType,E: $tType,C: $tType,B: $tType,R12: fun(D,fun(E,$o))] : aa(fun(fun(B,C),fun(fun(E,B),fun(E,C))),$o,aa(fun(fun(B,C),fun(fun(D,B),fun(D,C))),fun(fun(fun(B,C),fun(fun(E,B),fun(E,C))),$o),bNF_rel_fun(fun(B,C),fun(B,C),fun(fun(D,B),fun(D,C)),fun(fun(E,B),fun(E,C)),fequal(fun(B,C)),bNF_rel_fun(fun(D,B),fun(E,B),fun(D,C),fun(E,C),bNF_rel_fun(D,E,B,B,R12,fequal(B)),bNF_rel_fun(D,E,C,C,R12,fequal(C)))),comp(B,C,D)),comp(B,C,E)) ).

% o_rsp(2)
tff(fact_2676_apfst__convE,axiom,
    ! [D: $tType,B: $tType,C: $tType,Q3: product_prod(B,C),F: fun(D,B),P3: product_prod(D,C)] :
      ( ( Q3 = aa(product_prod(D,C),product_prod(B,C),product_apfst(D,B,C,F),P3) )
     => ~ ! [X3: D,Y4: C] :
            ( ( P3 = aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),X3),Y4) )
           => ( Q3 != aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,F,X3)),Y4) ) ) ) ).

% apfst_convE
tff(fact_2677_UN__le__eq__Un0,axiom,
    ! [B: $tType,M2: fun(nat,set(B)),N: nat] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),M2),aa(nat,set(nat),set_ord_atMost(nat),N))) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),M2),set_or1337092689740270186AtMost(nat,one_one(nat),N)))),aa(nat,set(B),M2,zero_zero(nat))) ).

% UN_le_eq_Un0
tff(fact_2678_times__int_Orsp,axiom,
    aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),$o),bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),fun(product_prod(nat,nat),product_prod(nat,nat)),intrel,bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),intrel,intrel)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cv(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cv(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))) ).

% times_int.rsp
tff(fact_2679_sup__Some,axiom,
    ! [B: $tType] :
      ( sup(B)
     => ! [X2: B,Y: B] : aa(option(B),option(B),aa(option(B),fun(option(B),option(B)),sup_sup(option(B)),aa(B,option(B),some(B),X2)),aa(B,option(B),some(B),Y)) = aa(B,option(B),some(B),aa(B,B,aa(B,fun(B,B),sup_sup(B),X2),Y)) ) ).

% sup_Some
tff(fact_2680_intrel__iff,axiom,
    ! [X2: nat,Y: nat,U: nat,V: nat] :
      ( aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),intrel,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),Y)),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),U),V))
    <=> ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X2),V) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),U),Y) ) ) ).

% intrel_iff
tff(fact_2681_insert__Times__insert,axiom,
    ! [B: $tType,C: $tType,A3: B,A4: set(B),B2: C,B5: set(C)] : product_Sigma(B,C,aa(set(B),set(B),insert2(B,A3),A4),aa(set(C),fun(B,set(C)),aTP_Lamp_ko(C,fun(set(C),fun(B,set(C))),B2),B5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),insert2(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)),aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),sup_sup(set(product_prod(B,C))),product_Sigma(B,C,A4,aa(set(C),fun(B,set(C)),aTP_Lamp_ko(C,fun(set(C),fun(B,set(C))),B2),B5))),product_Sigma(B,C,aa(set(B),set(B),insert2(B,A3),A4),aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))) ).

% insert_Times_insert
tff(fact_2682_Sigma__Un__distrib1,axiom,
    ! [C: $tType,B: $tType,I4: set(B),J4: set(B),C5: fun(B,set(C))] : product_Sigma(B,C,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),I4),J4),C5) = aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),sup_sup(set(product_prod(B,C))),product_Sigma(B,C,I4,C5)),product_Sigma(B,C,J4,C5)) ).

% Sigma_Un_distrib1
tff(fact_2683_Sigma__Un__distrib2,axiom,
    ! [C: $tType,B: $tType,I4: set(B),A4: fun(B,set(C)),B5: fun(B,set(C))] : product_Sigma(B,C,I4,aa(fun(B,set(C)),fun(B,set(C)),aTP_Lamp_kp(fun(B,set(C)),fun(fun(B,set(C)),fun(B,set(C))),A4),B5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),sup_sup(set(product_prod(B,C))),product_Sigma(B,C,I4,A4)),product_Sigma(B,C,I4,B5)) ).

% Sigma_Un_distrib2
tff(fact_2684_Times__Un__distrib1,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(B),C5: set(C)] : product_Sigma(B,C,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5),aTP_Lamp_jm(set(C),fun(B,set(C)),C5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),sup_sup(set(product_prod(B,C))),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))),product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))) ).

% Times_Un_distrib1
tff(fact_2685_set__diff__diff__left,axiom,
    ! [B: $tType,A4: set(B),B5: set(B),C5: set(B)] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5)),C5) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),B5),C5)) ).

% set_diff_diff_left
tff(fact_2686_sup__option__def,axiom,
    ! [B: $tType] :
      ( sup(B)
     => ! [X2: option(B),Y: option(B)] : aa(option(B),option(B),aa(option(B),fun(option(B),option(B)),sup_sup(option(B)),X2),Y) = aa(option(B),option(B),aa(fun(B,option(B)),fun(option(B),option(B)),aa(option(B),fun(fun(B,option(B)),fun(option(B),option(B))),case_option(option(B),B),Y),aa(option(B),fun(B,option(B)),aTP_Lamp_kr(option(B),fun(option(B),fun(B,option(B))),X2),Y)),X2) ) ).

% sup_option_def
tff(fact_2687_ivl__disj__un__two__touch_I4_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or1337092689740270186AtMost(B,L,M)),set_or1337092689740270186AtMost(B,M,U)) = set_or1337092689740270186AtMost(B,L,U) ) ) ) ) ).

% ivl_disj_un_two_touch(4)
tff(fact_2688_ivl__disj__un__two_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or7035219750837199246ssThan(B,L,M)),set_or7035219750837199246ssThan(B,M,U)) = set_or7035219750837199246ssThan(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(3)
tff(fact_2689_max__ext__additive,axiom,
    ! [B: $tType,A4: set(B),B5: set(B),R4: set(product_prod(B,B)),C5: set(B),D4: set(B)] :
      ( member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),A4),B5),max_ext(B,R4))
     => ( member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),C5),D4),max_ext(B,R4))
       => member(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),C5)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),B5),D4)),max_ext(B,R4)) ) ) ).

% max_ext_additive
tff(fact_2690_zero__int_Orsp,axiom,
    aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),intrel,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),zero_zero(nat)),zero_zero(nat))),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),zero_zero(nat)),zero_zero(nat))) ).

% zero_int.rsp
tff(fact_2691_ivl__disj__un__two_I7_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or7035219750837199246ssThan(B,L,M)),set_or1337092689740270186AtMost(B,M,U)) = set_or1337092689740270186AtMost(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(7)
tff(fact_2692_card__Un__le,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] : aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,A4)),finite_card(B,B5))) ).

% card_Un_le
tff(fact_2693_ivl__disj__un__one_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(B,set(B),set_ord_lessThan(B),L)),set_or7035219750837199246ssThan(B,L,U)) = aa(B,set(B),set_ord_lessThan(B),U) ) ) ) ).

% ivl_disj_un_one(2)
tff(fact_2694_atLeastLessThan__add__Un,axiom,
    ! [I: nat,J: nat,K: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( set_or7035219750837199246ssThan(nat,I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K)) = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),set_or7035219750837199246ssThan(nat,I,J)),set_or7035219750837199246ssThan(nat,J,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),K))) ) ) ).

% atLeastLessThan_add_Un
tff(fact_2695_uminus__int_Orsp,axiom,
    aa(fun(product_prod(nat,nat),product_prod(nat,nat)),$o,aa(fun(product_prod(nat,nat),product_prod(nat,nat)),fun(fun(product_prod(nat,nat),product_prod(nat,nat)),$o),bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),intrel,intrel),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_bo(nat,fun(nat,product_prod(nat,nat))))),aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aTP_Lamp_bo(nat,fun(nat,product_prod(nat,nat))))) ).

% uminus_int.rsp
tff(fact_2696_one__int_Orsp,axiom,
    aa(product_prod(nat,nat),$o,aa(product_prod(nat,nat),fun(product_prod(nat,nat),$o),intrel,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),one_one(nat)),zero_zero(nat))),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),one_one(nat)),zero_zero(nat))) ).

% one_int.rsp
tff(fact_2697_ivl__disj__un__two__touch_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or1337092689740270186AtMost(B,L,M)),set_or7035219750837199246ssThan(B,M,U)) = set_or7035219750837199246ssThan(B,L,U) ) ) ) ) ).

% ivl_disj_un_two_touch(2)
tff(fact_2698_ivl__disj__un__two_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or5935395276787703475ssThan(B,L,M)),set_or7035219750837199246ssThan(B,M,U)) = set_or5935395276787703475ssThan(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(1)
tff(fact_2699_ivl__disj__un__singleton_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [U: B] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(B,set(B),set_ord_lessThan(B),U)),aa(set(B),set(B),insert2(B,U),bot_bot(set(B)))) = aa(B,set(B),set_ord_atMost(B),U) ) ).

% ivl_disj_un_singleton(2)
tff(fact_2700_ivl__disj__un__one_I4_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(B,set(B),set_ord_lessThan(B),L)),set_or1337092689740270186AtMost(B,L,U)) = aa(B,set(B),set_ord_atMost(B),U) ) ) ) ).

% ivl_disj_un_one(4)
tff(fact_2701_ivl__disj__un__one_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(B,set(B),set_ord_atMost(B),L)),set_or5935395276787703475ssThan(B,L,U)) = aa(B,set(B),set_ord_lessThan(B),U) ) ) ) ).

% ivl_disj_un_one(1)
tff(fact_2702_intrel__def,axiom,
    intrel = aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_kt(nat,fun(nat,fun(product_prod(nat,nat),$o)))) ).

% intrel_def
tff(fact_2703_ivl__disj__un__singleton_I6_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or7035219750837199246ssThan(B,L,U)),aa(set(B),set(B),insert2(B,U),bot_bot(set(B)))) = set_or1337092689740270186AtMost(B,L,U) ) ) ) ).

% ivl_disj_un_singleton(6)
tff(fact_2704_ivl__disj__un__singleton_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(B),set(B),insert2(B,L),bot_bot(set(B)))),set_or5935395276787703475ssThan(B,L,U)) = set_or7035219750837199246ssThan(B,L,U) ) ) ) ).

% ivl_disj_un_singleton(3)
tff(fact_2705_ivl__disj__un__two_I4_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or1337092689740270186AtMost(B,L,M)),set_or5935395276787703475ssThan(B,M,U)) = set_or7035219750837199246ssThan(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(4)
tff(fact_2706_less__int_Orsp,axiom,
    aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),fun(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),$o),bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),fun(product_prod(nat,nat),$o),fun(product_prod(nat,nat),$o),intrel,bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),$o,$o,intrel,fequal($o))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o))))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o))))) ).

% less_int.rsp
tff(fact_2707_less__eq__int_Orsp,axiom,
    aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),fun(fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),$o),bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),fun(product_prod(nat,nat),$o),fun(product_prod(nat,nat),$o),intrel,bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),$o,$o,intrel,fequal($o))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o))))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),$o))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),$o)),product_case_prod(nat,nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o))))) ).

% less_eq_int.rsp
tff(fact_2708_plus__int_Orsp,axiom,
    aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),$o),bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),fun(product_prod(nat,nat),product_prod(nat,nat)),intrel,bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),intrel,intrel)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cr(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cr(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))) ).

% plus_int.rsp
tff(fact_2709_minus__int_Orsp,axiom,
    aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),$o,aa(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),fun(fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),$o),bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat)),fun(product_prod(nat,nat),product_prod(nat,nat)),intrel,bNF_rel_fun(product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),product_prod(nat,nat),intrel,intrel)),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_ct(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))),aa(fun(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),fun(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(nat,nat))),product_case_prod(nat,nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_ct(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))))) ).

% minus_int.rsp
tff(fact_2710_max__weak__def,axiom,
    fun_max_weak = aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),fun(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),sup_sup(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),max_ext(product_prod(nat,nat),fun_pair_leq)),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),insert2(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),bot_bot(set(product_prod(nat,nat)))),bot_bot(set(product_prod(nat,nat))))),bot_bot(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))))) ).

% max_weak_def
tff(fact_2711_min__weak__def,axiom,
    fun_min_weak = aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),fun(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),sup_sup(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))),min_ext(product_prod(nat,nat),fun_pair_leq)),aa(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),insert2(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),bot_bot(set(product_prod(nat,nat)))),bot_bot(set(product_prod(nat,nat))))),bot_bot(set(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))))))) ).

% min_weak_def
tff(fact_2712_fold__union__pair,axiom,
    ! [C: $tType,B: $tType,B5: set(B),X2: C,A4: set(product_prod(C,B))] :
      ( finite_finite2(B,B5)
     => ( aa(set(product_prod(C,B)),set(product_prod(C,B)),aa(set(product_prod(C,B)),fun(set(product_prod(C,B)),set(product_prod(C,B))),sup_sup(set(product_prod(C,B))),aa(set(set(product_prod(C,B))),set(product_prod(C,B)),complete_Sup_Sup(set(product_prod(C,B))),aa(set(B),set(set(product_prod(C,B))),image2(B,set(product_prod(C,B)),aTP_Lamp_ku(C,fun(B,set(product_prod(C,B))),X2)),B5))),A4) = finite_fold(B,set(product_prod(C,B)),aTP_Lamp_kv(C,fun(B,fun(set(product_prod(C,B)),set(product_prod(C,B)))),X2),A4,B5) ) ) ).

% fold_union_pair
tff(fact_2713_Field__insert,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] : field2(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2)),R)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(B),set(B),insert2(B,A3),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))),field2(B,R)) ).

% Field_insert
tff(fact_2714_set__to__map__insert,axiom,
    ! [C: $tType,B: $tType,Kv: product_prod(B,C),S2: set(product_prod(B,C))] :
      ( ~ member(B,aa(product_prod(B,C),B,product_fst(B,C),Kv),aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),S2))
     => ( set_to_map(B,C,aa(set(product_prod(B,C)),set(product_prod(B,C)),insert2(product_prod(B,C),Kv),S2)) = fun_upd(B,option(C),set_to_map(B,C,S2),aa(product_prod(B,C),B,product_fst(B,C),Kv),aa(C,option(C),some(C),aa(product_prod(B,C),C,product_snd(B,C),Kv))) ) ) ).

% set_to_map_insert
tff(fact_2715_plus__rat_Orsp,axiom,
    aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),$o,aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),fun(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),$o),bNF_rel_fun(product_prod(int,int),product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)),fun(product_prod(int,int),product_prod(int,int)),ratrel,bNF_rel_fun(product_prod(int,int),product_prod(int,int),product_prod(int,int),product_prod(int,int),ratrel,ratrel)),aTP_Lamp_kj(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))),aTP_Lamp_kj(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))) ).

% plus_rat.rsp
tff(fact_2716_inverse__rat_Orsp,axiom,
    aa(fun(product_prod(int,int),product_prod(int,int)),$o,aa(fun(product_prod(int,int),product_prod(int,int)),fun(fun(product_prod(int,int),product_prod(int,int)),$o),bNF_rel_fun(product_prod(int,int),product_prod(int,int),product_prod(int,int),product_prod(int,int),ratrel,ratrel),aTP_Lamp_kk(product_prod(int,int),product_prod(int,int))),aTP_Lamp_kk(product_prod(int,int),product_prod(int,int))) ).

% inverse_rat.rsp
tff(fact_2717_fun__upd__upd,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),X2: B,Y: C,Z2: C] : fun_upd(B,C,fun_upd(B,C,F,X2,Y),X2,Z2) = fun_upd(B,C,F,X2,Z2) ).

% fun_upd_upd
tff(fact_2718_fun__upd__triv,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),X2: B] : fun_upd(B,C,F,X2,aa(B,C,F,X2)) = F ).

% fun_upd_triv
tff(fact_2719_fun__upd__apply,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: C,Y: B,Z2: C] :
      aa(C,B,fun_upd(C,B,F,X2,Y),Z2) = $ite(Z2 = X2,Y,aa(C,B,F,Z2)) ).

% fun_upd_apply
tff(fact_2720_image__update,axiom,
    ! [C: $tType,B: $tType,X2: B,A4: set(B),F: fun(B,C),N: C] :
      ( ~ member(B,X2,A4)
     => ( aa(set(B),set(C),image2(B,C,fun_upd(B,C,F,X2,N)),A4) = aa(set(B),set(C),image2(B,C,F),A4) ) ) ).

% image_update
tff(fact_2721_empty__upd__none,axiom,
    ! [B: $tType,C: $tType,X2: B,X: B] : aa(B,option(C),fun_upd(B,option(C),aTP_Lamp_hj(B,option(C)),X2,none(C)),X) = none(C) ).

% empty_upd_none
tff(fact_2722_sup__None__1,axiom,
    ! [B: $tType] :
      ( sup(B)
     => ! [Y: option(B)] : aa(option(B),option(B),aa(option(B),fun(option(B),option(B)),sup_sup(option(B)),none(B)),Y) = Y ) ).

% sup_None_1
tff(fact_2723_sup__None__2,axiom,
    ! [B: $tType] :
      ( sup(B)
     => ! [X2: option(B)] : aa(option(B),option(B),aa(option(B),fun(option(B),option(B)),sup_sup(option(B)),X2),none(B)) = X2 ) ).

% sup_None_2
tff(fact_2724_finite__Field__eq__finite,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( finite_finite2(B,field2(B,R4))
    <=> finite_finite2(product_prod(B,B),R4) ) ).

% finite_Field_eq_finite
tff(fact_2725_image__map__upd,axiom,
    ! [C: $tType,B: $tType,X2: B,A4: set(B),M: fun(B,option(C)),Y: C] :
      ( ~ member(B,X2,A4)
     => ( aa(set(B),set(option(C)),image2(B,option(C),fun_upd(B,option(C),M,X2,aa(C,option(C),some(C),Y))),A4) = aa(set(B),set(option(C)),image2(B,option(C),M),A4) ) ) ).

% image_map_upd
tff(fact_2726_map__option__o__map__upd,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,C),M: fun(B,option(D)),A3: B,B2: D] : aa(fun(B,option(D)),fun(B,option(C)),aa(fun(option(D),option(C)),fun(fun(B,option(D)),fun(B,option(C))),comp(option(D),option(C),B),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F)),fun_upd(B,option(D),M,A3,aa(D,option(D),some(D),B2))) = fun_upd(B,option(C),aa(fun(B,option(D)),fun(B,option(C)),aa(fun(option(D),option(C)),fun(fun(B,option(D)),fun(B,option(C))),comp(option(D),option(C),B),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F)),M),A3,aa(C,option(C),some(C),aa(D,C,F,B2))) ).

% map_option_o_map_upd
tff(fact_2727_fun__upd__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A3: B,B2: C,X: B] :
      aa(B,C,fun_upd(B,C,F,A3,B2),X) = $ite(X = A3,B2,aa(B,C,F,X)) ).

% fun_upd_def
tff(fact_2728_fun__upd__eqD,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),X2: B,Y: C,G: fun(B,C),Z2: C] :
      ( ( fun_upd(B,C,F,X2,Y) = fun_upd(B,C,G,X2,Z2) )
     => ( Y = Z2 ) ) ).

% fun_upd_eqD
tff(fact_2729_fun__upd__idem,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: C,Y: B] :
      ( ( aa(C,B,F,X2) = Y )
     => ( fun_upd(C,B,F,X2,Y) = F ) ) ).

% fun_upd_idem
tff(fact_2730_fun__upd__same,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),X2: C,Y: B] : aa(C,B,fun_upd(C,B,F,X2,Y),X2) = Y ).

% fun_upd_same
tff(fact_2731_fun__upd__other,axiom,
    ! [C: $tType,B: $tType,Z2: B,X2: B,F: fun(B,C),Y: C] :
      ( ( Z2 != X2 )
     => ( aa(B,C,fun_upd(B,C,F,X2,Y),Z2) = aa(B,C,F,Z2) ) ) ).

% fun_upd_other
tff(fact_2732_fun__upd__twist,axiom,
    ! [B: $tType,C: $tType,A3: B,C2: B,M: fun(B,C),B2: C,D3: C] :
      ( ( A3 != C2 )
     => ( fun_upd(B,C,fun_upd(B,C,M,A3,B2),C2,D3) = fun_upd(B,C,fun_upd(B,C,M,C2,D3),A3,B2) ) ) ).

% fun_upd_twist
tff(fact_2733_fun__upd__idem__iff,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),X2: B,Y: C] :
      ( ( fun_upd(B,C,F,X2,Y) = F )
    <=> ( aa(B,C,F,X2) = Y ) ) ).

% fun_upd_idem_iff
tff(fact_2734_map__upd__Some__unfold,axiom,
    ! [C: $tType,B: $tType,M: fun(C,option(B)),A3: C,B2: B,X2: C,Y: B] :
      ( ( aa(C,option(B),fun_upd(C,option(B),M,A3,aa(B,option(B),some(B),B2)),X2) = aa(B,option(B),some(B),Y) )
    <=> ( ( ( X2 = A3 )
          & ( B2 = Y ) )
        | ( ( X2 != A3 )
          & ( aa(C,option(B),M,X2) = aa(B,option(B),some(B),Y) ) ) ) ) ).

% map_upd_Some_unfold
tff(fact_2735_map__upd__triv,axiom,
    ! [B: $tType,C: $tType,T2: fun(C,option(B)),K: C,X2: B] :
      ( ( aa(C,option(B),T2,K) = aa(B,option(B),some(B),X2) )
     => ( fun_upd(C,option(B),T2,K,aa(B,option(B),some(B),X2)) = T2 ) ) ).

% map_upd_triv
tff(fact_2736_map__upd__eqD1,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),A3: B,X2: C,N: fun(B,option(C)),Y: C] :
      ( ( fun_upd(B,option(C),M,A3,aa(C,option(C),some(C),X2)) = fun_upd(B,option(C),N,A3,aa(C,option(C),some(C),Y)) )
     => ( X2 = Y ) ) ).

% map_upd_eqD1
tff(fact_2737_FieldI2,axiom,
    ! [B: $tType,I: B,J: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),I),J),R4)
     => member(B,J,field2(B,R4)) ) ).

% FieldI2
tff(fact_2738_FieldI1,axiom,
    ! [B: $tType,I: B,J: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),I),J),R4)
     => member(B,I,field2(B,R4)) ) ).

% FieldI1
tff(fact_2739_sup__Un__eq2,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(B,C)),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aa(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),sup_sup(fun(B,fun(C,$o))),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R4)),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),S2)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),sup_sup(set(product_prod(B,C))),R4),S2)) ) ).

% sup_Un_eq2
tff(fact_2740_fun__upd__comp,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,C),G: fun(B,D),X2: B,Y: D] : aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),fun_upd(B,D,G,X2,Y)) = fun_upd(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G),X2,aa(D,C,F,Y)) ).

% fun_upd_comp
tff(fact_2741_map__upd__nonempty,axiom,
    ! [B: $tType,C: $tType,T2: fun(B,option(C)),K: B,X2: C] :
      ~ ! [X3: B] : aa(B,option(C),fun_upd(B,option(C),T2,K,aa(C,option(C),some(C),X2)),X3) = none(C) ).

% map_upd_nonempty
tff(fact_2742_one__rat_Orsp,axiom,
    aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),one_one(int))),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),one_one(int))) ).

% one_rat.rsp
tff(fact_2743_R__subset__Field,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),product_Sigma(B,B,field2(B,R4),aTP_Lamp_kw(set(product_prod(B,B)),fun(B,set(B)),R4))) ).

% R_subset_Field
tff(fact_2744_fst__in__Field,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(product_prod(B,B)),set(B),image2(product_prod(B,B),B,product_fst(B,B)),R4)),field2(B,R4)) ).

% fst_in_Field
tff(fact_2745_snd__in__Field,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(product_prod(B,B)),set(B),image2(product_prod(B,B),B,product_snd(B,B)),R4)),field2(B,R4)) ).

% snd_in_Field
tff(fact_2746_zero__rat_Orsp,axiom,
    aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int))),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int))) ).

% zero_rat.rsp
tff(fact_2747_Fract_Orsp,axiom,
    aa(fun(int,fun(int,product_prod(int,int))),$o,aa(fun(int,fun(int,product_prod(int,int))),fun(fun(int,fun(int,product_prod(int,int))),$o),bNF_rel_fun(int,int,fun(int,product_prod(int,int)),fun(int,product_prod(int,int)),fequal(int),bNF_rel_fun(int,int,product_prod(int,int),product_prod(int,int),fequal(int),ratrel)),aTP_Lamp_kx(int,fun(int,product_prod(int,int)))),aTP_Lamp_kx(int,fun(int,product_prod(int,int)))) ).

% Fract.rsp
tff(fact_2748_sum_Oeq__fold,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(C,B),A4: set(C)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7311177749621191930dd_sum(C,B),G),A4) = finite_fold(C,B,aa(fun(C,B),fun(C,fun(B,B)),aa(fun(B,fun(B,B)),fun(fun(C,B),fun(C,fun(B,B))),comp(B,fun(B,B),C),plus_plus(B)),G),zero_zero(B),A4) ) ).

% sum.eq_fold
tff(fact_2749_prod_Oeq__fold,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(B)
     => ! [G: fun(C,B),A4: set(C)] : aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups7121269368397514597t_prod(C,B),G),A4) = finite_fold(C,B,aa(fun(C,B),fun(C,fun(B,B)),aa(fun(B,fun(B,B)),fun(fun(C,B),fun(C,fun(B,B))),comp(B,fun(B,B),C),times_times(B)),G),one_one(B),A4) ) ).

% prod.eq_fold
tff(fact_2750_finite__range__updI,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),A3: C,B2: B] :
      ( finite_finite2(option(B),aa(set(C),set(option(B)),image2(C,option(B),F),top_top(set(C))))
     => finite_finite2(option(B),aa(set(C),set(option(B)),image2(C,option(B),fun_upd(C,option(B),F,A3,aa(B,option(B),some(B),B2))),top_top(set(C)))) ) ).

% finite_range_updI
tff(fact_2751_fun__upd__image,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: C,Y: B,A4: set(C)] :
      aa(set(C),set(B),image2(C,B,fun_upd(C,B,F,X2,Y)),A4) = $ite(member(C,X2,A4),aa(set(B),set(B),insert2(B,Y),aa(set(C),set(B),image2(C,B,F),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),A4),aa(set(C),set(C),insert2(C,X2),bot_bot(set(C)))))),aa(set(C),set(B),image2(C,B,F),A4)) ).

% fun_upd_image
tff(fact_2752_times__rat_Orsp,axiom,
    aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),$o,aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),fun(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),$o),bNF_rel_fun(product_prod(int,int),product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)),fun(product_prod(int,int),product_prod(int,int)),ratrel,bNF_rel_fun(product_prod(int,int),product_prod(int,int),product_prod(int,int),product_prod(int,int),ratrel,ratrel)),aTP_Lamp_km(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))),aTP_Lamp_km(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))) ).

% times_rat.rsp
tff(fact_2753_uminus__rat_Orsp,axiom,
    aa(fun(product_prod(int,int),product_prod(int,int)),$o,aa(fun(product_prod(int,int),product_prod(int,int)),fun(fun(product_prod(int,int),product_prod(int,int)),$o),bNF_rel_fun(product_prod(int,int),product_prod(int,int),product_prod(int,int),product_prod(int,int),ratrel,ratrel),aTP_Lamp_kn(product_prod(int,int),product_prod(int,int))),aTP_Lamp_kn(product_prod(int,int),product_prod(int,int))) ).

% uminus_rat.rsp
tff(fact_2754_product__fold,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(C,B5)
       => ( product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)) = finite_fold(B,set(product_prod(B,C)),aTP_Lamp_kz(set(C),fun(B,fun(set(product_prod(B,C)),set(product_prod(B,C)))),B5),bot_bot(set(product_prod(B,C))),A4) ) ) ) ).

% product_fold
tff(fact_2755_Id__on__fold,axiom,
    ! [B: $tType,A4: set(B)] :
      ( finite_finite2(B,A4)
     => ( id_on(B,A4) = finite_fold(B,set(product_prod(B,B)),aTP_Lamp_la(B,fun(set(product_prod(B,B)),set(product_prod(B,B)))),bot_bot(set(product_prod(B,B))),A4) ) ) ).

% Id_on_fold
tff(fact_2756_plus__rat_Oabs__eq,axiom,
    ! [Xa: product_prod(int,int),X2: product_prod(int,int)] :
      ( aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,Xa),Xa)
     => ( aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,X2),X2)
       => ( aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),aa(product_prod(int,int),rat,abs_Rat,Xa)),aa(product_prod(int,int),rat,abs_Rat,X2)) = aa(product_prod(int,int),rat,abs_Rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),Xa)),aa(product_prod(int,int),int,product_snd(int,int),X2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),X2)),aa(product_prod(int,int),int,product_snd(int,int),Xa)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),Xa)),aa(product_prod(int,int),int,product_snd(int,int),X2)))) ) ) ) ).

% plus_rat.abs_eq
tff(fact_2757_inverse__rat_Oabs__eq,axiom,
    ! [X2: product_prod(int,int)] :
      ( aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,X2),X2)
     => ( aa(rat,rat,inverse_inverse(rat),aa(product_prod(int,int),rat,abs_Rat,X2)) = aa(product_prod(int,int),rat,abs_Rat,
            $ite(aa(product_prod(int,int),int,product_fst(int,int),X2) = zero_zero(int),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(product_prod(int,int),int,product_snd(int,int),X2)),aa(product_prod(int,int),int,product_fst(int,int),X2)))) ) ) ).

% inverse_rat.abs_eq
tff(fact_2758_times__rat_Oabs__eq,axiom,
    ! [Xa: product_prod(int,int),X2: product_prod(int,int)] :
      ( aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,Xa),Xa)
     => ( aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,X2),X2)
       => ( aa(rat,rat,aa(rat,fun(rat,rat),times_times(rat),aa(product_prod(int,int),rat,abs_Rat,Xa)),aa(product_prod(int,int),rat,abs_Rat,X2)) = aa(product_prod(int,int),rat,abs_Rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),Xa)),aa(product_prod(int,int),int,product_fst(int,int),X2))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),Xa)),aa(product_prod(int,int),int,product_snd(int,int),X2)))) ) ) ) ).

% times_rat.abs_eq
tff(fact_2759_uminus__rat_Oabs__eq,axiom,
    ! [X2: product_prod(int,int)] :
      ( aa(product_prod(int,int),$o,aa(product_prod(int,int),fun(product_prod(int,int),$o),ratrel,X2),X2)
     => ( aa(rat,rat,uminus_uminus(rat),aa(product_prod(int,int),rat,abs_Rat,X2)) = aa(product_prod(int,int),rat,abs_Rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),aa(product_prod(int,int),int,product_fst(int,int),X2))),aa(product_prod(int,int),int,product_snd(int,int),X2))) ) ) ).

% uminus_rat.abs_eq
tff(fact_2760_graph__map__upd,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),K: B,V: C] : graph(B,C,fun_upd(B,option(C),M,K,aa(C,option(C),some(C),V))) = aa(set(product_prod(B,C)),set(product_prod(B,C)),insert2(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V)),graph(B,C,fun_upd(B,option(C),M,K,none(C)))) ).

% graph_map_upd
tff(fact_2761_insert__relcomp__union__fold,axiom,
    ! [D: $tType,C: $tType,B: $tType,S2: set(product_prod(B,C)),X2: product_prod(D,B),X7: set(product_prod(D,C))] :
      ( finite_finite2(product_prod(B,C),S2)
     => ( 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))),sup_sup(set(product_prod(D,C))),relcomp(D,B,C,aa(set(product_prod(D,B)),set(product_prod(D,B)),insert2(product_prod(D,B),X2),bot_bot(set(product_prod(D,B)))),S2)),X7) = finite_fold(product_prod(B,C),set(product_prod(D,C)),aa(fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),fun(product_prod(B,C),fun(set(product_prod(D,C)),set(product_prod(D,C)))),product_case_prod(B,C,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aTP_Lamp_lb(product_prod(D,B),fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),X2)),X7,S2) ) ) ).

% insert_relcomp_union_fold
tff(fact_2762_graph__empty,axiom,
    ! [C: $tType,B: $tType] : graph(B,C,aTP_Lamp_hj(B,option(C))) = bot_bot(set(product_prod(B,C))) ).

% graph_empty
tff(fact_2763_relcomp_Ocases,axiom,
    ! [B: $tType,C: $tType,D: $tType,A1: B,A22: C,R: set(product_prod(B,D)),S: set(product_prod(D,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A1),A22),relcomp(B,D,C,R,S))
     => ~ ! [B3: D] :
            ( member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A1),B3),R)
           => ~ member(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),B3),A22),S) ) ) ).

% relcomp.cases
tff(fact_2764_relcomp_Osimps,axiom,
    ! [B: $tType,C: $tType,D: $tType,A1: B,A22: C,R: set(product_prod(B,D)),S: set(product_prod(D,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A1),A22),relcomp(B,D,C,R,S))
    <=> ? [A7: B,B7: D,C4: C] :
          ( ( A1 = A7 )
          & ( A22 = C4 )
          & member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A7),B7),R)
          & member(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),B7),C4),S) ) ) ).

% relcomp.simps
tff(fact_2765_relcomp_OrelcompI,axiom,
    ! [B: $tType,D: $tType,C: $tType,A3: B,B2: C,R: set(product_prod(B,C)),C2: D,S: set(product_prod(C,D))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R)
     => ( member(product_prod(C,D),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),B2),C2),S)
       => member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A3),C2),relcomp(B,C,D,R,S)) ) ) ).

% relcomp.relcompI
tff(fact_2766_relcompE,axiom,
    ! [B: $tType,C: $tType,D: $tType,Xz: product_prod(B,C),R: set(product_prod(B,D)),S: set(product_prod(D,C))] :
      ( member(product_prod(B,C),Xz,relcomp(B,D,C,R,S))
     => ~ ! [X3: B,Y4: D,Z3: C] :
            ( ( Xz = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Z3) )
           => ( member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),X3),Y4),R)
             => ~ member(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),Y4),Z3),S) ) ) ) ).

% relcompE
tff(fact_2767_relcompEpair,axiom,
    ! [B: $tType,C: $tType,D: $tType,A3: B,C2: C,R: set(product_prod(B,D)),S: set(product_prod(D,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),C2),relcomp(B,D,C,R,S))
     => ~ ! [B3: D] :
            ( member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A3),B3),R)
           => ~ member(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),B3),C2),S) ) ) ).

% relcompEpair
tff(fact_2768_in__graphI,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),K: C,V: B] :
      ( ( aa(C,option(B),M,K) = aa(B,option(B),some(B),V) )
     => member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),K),V),graph(C,B,M)) ) ).

% in_graphI
tff(fact_2769_in__graphD,axiom,
    ! [B: $tType,C: $tType,K: B,V: C,M: fun(B,option(C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V),graph(B,C,M))
     => ( aa(B,option(C),M,K) = aa(C,option(C),some(C),V) ) ) ).

% in_graphD
tff(fact_2770_max__ext__compat,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),S2: set(product_prod(B,B))] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),relcomp(B,B,B,R4,S2)),R4)
     => aa(set(product_prod(set(B),set(B))),$o,aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(B),set(B))),$o),ord_less_eq(set(product_prod(set(B),set(B)))),relcomp(set(B),set(B),set(B),max_ext(B,R4),aa(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),sup_sup(set(product_prod(set(B),set(B)))),max_ext(B,S2)),aa(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B))),insert2(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),bot_bot(set(B))),bot_bot(set(B)))),bot_bot(set(product_prod(set(B),set(B)))))))),max_ext(B,R4)) ) ).

% max_ext_compat
tff(fact_2771_min__ext__compat,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),S2: set(product_prod(B,B))] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),relcomp(B,B,B,R4,S2)),R4)
     => aa(set(product_prod(set(B),set(B))),$o,aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(B),set(B))),$o),ord_less_eq(set(product_prod(set(B),set(B)))),relcomp(set(B),set(B),set(B),min_ext(B,R4),aa(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),sup_sup(set(product_prod(set(B),set(B)))),min_ext(B,S2)),aa(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B))),insert2(product_prod(set(B),set(B)),aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),bot_bot(set(B))),bot_bot(set(B)))),bot_bot(set(product_prod(set(B),set(B)))))))),min_ext(B,R4)) ) ).

% min_ext_compat
tff(fact_2772_relcomp__fold,axiom,
    ! [D: $tType,C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(C,D))] :
      ( finite_finite2(product_prod(B,C),R4)
     => ( finite_finite2(product_prod(C,D),S2)
       => ( relcomp(B,C,D,R4,S2) = finite_fold(product_prod(B,C),set(product_prod(B,D)),aa(fun(B,fun(C,fun(set(product_prod(B,D)),set(product_prod(B,D))))),fun(product_prod(B,C),fun(set(product_prod(B,D)),set(product_prod(B,D)))),product_case_prod(B,C,fun(set(product_prod(B,D)),set(product_prod(B,D)))),aTP_Lamp_ld(set(product_prod(C,D)),fun(B,fun(C,fun(set(product_prod(B,D)),set(product_prod(B,D))))),S2)),bot_bot(set(product_prod(B,D))),R4) ) ) ) ).

% relcomp_fold
tff(fact_2773_one__rat__def,axiom,
    one_one(rat) = aa(product_prod(int,int),rat,abs_Rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),one_one(int)),one_one(int))) ).

% one_rat_def
tff(fact_2774_graph__fun__upd__None,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),K: B] : graph(B,C,fun_upd(B,option(C),M,K,none(C))) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(B,fun(product_prod(B,C),$o),aTP_Lamp_le(fun(B,option(C)),fun(B,fun(product_prod(B,C),$o)),M),K)) ).

% graph_fun_upd_None
tff(fact_2775_insert__relcomp__fold,axiom,
    ! [D: $tType,C: $tType,B: $tType,S2: set(product_prod(B,C)),X2: product_prod(D,B),R4: set(product_prod(D,B))] :
      ( finite_finite2(product_prod(B,C),S2)
     => ( relcomp(D,B,C,aa(set(product_prod(D,B)),set(product_prod(D,B)),insert2(product_prod(D,B),X2),R4),S2) = finite_fold(product_prod(B,C),set(product_prod(D,C)),aa(fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),fun(product_prod(B,C),fun(set(product_prod(D,C)),set(product_prod(D,C)))),product_case_prod(B,C,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aTP_Lamp_lb(product_prod(D,B),fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),X2)),relcomp(D,B,C,R4,S2),S2) ) ) ).

% insert_relcomp_fold
tff(fact_2776_zero__rat__def,axiom,
    zero_zero(rat) = aa(product_prod(int,int),rat,abs_Rat,aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int))) ).

% zero_rat_def
tff(fact_2777_plus__rat__def,axiom,
    plus_plus(rat) = aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),fun(rat,fun(rat,rat)),map_fun(rat,product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)),fun(rat,rat),rep_Rat,map_fun(rat,product_prod(int,int),product_prod(int,int),rat,rep_Rat,abs_Rat)),aTP_Lamp_kj(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))) ).

% plus_rat_def
tff(fact_2778_inverse__rat__def,axiom,
    inverse_inverse(rat) = aa(fun(product_prod(int,int),product_prod(int,int)),fun(rat,rat),map_fun(rat,product_prod(int,int),product_prod(int,int),rat,rep_Rat,abs_Rat),aTP_Lamp_kk(product_prod(int,int),product_prod(int,int))) ).

% inverse_rat_def
tff(fact_2779_times__rat__def,axiom,
    times_times(rat) = aa(fun(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),fun(rat,fun(rat,rat)),map_fun(rat,product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)),fun(rat,rat),rep_Rat,map_fun(rat,product_prod(int,int),product_prod(int,int),rat,rep_Rat,abs_Rat)),aTP_Lamp_km(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)))) ).

% times_rat_def
tff(fact_2780_uminus__rat__def,axiom,
    uminus_uminus(rat) = aa(fun(product_prod(int,int),product_prod(int,int)),fun(rat,rat),map_fun(rat,product_prod(int,int),product_prod(int,int),rat,rep_Rat,abs_Rat),aTP_Lamp_kn(product_prod(int,int),product_prod(int,int))) ).

% uminus_rat_def
tff(fact_2781_comp__fun__commute__relcomp__fold,axiom,
    ! [D: $tType,C: $tType,B: $tType,S2: set(product_prod(B,C))] :
      ( finite_finite2(product_prod(B,C),S2)
     => finite6289374366891150609ommute(product_prod(D,B),set(product_prod(D,C)),aa(fun(D,fun(B,fun(set(product_prod(D,C)),set(product_prod(D,C))))),fun(product_prod(D,B),fun(set(product_prod(D,C)),set(product_prod(D,C)))),product_case_prod(D,B,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aTP_Lamp_lg(set(product_prod(B,C)),fun(D,fun(B,fun(set(product_prod(D,C)),set(product_prod(D,C))))),S2))) ) ).

% comp_fun_commute_relcomp_fold
tff(fact_2782_restrict__upd__same,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),X2: B,Y: C] : restrict_map(B,C,fun_upd(B,option(C),M,X2,aa(C,option(C),some(C),Y)),aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))) = restrict_map(B,C,M,aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))) ).

% restrict_upd_same
tff(fact_2783_restrict__map__UNIV,axiom,
    ! [C: $tType,B: $tType,F: fun(B,option(C))] : restrict_map(B,C,F,top_top(set(B))) = F ).

% restrict_map_UNIV
tff(fact_2784_restrict__out,axiom,
    ! [B: $tType,C: $tType,X2: B,A4: set(B),M: fun(B,option(C))] :
      ( ~ member(B,X2,A4)
     => ( aa(B,option(C),restrict_map(B,C,M,A4),X2) = none(C) ) ) ).

% restrict_out
tff(fact_2785_restrict__map__empty,axiom,
    ! [B: $tType,C: $tType,D4: set(B),X: B] : aa(B,option(C),restrict_map(B,C,aTP_Lamp_hj(B,option(C)),D4),X) = none(C) ).

% restrict_map_empty
tff(fact_2786_restrict__map__to__empty,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),X: B] : aa(B,option(C),restrict_map(B,C,M,bot_bot(set(B))),X) = none(C) ).

% restrict_map_to_empty
tff(fact_2787_fun__upd__None__restrict,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),D4: set(B),X2: B] :
      fun_upd(B,option(C),restrict_map(B,C,M,D4),X2,none(C)) = $ite(member(B,X2,D4),restrict_map(B,C,M,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),D4),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))),restrict_map(B,C,M,D4)) ).

% fun_upd_None_restrict
tff(fact_2788_le__map__restrict,axiom,
    ! [C: $tType,B: $tType] :
      ( order(C)
     => ! [M: fun(B,option(C)),X7: set(B)] : aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),restrict_map(B,C,M,X7)),M) ) ).

% le_map_restrict
tff(fact_2789_restrict__map__subset__eq,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),R4: set(B),M7: fun(B,option(C)),R6: set(B)] :
      ( ( restrict_map(B,C,M,R4) = M7 )
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),R6),R4)
       => ( restrict_map(B,C,M,R6) = restrict_map(B,C,M7,R6) ) ) ) ).

% restrict_map_subset_eq
tff(fact_2790_restrict__map__eq_I2_J,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),A4: set(C),K: C,V: B] :
      ( ( aa(C,option(B),restrict_map(C,B,M,A4),K) = aa(B,option(B),some(B),V) )
    <=> ( ( aa(C,option(B),M,K) = aa(B,option(B),some(B),V) )
        & member(C,K,A4) ) ) ).

% restrict_map_eq(2)
tff(fact_2791_restrict__map__def,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),A4: set(B),X: B] :
      aa(B,option(C),restrict_map(B,C,M,A4),X) = $ite(member(B,X,A4),aa(B,option(C),M,X),none(C)) ).

% restrict_map_def
tff(fact_2792_comp__fun__commute_Ointro,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( ! [Y4: B,X3: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y4)),aa(B,fun(C,C),F,X3)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,Y4))
     => finite6289374366891150609ommute(B,C,F) ) ).

% comp_fun_commute.intro
tff(fact_2793_comp__fun__commute_Ocomp__fun__commute,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C)),Y: B,X2: B] :
      ( finite6289374366891150609ommute(B,C,F)
     => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y)),aa(B,fun(C,C),F,X2)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X2)),aa(B,fun(C,C),F,Y)) ) ) ).

% comp_fun_commute.comp_fun_commute
tff(fact_2794_comp__fun__commute__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( finite6289374366891150609ommute(B,C,F)
    <=> ! [Y3: B,X4: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y3)),aa(B,fun(C,C),F,X4)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X4)),aa(B,fun(C,C),F,Y3)) ) ).

% comp_fun_commute_def
tff(fact_2795_graph__restrictD_I1_J,axiom,
    ! [C: $tType,B: $tType,K: B,V: C,M: fun(B,option(C)),A4: set(B)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V),graph(B,C,restrict_map(B,C,M,A4)))
     => member(B,K,A4) ) ).

% graph_restrictD(1)
tff(fact_2796_map__restrict__insert__none__simp,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),X2: C,S: set(C)] :
      ( ( aa(C,option(B),M,X2) = none(B) )
     => ( restrict_map(C,B,M,aa(set(C),set(C),uminus_uminus(set(C)),aa(set(C),set(C),insert2(C,X2),S))) = restrict_map(C,B,M,aa(set(C),set(C),uminus_uminus(set(C)),S)) ) ) ).

% map_restrict_insert_none_simp
tff(fact_2797_restrict__map__upd,axiom,
    ! [C: $tType,B: $tType,F: fun(B,option(C)),S2: set(B),K: B,V: C] : fun_upd(B,option(C),restrict_map(B,C,F,S2),K,aa(C,option(C),some(C),V)) = restrict_map(B,C,fun_upd(B,option(C),F,K,aa(C,option(C),some(C),V)),aa(set(B),set(B),insert2(B,K),S2)) ).

% restrict_map_upd
tff(fact_2798_graph__restrictD_I2_J,axiom,
    ! [B: $tType,C: $tType,K: B,V: C,M: fun(B,option(C)),A4: set(B)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V),graph(B,C,restrict_map(B,C,M,A4)))
     => ( aa(B,option(C),M,K) = aa(C,option(C),some(C),V) ) ) ).

% graph_restrictD(2)
tff(fact_2799_restrict__complement__singleton__eq,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),X2: B] : restrict_map(B,C,F,aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))) = fun_upd(B,option(C),F,X2,none(C)) ).

% restrict_complement_singleton_eq
tff(fact_2800_map__upd__eq__restrict,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),X2: B] : fun_upd(B,option(C),M,X2,none(C)) = restrict_map(B,C,M,aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))) ).

% map_upd_eq_restrict
tff(fact_2801_comp__fun__commute__product__fold,axiom,
    ! [C: $tType,B: $tType,B5: set(B)] :
      ( finite_finite2(B,B5)
     => finite6289374366891150609ommute(C,set(product_prod(C,B)),aTP_Lamp_lh(set(B),fun(C,fun(set(product_prod(C,B)),set(product_prod(C,B)))),B5)) ) ).

% comp_fun_commute_product_fold
tff(fact_2802_Sup__fin_Oeq__fold_H,axiom,
    ! [B: $tType] :
      ( semilattice_sup(B)
     => ! [A4: set(B)] : lattic5882676163264333800up_fin(B,A4) = aa(option(B),B,the2(B),finite_fold(B,option(B),aTP_Lamp_li(B,fun(option(B),option(B))),none(B),A4)) ) ).

% Sup_fin.eq_fold'
tff(fact_2803_ran__map__upd,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),A3: C,B2: B] :
      ( ( aa(C,option(B),M,A3) = none(B) )
     => ( ran(C,B,fun_upd(C,option(B),M,A3,aa(B,option(B),some(B),B2))) = aa(set(B),set(B),insert2(B,B2),ran(C,B,M)) ) ) ).

% ran_map_upd
tff(fact_2804_Gcd__fin_Oeq__fold,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A4: set(B)] :
          aa(set(B),B,semiring_gcd_Gcd_fin(B),A4) = $ite(finite_finite2(B,A4),finite_fold(B,B,gcd_gcd(B),zero_zero(B),A4),one_one(B)) ) ).

% Gcd_fin.eq_fold
tff(fact_2805_Max_Oeq__fold_H,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A4: set(B)] : lattic643756798349783984er_Max(B,A4) = aa(option(B),B,the2(B),finite_fold(B,option(B),aTP_Lamp_lj(B,fun(option(B),option(B))),none(B),A4)) ) ).

% Max.eq_fold'
tff(fact_2806_Min_Oeq__fold_H,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A4: set(B)] : lattic643756798350308766er_Min(B,A4) = aa(option(B),B,the2(B),finite_fold(B,option(B),aTP_Lamp_lk(B,fun(option(B),option(B))),none(B),A4)) ) ).

% Min.eq_fold'
tff(fact_2807_pairself__image__eq,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),P: fun(C,fun(C,$o))] : aa(set(product_prod(C,C)),set(product_prod(B,B)),image2(product_prod(C,C),product_prod(B,B),pairself(C,B,F)),aa(fun(product_prod(C,C),$o),set(product_prod(C,C)),collect(product_prod(C,C)),aa(fun(C,fun(C,$o)),fun(product_prod(C,C),$o),product_case_prod(C,C,$o),P))) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(C,fun(C,$o)),fun(product_prod(B,B),$o),aTP_Lamp_ll(fun(C,B),fun(fun(C,fun(C,$o)),fun(product_prod(B,B),$o)),F),P)) ).

% pairself_image_eq
tff(fact_2808_eq__or__mem__image__simp,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),A3: C,B5: set(C)] : aa(fun(B,$o),set(B),collect(B),aa(set(C),fun(B,$o),aa(C,fun(set(C),fun(B,$o)),aTP_Lamp_lm(fun(C,B),fun(C,fun(set(C),fun(B,$o))),F),A3),B5)) = aa(set(B),set(B),insert2(B,aa(C,B,F,A3)),aa(fun(B,$o),set(B),collect(B),aa(set(C),fun(B,$o),aTP_Lamp_ln(fun(C,B),fun(set(C),fun(B,$o)),F),B5))) ).

% eq_or_mem_image_simp
tff(fact_2809_Gcd__fin_Oinfinite,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A4: set(B)] :
          ( ~ finite_finite2(B,A4)
         => ( aa(set(B),B,semiring_gcd_Gcd_fin(B),A4) = one_one(B) ) ) ) ).

% Gcd_fin.infinite
tff(fact_2810_is__unit__Gcd__fin__iff,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A4: set(B)] :
          ( dvd_dvd(B,aa(set(B),B,semiring_gcd_Gcd_fin(B),A4),one_one(B))
        <=> ( aa(set(B),B,semiring_gcd_Gcd_fin(B),A4) = one_one(B) ) ) ) ).

% is_unit_Gcd_fin_iff
tff(fact_2811_Eps__Opt__eq__None,axiom,
    ! [B: $tType,P: fun(B,$o)] :
      ( ( eps_Opt(B,P) = none(B) )
    <=> ~ ? [X_1: B] : aa(B,$o,P,X_1) ) ).

% Eps_Opt_eq_None
tff(fact_2812_ran__empty,axiom,
    ! [C: $tType,B: $tType] : ran(C,B,aTP_Lamp_bf(C,option(B))) = bot_bot(set(B)) ).

% ran_empty
tff(fact_2813_map__update__eta__repair_I2_J,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),K: C,V: B] :
      ( ( aa(C,option(B),M,K) = none(B) )
     => ( ran(C,B,aa(B,fun(C,option(B)),aa(C,fun(B,fun(C,option(B))),aTP_Lamp_lo(fun(C,option(B)),fun(C,fun(B,fun(C,option(B)))),M),K),V)) = aa(set(B),set(B),insert2(B,V),ran(C,B,M)) ) ) ).

% map_update_eta_repair(2)
tff(fact_2814_ran__def,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B))] : ran(C,B,M) = aa(fun(B,$o),set(B),collect(B),aTP_Lamp_lp(fun(C,option(B)),fun(B,$o),M)) ).

% ran_def
tff(fact_2815_ranI,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),A3: C,B2: B] :
      ( ( aa(C,option(B),M,A3) = aa(B,option(B),some(B),B2) )
     => member(B,B2,ran(C,B,M)) ) ).

% ranI
tff(fact_2816_fs__contract,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,fun(C,D)),S2: set(D)] : aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(set(D),fun(product_prod(B,C),$o),aTP_Lamp_lq(fun(B,fun(C,D)),fun(set(D),fun(product_prod(B,C),$o)),F),S2))) = aa(fun(B,$o),set(B),collect(B),aa(set(D),fun(B,$o),aTP_Lamp_lr(fun(B,fun(C,D)),fun(set(D),fun(B,$o)),F),S2)) ).

% fs_contract
tff(fact_2817_ran__restrictD,axiom,
    ! [C: $tType,B: $tType,Y: B,M: fun(C,option(B)),A4: set(C)] :
      ( member(B,Y,ran(C,B,restrict_map(C,B,M,A4)))
     => ? [X3: C] :
          ( member(C,X3,A4)
          & ( aa(C,option(B),M,X3) = aa(B,option(B),some(B),Y) ) ) ) ).

% ran_restrictD
tff(fact_2818_Un__interval,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [B1: B,B22: B,B32: B,F: fun(B,C)] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B1),B22)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B22),B32)
           => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(fun(C,$o),set(C),collect(C),aa(fun(B,C),fun(C,$o),aa(B,fun(fun(B,C),fun(C,$o)),aTP_Lamp_ls(B,fun(B,fun(fun(B,C),fun(C,$o))),B1),B22),F))),aa(fun(C,$o),set(C),collect(C),aa(fun(B,C),fun(C,$o),aa(B,fun(fun(B,C),fun(C,$o)),aTP_Lamp_ls(B,fun(B,fun(fun(B,C),fun(C,$o))),B22),B32),F))) = aa(fun(C,$o),set(C),collect(C),aa(fun(B,C),fun(C,$o),aa(B,fun(fun(B,C),fun(C,$o)),aTP_Lamp_ls(B,fun(B,fun(fun(B,C),fun(C,$o))),B1),B32),F)) ) ) ) ) ).

% Un_interval
tff(fact_2819_fold__atLeastAtMost__nat,axiom,
    ! [B: $tType,F: fun(nat,fun(B,B)),A3: nat,B2: nat,Acc2: B] :
      ( finite6289374366891150609ommute(nat,B,F)
     => ( set_fo6178422350223883121st_nat(B,F,A3,B2,Acc2) = finite_fold(nat,B,F,Acc2,set_or1337092689740270186AtMost(nat,A3,B2)) ) ) ).

% fold_atLeastAtMost_nat
tff(fact_2820_Min_Oinfinite,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A4: set(B)] :
          ( ~ finite_finite2(B,A4)
         => ( lattic643756798350308766er_Min(B,A4) = aa(option(B),B,the2(B),none(B)) ) ) ) ).

% Min.infinite
tff(fact_2821_relcomp__unfold,axiom,
    ! [B: $tType,C: $tType,D: $tType,R: set(product_prod(B,D)),S: set(product_prod(D,C))] : relcomp(B,D,C,R,S) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(set(product_prod(D,C)),fun(B,fun(C,$o)),aTP_Lamp_lt(set(product_prod(B,D)),fun(set(product_prod(D,C)),fun(B,fun(C,$o))),R),S))) ).

% relcomp_unfold
tff(fact_2822_Max_Oinfinite,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A4: set(B)] :
          ( ~ finite_finite2(B,A4)
         => ( lattic643756798349783984er_Max(B,A4) = aa(option(B),B,the2(B),none(B)) ) ) ) ).

% Max.infinite
tff(fact_2823_graph__def,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : graph(B,C,M) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aTP_Lamp_lu(fun(B,option(C)),fun(product_prod(B,C),$o),M)) ).

% graph_def
tff(fact_2824_Sup__fin_Oinfinite,axiom,
    ! [B: $tType] :
      ( semilattice_sup(B)
     => ! [A4: set(B)] :
          ( ~ finite_finite2(B,A4)
         => ( lattic5882676163264333800up_fin(B,A4) = aa(option(B),B,the2(B),none(B)) ) ) ) ).

% Sup_fin.infinite
tff(fact_2825_Min__add__commute,axiom,
    ! [B: $tType,C: $tType] :
      ( linord4140545234300271783up_add(C)
     => ! [S2: set(B),F: fun(B,C),K: C] :
          ( finite_finite2(B,S2)
         => ( ( S2 != bot_bot(set(B)) )
           => ( lattic643756798350308766er_Min(C,aa(set(B),set(C),image2(B,C,aa(C,fun(B,C),aTP_Lamp_lv(fun(B,C),fun(C,fun(B,C)),F),K)),S2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),lattic643756798350308766er_Min(C,aa(set(B),set(C),image2(B,C,F),S2))),K) ) ) ) ) ).

% Min_add_commute
tff(fact_2826_card__le__Suc__Max,axiom,
    ! [S2: set(nat)] :
      ( finite_finite2(nat,S2)
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),finite_card(nat,S2)),aa(nat,nat,suc,lattic643756798349783984er_Max(nat,S2))) ) ).

% card_le_Suc_Max
tff(fact_2827_Max__add__commute,axiom,
    ! [B: $tType,C: $tType] :
      ( linord4140545234300271783up_add(C)
     => ! [S2: set(B),F: fun(B,C),K: C] :
          ( finite_finite2(B,S2)
         => ( ( S2 != bot_bot(set(B)) )
           => ( lattic643756798349783984er_Max(C,aa(set(B),set(C),image2(B,C,aa(C,fun(B,C),aTP_Lamp_lv(fun(B,C),fun(C,fun(B,C)),F),K)),S2)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),lattic643756798349783984er_Max(C,aa(set(B),set(C),image2(B,C,F),S2))),K) ) ) ) ) ).

% Max_add_commute
tff(fact_2828_set__to__map__ran,axiom,
    ! [B: $tType,C: $tType,S2: set(product_prod(C,B))] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),ran(C,B,set_to_map(C,B,S2))),aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),S2)) ).

% set_to_map_ran
tff(fact_2829_map__to__set__upd,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),K: B,V: C] : map_to_set(B,C,fun_upd(B,option(C),M,K,aa(C,option(C),some(C),V))) = aa(set(product_prod(B,C)),set(product_prod(B,C)),insert2(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V)),aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),set(product_prod(B,C))),minus_minus(set(product_prod(B,C))),map_to_set(B,C,M)),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aTP_Lamp_lw(B,fun(product_prod(B,C),$o),K)))) ).

% map_to_set_upd
tff(fact_2830_brk__rel__def,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C))] : brk_rel(B,C,R4) = aa(set(product_prod(product_prod($o,B),product_prod($o,C))),set(product_prod(product_prod($o,B),product_prod($o,C))),aa(set(product_prod(product_prod($o,B),product_prod($o,C))),fun(set(product_prod(product_prod($o,B),product_prod($o,C))),set(product_prod(product_prod($o,B),product_prod($o,C)))),sup_sup(set(product_prod(product_prod($o,B),product_prod($o,C)))),aa(fun(product_prod(product_prod($o,B),product_prod($o,C)),$o),set(product_prod(product_prod($o,B),product_prod($o,C))),collect(product_prod(product_prod($o,B),product_prod($o,C))),aTP_Lamp_lx(set(product_prod(B,C)),fun(product_prod(product_prod($o,B),product_prod($o,C)),$o),R4))),aa(fun(product_prod(product_prod($o,B),product_prod($o,C)),$o),set(product_prod(product_prod($o,B),product_prod($o,C))),collect(product_prod(product_prod($o,B),product_prod($o,C))),aTP_Lamp_ly(product_prod(product_prod($o,B),product_prod($o,C)),$o))) ).

% brk_rel_def
tff(fact_2831_image2__def,axiom,
    ! [B: $tType,C: $tType,D: $tType,A4: set(D),F: fun(D,B),G: fun(D,C)] : bNF_Greatest_image2(D,B,C,A4,F,G) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(D,C),fun(product_prod(B,C),$o),aa(fun(D,B),fun(fun(D,C),fun(product_prod(B,C),$o)),aTP_Lamp_lz(set(D),fun(fun(D,B),fun(fun(D,C),fun(product_prod(B,C),$o))),A4),F),G)) ).

% image2_def
tff(fact_2832_greaterThan__Suc,axiom,
    ! [K: nat] : aa(nat,set(nat),set_ord_greaterThan(nat),aa(nat,nat,suc,K)) = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),minus_minus(set(nat)),aa(nat,set(nat),set_ord_greaterThan(nat),K)),aa(set(nat),set(nat),insert2(nat,aa(nat,nat,suc,K)),bot_bot(set(nat)))) ).

% greaterThan_Suc
tff(fact_2833_refl__on__singleton,axiom,
    ! [B: $tType,X2: B] : refl_on(B,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),X2)),bot_bot(set(product_prod(B,B))))) ).

% refl_on_singleton
tff(fact_2834_time__refines,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),C6: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( refine_Imp_refines(B,C2,C6)
     => ( ~ time_fails(B,C6,Ha)
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),time_time(B,C2,Ha)),time_time(B,C6,Ha)) ) ) ).

% time_refines
tff(fact_2835_greaterThan__eq__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,set(B),set_ord_greaterThan(B),X2) = aa(B,set(B),set_ord_greaterThan(B),Y) )
        <=> ( X2 = Y ) ) ) ).

% greaterThan_eq_iff
tff(fact_2836_greaterThan__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,K: B] :
          ( member(B,I,aa(B,set(B),set_ord_greaterThan(B),K))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),K),I) ) ) ).

% greaterThan_iff
tff(fact_2837_Inf__greaterThan,axiom,
    ! [B: $tType] :
      ( ( comple6319245703460814977attice(B)
        & dense_linorder(B) )
     => ! [X2: B] : complete_Inf_Inf(B,aa(B,set(B),set_ord_greaterThan(B),X2)) = X2 ) ).

% Inf_greaterThan
tff(fact_2838_greaterThan__subset__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: B,Y: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_greaterThan(B),X2)),aa(B,set(B),set_ord_greaterThan(B),Y))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y),X2) ) ) ).

% greaterThan_subset_iff
tff(fact_2839_Compl__greaterThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [K: B] : aa(set(B),set(B),uminus_uminus(set(B)),aa(B,set(B),set_ord_greaterThan(B),K)) = aa(B,set(B),set_ord_atMost(B),K) ) ).

% Compl_greaterThan
tff(fact_2840_Compl__atMost,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [K: B] : aa(set(B),set(B),uminus_uminus(set(B)),aa(B,set(B),set_ord_atMost(B),K)) = aa(B,set(B),set_ord_greaterThan(B),K) ) ).

% Compl_atMost
tff(fact_2841_map__to__set__empty,axiom,
    ! [C: $tType,B: $tType] : map_to_set(B,C,aTP_Lamp_hj(B,option(C))) = bot_bot(set(product_prod(B,C))) ).

% map_to_set_empty
tff(fact_2842_Sup__greaterThanAtLeast,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),top_top(B))
         => ( aa(set(B),B,complete_Sup_Sup(B),aa(B,set(B),set_ord_greaterThan(B),X2)) = top_top(B) ) ) ) ).

% Sup_greaterThanAtLeast
tff(fact_2843_image__uminus__greaterThan,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),aa(B,set(B),set_ord_greaterThan(B),X2)) = aa(B,set(B),set_ord_lessThan(B),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_greaterThan
tff(fact_2844_image__uminus__lessThan,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),aa(B,set(B),set_ord_lessThan(B),X2)) = aa(B,set(B),set_ord_greaterThan(B),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_lessThan
tff(fact_2845_refl__onD2,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,Y: B] :
      ( refl_on(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
       => member(B,Y,A4) ) ) ).

% refl_onD2
tff(fact_2846_refl__onD1,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,Y: B] :
      ( refl_on(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
       => member(B,X2,A4) ) ) ).

% refl_onD1
tff(fact_2847_refl__onD,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),A3: B] :
      ( refl_on(B,A4,R)
     => ( member(B,A3,A4)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3),R) ) ) ).

% refl_onD
tff(fact_2848_greaterThan__non__empty,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [X2: B] : aa(B,set(B),set_ord_greaterThan(B),X2) != bot_bot(set(B)) ) ).

% greaterThan_non_empty
tff(fact_2849_infinite__Ioi,axiom,
    ! [B: $tType] :
      ( ( linorder(B)
        & no_top(B) )
     => ! [A3: B] : ~ finite_finite2(B,aa(B,set(B),set_ord_greaterThan(B),A3)) ) ).

% infinite_Ioi
tff(fact_2850_greaterThan__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [L: B] : aa(B,set(B),set_ord_greaterThan(B),L) = aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),ord_less(B),L)) ) ).

% greaterThan_def
tff(fact_2851_fails__refines,axiom,
    ! [B: $tType,C2: heap_Time_Heap(B),C6: heap_Time_Heap(B),Ha: heap_ext(product_unit)] :
      ( refine_Imp_refines(B,C2,C6)
     => ( time_fails(B,C2,Ha)
       => time_fails(B,C6,Ha) ) ) ).

% fails_refines
tff(fact_2852_map__to__set__inverse,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : set_to_map(B,C,map_to_set(B,C,M)) = M ).

% map_to_set_inverse
tff(fact_2853_map__to__set__empty__iff_I1_J,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C))] :
      ( ( map_to_set(B,C,M) = bot_bot(set(product_prod(B,C))) )
    <=> ! [X4: B] : aa(B,option(C),M,X4) = none(C) ) ).

% map_to_set_empty_iff(1)
tff(fact_2854_map__to__set__empty__iff_I2_J,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C))] :
      ( ( bot_bot(set(product_prod(B,C))) = map_to_set(B,C,M) )
    <=> ! [X4: B] : aa(B,option(C),M,X4) = none(C) ) ).

% map_to_set_empty_iff(2)
tff(fact_2855_image2__eqI,axiom,
    ! [B: $tType,D: $tType,C: $tType,B2: B,F: fun(C,B),X2: C,C2: D,G: fun(C,D),A4: set(C)] :
      ( ( B2 = aa(C,B,F,X2) )
     => ( ( C2 = aa(C,D,G,X2) )
       => ( member(C,X2,A4)
         => member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),B2),C2),bNF_Greatest_image2(C,B,D,A4,F,G)) ) ) ) ).

% image2_eqI
tff(fact_2856_refl__on__def,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( refl_on(B,A4,R)
    <=> ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))
        & ! [X4: B] :
            ( member(B,X4,A4)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),X4),R) ) ) ) ).

% refl_on_def
tff(fact_2857_refl__onI,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))
     => ( ! [X3: B] :
            ( member(B,X3,A4)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),R) )
       => refl_on(B,A4,R) ) ) ).

% refl_onI
tff(fact_2858_map__to__set__def,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : map_to_set(B,C,M) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_mb(fun(B,option(C)),fun(B,fun(C,$o)),M))) ).

% map_to_set_def
tff(fact_2859_INT__greaterThan__UNIV,axiom,
    complete_Inf_Inf(set(nat),aa(set(nat),set(set(nat)),image2(nat,set(nat),set_ord_greaterThan(nat)),top_top(set(nat)))) = bot_bot(set(nat)) ).

% INT_greaterThan_UNIV
tff(fact_2860_map__to__set__ran,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B))] : ran(C,B,M) = aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),map_to_set(C,B,M)) ).

% map_to_set_ran
tff(fact_2861_greaterThan__0,axiom,
    aa(nat,set(nat),set_ord_greaterThan(nat),zero_zero(nat)) = aa(set(nat),set(nat),image2(nat,nat,suc),top_top(set(nat))) ).

% greaterThan_0
tff(fact_2862_refines__def,axiom,
    ! [B: $tType,P3: heap_Time_Heap(B),Q3: heap_Time_Heap(B)] :
      ( refine_Imp_refines(B,P3,Q3)
    <=> ! [H6: heap_ext(product_unit)] : aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),$o,aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),$o),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),$o),aa($o,fun(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),$o),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),$o)),case_option($o,product_prod(B,product_prod(heap_ext(product_unit),nat))),$true),aa(fun(B,fun(product_prod(heap_ext(product_unit),nat),$o)),fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),$o),product_case_prod(B,product_prod(heap_ext(product_unit),nat),$o),aa(heap_ext(product_unit),fun(B,fun(product_prod(heap_ext(product_unit),nat),$o)),aTP_Lamp_md(heap_Time_Heap(B),fun(heap_ext(product_unit),fun(B,fun(product_prod(heap_ext(product_unit),nat),$o))),P3),H6))),aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),Q3),H6)) ) ).

% refines_def
tff(fact_2863_refines__empty,axiom,
    ! [B: $tType,M: heap_Time_Heap(B)] : refine_Imp_refines(B,M,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aTP_Lamp_ao(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))))) ).

% refines_empty
tff(fact_2864_refines__bind,axiom,
    ! [C: $tType,B: $tType,M: heap_Time_Heap(B),M7: heap_Time_Heap(B),F: fun(B,heap_Time_Heap(C)),F2: fun(B,heap_Time_Heap(C))] :
      ( refine_Imp_refines(B,M,M7)
     => ( ! [X3: B] : refine_Imp_refines(C,aa(B,heap_Time_Heap(C),F,X3),aa(B,heap_Time_Heap(C),F2,X3))
       => refine_Imp_refines(C,heap_Time_bind(B,C,M,F),heap_Time_bind(B,C,M7,F2)) ) ) ).

% refines_bind
tff(fact_2865_refl__on__domain,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),A3: B,B2: B] :
      ( refl_on(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => ( member(B,A3,A4)
          & member(B,B2,A4) ) ) ) ).

% refl_on_domain
tff(fact_2866_refines__option,axiom,
    ! [C: $tType,B: $tType,A3: option(B),A6: option(B),M1: heap_Time_Heap(C),M12: heap_Time_Heap(C),M22: fun(B,heap_Time_Heap(C)),M23: fun(B,heap_Time_Heap(C))] :
      ( ( A3 = A6 )
     => ( refine_Imp_refines(C,M1,M12)
       => ( ! [X3: B] : refine_Imp_refines(C,aa(B,heap_Time_Heap(C),M22,X3),aa(B,heap_Time_Heap(C),M23,X3))
         => refine_Imp_refines(C,aa(option(B),heap_Time_Heap(C),aa(fun(B,heap_Time_Heap(C)),fun(option(B),heap_Time_Heap(C)),aa(heap_Time_Heap(C),fun(fun(B,heap_Time_Heap(C)),fun(option(B),heap_Time_Heap(C))),case_option(heap_Time_Heap(C),B),M1),M22),A3),aa(option(B),heap_Time_Heap(C),aa(fun(B,heap_Time_Heap(C)),fun(option(B),heap_Time_Heap(C)),aa(heap_Time_Heap(C),fun(fun(B,heap_Time_Heap(C)),fun(option(B),heap_Time_Heap(C))),case_option(heap_Time_Heap(C),B),M12),M23),A6)) ) ) ) ).

% refines_option
tff(fact_2867_linear__order__on__singleton,axiom,
    ! [B: $tType,X2: B] : order_679001287576687338der_on(B,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),X2)),bot_bot(set(product_prod(B,B))))) ).

% linear_order_on_singleton
tff(fact_2868_Total__subset__Id,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( total_on(B,field2(B,R),R)
     => ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R),id2(B))
       => ( ( R = bot_bot(set(product_prod(B,B))) )
          | ? [A5: B] : R = aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),A5)),bot_bot(set(product_prod(B,B)))) ) ) ) ).

% Total_subset_Id
tff(fact_2869_relation__of__def,axiom,
    ! [B: $tType,P: fun(B,fun(B,$o)),A4: set(B)] : order_relation_of(B,P,A4) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(set(B),fun(B,fun(B,$o)),aTP_Lamp_me(fun(B,fun(B,$o)),fun(set(B),fun(B,fun(B,$o))),P),A4))) ).

% relation_of_def
tff(fact_2870_euclidean__size__times__nonunit,axiom,
    ! [B: $tType] :
      ( euclid3725896446679973847miring(B)
     => ! [A3: B,B2: B] :
          ( ( A3 != zero_zero(B) )
         => ( ( B2 != zero_zero(B) )
           => ( ~ dvd_dvd(B,A3,one_one(B))
             => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,euclid6346220572633701492n_size(B),B2)),aa(B,nat,euclid6346220572633701492n_size(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2))) ) ) ) ) ).

% euclidean_size_times_nonunit
tff(fact_2871_surj__swap,axiom,
    ! [C: $tType,B: $tType] : aa(set(product_prod(C,B)),set(product_prod(B,C)),image2(product_prod(C,B),product_prod(B,C),product_swap(C,B)),top_top(set(product_prod(C,B)))) = top_top(set(product_prod(B,C))) ).

% surj_swap
tff(fact_2872_euclidean__size__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,nat,euclid6346220572633701492n_size(code_integer),X2) = aa(int,nat,euclid6346220572633701492n_size(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% euclidean_size_integer.rep_eq
tff(fact_2873_swap__swap,axiom,
    ! [C: $tType,B: $tType,P3: product_prod(B,C)] : aa(product_prod(C,B),product_prod(B,C),product_swap(C,B),aa(product_prod(B,C),product_prod(C,B),product_swap(B,C),P3)) = P3 ).

% swap_swap
tff(fact_2874_pair__in__Id__conv,axiom,
    ! [B: $tType,A3: B,B2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),id2(B))
    <=> ( A3 = B2 ) ) ).

% pair_in_Id_conv
tff(fact_2875_IdI,axiom,
    ! [B: $tType,A3: B] : member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3),id2(B)) ).

% IdI
tff(fact_2876_swap__simp,axiom,
    ! [B: $tType,C: $tType,X2: C,Y: B] : aa(product_prod(C,B),product_prod(B,C),product_swap(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y),X2) ).

% swap_simp
tff(fact_2877_case__swap,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,fun(C,B)),P3: product_prod(D,C)] : aa(product_prod(C,D),B,aa(fun(C,fun(D,B)),fun(product_prod(C,D),B),product_case_prod(C,D,B),aTP_Lamp_mf(fun(D,fun(C,B)),fun(C,fun(D,B)),F)),aa(product_prod(D,C),product_prod(C,D),product_swap(D,C),P3)) = aa(product_prod(D,C),B,aa(fun(D,fun(C,B)),fun(product_prod(D,C),B),product_case_prod(D,C,B),F),P3) ).

% case_swap
tff(fact_2878_swap__comp__swap,axiom,
    ! [C: $tType,B: $tType] : aa(fun(product_prod(B,C),product_prod(C,B)),fun(product_prod(B,C),product_prod(B,C)),aa(fun(product_prod(C,B),product_prod(B,C)),fun(fun(product_prod(B,C),product_prod(C,B)),fun(product_prod(B,C),product_prod(B,C))),comp(product_prod(C,B),product_prod(B,C),product_prod(B,C)),product_swap(C,B)),product_swap(B,C)) = id(product_prod(B,C)) ).

% swap_comp_swap
tff(fact_2879_bijective__Id,axiom,
    ! [B: $tType] : bijective(B,B,id2(B)) ).

% bijective_Id
tff(fact_2880_euclidean__size__1,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ( aa(B,nat,euclid6346220572633701492n_size(B),one_one(B)) = one_one(nat) ) ) ).

% euclidean_size_1
tff(fact_2881_fst__swap,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(C,B)] : aa(product_prod(B,C),B,product_fst(B,C),aa(product_prod(C,B),product_prod(B,C),product_swap(C,B),X2)) = aa(product_prod(C,B),B,product_snd(C,B),X2) ).

% fst_swap
tff(fact_2882_snd__swap,axiom,
    ! [C: $tType,B: $tType,X2: product_prod(B,C)] : aa(product_prod(C,B),B,product_snd(C,B),aa(product_prod(B,C),product_prod(C,B),product_swap(B,C),X2)) = aa(product_prod(B,C),B,product_fst(B,C),X2) ).

% snd_swap
tff(fact_2883_pair__in__swap__image,axiom,
    ! [B: $tType,C: $tType,Y: B,X2: C,A4: set(product_prod(C,B))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y),X2),aa(set(product_prod(C,B)),set(product_prod(B,C)),image2(product_prod(C,B),product_prod(B,C),product_swap(C,B)),A4))
    <=> member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y),A4) ) ).

% pair_in_swap_image
tff(fact_2884_euclidean__size__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,nat,euclid6346220572633701492n_size(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,nat,euclid6346220572633701492n_size(int),X2) ).

% euclidean_size_integer.abs_eq
tff(fact_2885_BNF__Greatest__Fixpoint_OIdD,axiom,
    ! [B: $tType,A3: B,B2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),id2(B))
     => ( A3 = B2 ) ) ).

% BNF_Greatest_Fixpoint.IdD
tff(fact_2886_IdE,axiom,
    ! [B: $tType,P3: product_prod(B,B)] :
      ( member(product_prod(B,B),P3,id2(B))
     => ~ ! [X3: B] : P3 != aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3) ) ).

% IdE
tff(fact_2887_euclidean__size__natural_Orsp,axiom,
    aa(fun(nat,nat),$o,aa(fun(nat,nat),fun(fun(nat,nat),$o),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat)),euclid6346220572633701492n_size(nat)),euclid6346220572633701492n_size(nat)) ).

% euclidean_size_natural.rsp
tff(fact_2888_Linear__order__in__diff__Id,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( order_679001287576687338der_on(B,field2(B,R),R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
          <=> ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R),id2(B))) ) ) ) ) ).

% Linear_order_in_diff_Id
tff(fact_2889_euclidean__size__unit,axiom,
    ! [B: $tType] :
      ( euclid3725896446679973847miring(B)
     => ! [A3: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,nat,euclid6346220572633701492n_size(B),A3) = aa(B,nat,euclid6346220572633701492n_size(B),one_one(B)) ) ) ) ).

% euclidean_size_unit
tff(fact_2890_euclidean__size__integer__def,axiom,
    euclid6346220572633701492n_size(code_integer) = aa(fun(int,nat),fun(code_integer,nat),map_fun(code_integer,int,nat,nat,code_int_of_integer,id(nat)),euclid6346220572633701492n_size(int)) ).

% euclidean_size_integer_def
tff(fact_2891_euclidean__size__integer_Orsp,axiom,
    aa(fun(int,nat),$o,aa(fun(int,nat),fun(fun(int,nat),$o),bNF_rel_fun(int,int,nat,nat,fequal(int),fequal(nat)),euclid6346220572633701492n_size(int)),euclid6346220572633701492n_size(int)) ).

% euclidean_size_integer.rsp
tff(fact_2892_Id__def,axiom,
    ! [B: $tType] : id2(B) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aTP_Lamp_mg(product_prod(B,B),$o)) ).

% Id_def
tff(fact_2893_unit__iff__euclidean__size,axiom,
    ! [B: $tType] :
      ( euclid3725896446679973847miring(B)
     => ! [A3: B] :
          ( dvd_dvd(B,A3,one_one(B))
        <=> ( ( aa(B,nat,euclid6346220572633701492n_size(B),A3) = aa(B,nat,euclid6346220572633701492n_size(B),one_one(B)) )
            & ( A3 != zero_zero(B) ) ) ) ) ).

% unit_iff_euclidean_size
tff(fact_2894_euclidean__size__times__unit,axiom,
    ! [B: $tType] :
      ( euclid3725896446679973847miring(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,nat,euclid6346220572633701492n_size(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,nat,euclid6346220572633701492n_size(B),B2) ) ) ) ).

% euclidean_size_times_unit
tff(fact_2895_product__swap,axiom,
    ! [B: $tType,C: $tType,A4: set(C),B5: set(B)] : aa(set(product_prod(C,B)),set(product_prod(B,C)),image2(product_prod(C,B),product_prod(B,C),product_swap(C,B)),product_Sigma(C,B,A4,aTP_Lamp_jr(set(B),fun(C,set(B)),B5))) = product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),A4)) ).

% product_swap
tff(fact_2896_prod_Oswap__def,axiom,
    ! [B: $tType,C: $tType,P3: product_prod(C,B)] : aa(product_prod(C,B),product_prod(B,C),product_swap(C,B),P3) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(product_prod(C,B),B,product_snd(C,B),P3)),aa(product_prod(C,B),C,product_fst(C,B),P3)) ).

% prod.swap_def
tff(fact_2897_reflcl__set__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X: B,Xa3: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(fun(B,fun(B,$o)),fun(B,fun(B,$o)),aa(fun(B,fun(B,$o)),fun(fun(B,fun(B,$o)),fun(B,fun(B,$o))),sup_sup(fun(B,fun(B,$o))),aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R)),fequal(B)),X),Xa3)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa3),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),R),id2(B))) ) ).

% reflcl_set_eq
tff(fact_2898_divmod__cases,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [B2: B,A3: B] :
          ( ( ( B2 != zero_zero(B) )
           => ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) = zero_zero(B) )
             => ( A3 != aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2)),B2) ) ) )
         => ( ( ( B2 != zero_zero(B) )
             => ! [Q2: B,R2: B] :
                  ( ( aa(B,B,euclid7384307370059645450egment(B),R2) = aa(B,B,euclid7384307370059645450egment(B),B2) )
                 => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,euclid6346220572633701492n_size(B),R2)),aa(B,nat,euclid6346220572633701492n_size(B),B2))
                   => ( ( R2 != zero_zero(B) )
                     => ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = Q2 )
                       => ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) = R2 )
                         => ( A3 != aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),Q2),B2)),R2) ) ) ) ) ) ) )
           => ( B2 = zero_zero(B) ) ) ) ) ).

% divmod_cases
tff(fact_2899_mod__eqI,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [B2: B,R: B,Q3: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( ( aa(B,B,euclid7384307370059645450egment(B),R) = aa(B,B,euclid7384307370059645450egment(B),B2) )
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,euclid6346220572633701492n_size(B),R)),aa(B,nat,euclid6346220572633701492n_size(B),B2))
             => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),Q3),B2)),R) = A3 )
               => ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),A3),B2) = R ) ) ) ) ) ) ).

% mod_eqI
tff(fact_2900_div__bounded,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [B2: B,R: B,Q3: B] :
          ( ( B2 != zero_zero(B) )
         => ( ( aa(B,B,euclid7384307370059645450egment(B),R) = aa(B,B,euclid7384307370059645450egment(B),B2) )
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,euclid6346220572633701492n_size(B),R)),aa(B,nat,euclid6346220572633701492n_size(B),B2))
             => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),Q3),B2)),R)),B2) = Q3 ) ) ) ) ) ).

% div_bounded
tff(fact_2901_div__eqI,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [B2: B,R: B,Q3: B,A3: B] :
          ( ( B2 != zero_zero(B) )
         => ( ( aa(B,B,euclid7384307370059645450egment(B),R) = aa(B,B,euclid7384307370059645450egment(B),B2) )
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,euclid6346220572633701492n_size(B),R)),aa(B,nat,euclid6346220572633701492n_size(B),B2))
             => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),Q3),B2)),R) = A3 )
               => ( aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),B2) = Q3 ) ) ) ) ) ) ).

% div_eqI
tff(fact_2902_division__segment__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_integer,int,code_int_of_integer,aa(code_integer,code_integer,euclid7384307370059645450egment(code_integer),X2)) = aa(int,int,euclid7384307370059645450egment(int),aa(code_integer,int,code_int_of_integer,X2)) ).

% division_segment_integer.rep_eq
tff(fact_2903_division__segment__1,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ( aa(B,B,euclid7384307370059645450egment(B),one_one(B)) = one_one(B) ) ) ).

% division_segment_1
tff(fact_2904_division__segment__numeral,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [K: num] : aa(B,B,euclid7384307370059645450egment(B),aa(num,B,numeral_numeral(B),K)) = one_one(B) ) ).

% division_segment_numeral
tff(fact_2905_division__segment__of__nat,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [N: nat] : aa(B,B,euclid7384307370059645450egment(B),aa(nat,B,semiring_1_of_nat(B),N)) = one_one(B) ) ).

% division_segment_of_nat
tff(fact_2906_division__segment__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_integer,euclid7384307370059645450egment(code_integer),aa(int,code_integer,code_integer_of_int,X2)) = aa(int,code_integer,code_integer_of_int,aa(int,int,euclid7384307370059645450egment(int),X2)) ).

% division_segment_integer.abs_eq
tff(fact_2907_division__segment__nat__def,axiom,
    ! [N: nat] : aa(nat,nat,euclid7384307370059645450egment(nat),N) = one_one(nat) ).

% division_segment_nat_def
tff(fact_2908_division__segment__integer_Orsp,axiom,
    aa(fun(int,int),$o,aa(fun(int,int),fun(fun(int,int),$o),bNF_rel_fun(int,int,int,int,fequal(int),fequal(int)),euclid7384307370059645450egment(int)),euclid7384307370059645450egment(int)) ).

% division_segment_integer.rsp
tff(fact_2909_division__segment__natural_Orsp,axiom,
    aa(fun(nat,nat),$o,aa(fun(nat,nat),fun(fun(nat,nat),$o),bNF_rel_fun(nat,nat,nat,nat,fequal(nat),fequal(nat)),euclid7384307370059645450egment(nat)),euclid7384307370059645450egment(nat)) ).

% division_segment_natural.rsp
tff(fact_2910_division__segment__integer__def,axiom,
    euclid7384307370059645450egment(code_integer) = aa(fun(int,int),fun(code_integer,code_integer),map_fun(code_integer,int,int,code_integer,code_int_of_integer,code_integer_of_int),euclid7384307370059645450egment(int)) ).

% division_segment_integer_def
tff(fact_2911_is__unit__division__segment,axiom,
    ! [B: $tType] :
      ( euclid3128863361964157862miring(B)
     => ! [A3: B] : dvd_dvd(B,aa(B,B,euclid7384307370059645450egment(B),A3),one_one(B)) ) ).

% is_unit_division_segment
tff(fact_2912_Linear__order__wf__diff__Id,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_679001287576687338der_on(B,field2(B,R),R)
     => ( wf(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R),id2(B)))
      <=> ! [A8: set(B)] :
            ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A8),field2(B,R))
           => ( ( A8 != bot_bot(set(B)) )
             => ? [X4: B] :
                  ( member(B,X4,A8)
                  & ! [Xa2: B] :
                      ( member(B,Xa2,A8)
                     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R) ) ) ) ) ) ) ).

% Linear_order_wf_diff_Id
tff(fact_2913_bsqr__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : bNF_Wellorder_bsqr(B,R) = aa(fun(product_prod(product_prod(B,B),product_prod(B,B)),$o),set(product_prod(product_prod(B,B),product_prod(B,B))),collect(product_prod(product_prod(B,B),product_prod(B,B))),aa(fun(product_prod(B,B),fun(product_prod(B,B),$o)),fun(product_prod(product_prod(B,B),product_prod(B,B)),$o),product_case_prod(product_prod(B,B),product_prod(B,B),$o),aa(fun(B,fun(B,fun(product_prod(B,B),$o))),fun(product_prod(B,B),fun(product_prod(B,B),$o)),product_case_prod(B,B,fun(product_prod(B,B),$o)),aTP_Lamp_mi(set(product_prod(B,B)),fun(B,fun(B,fun(product_prod(B,B),$o))),R)))) ).

% bsqr_def
tff(fact_2914_wo__rel_Ocases__Total3,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B,Phi: fun(B,fun(B,$o))] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,A3),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))),field2(B,R))
       => ( ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R),id2(B)))
              | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R),id2(B))) )
           => aa(B,$o,aa(B,fun(B,$o),Phi,A3),B2) )
         => ( ( ( A3 = B2 )
             => aa(B,$o,aa(B,fun(B,$o),Phi,A3),B2) )
           => aa(B,$o,aa(B,fun(B,$o),Phi,A3),B2) ) ) ) ) ).

% wo_rel.cases_Total3
tff(fact_2915_ivl__disj__un__two_I5_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or5935395276787703475ssThan(B,L,M)),set_or1337092689740270186AtMost(B,M,U)) = set_or3652927894154168847AtMost(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(5)
tff(fact_2916_ivl__disj__un__singleton_I4_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or5935395276787703475ssThan(B,L,U)),aa(set(B),set(B),insert2(B,U),bot_bot(set(B)))) = set_or3652927894154168847AtMost(B,L,U) ) ) ) ).

% ivl_disj_un_singleton(4)
tff(fact_2917_finite__greaterThanAtMost,axiom,
    ! [L: nat,U: nat] : finite_finite2(nat,set_or3652927894154168847AtMost(nat,L,U)) ).

% finite_greaterThanAtMost
tff(fact_2918_finite__greaterThanAtMost__int,axiom,
    ! [L: int,U: int] : finite_finite2(int,set_or3652927894154168847AtMost(int,L,U)) ).

% finite_greaterThanAtMost_int
tff(fact_2919_finite__greaterThanAtMost__integer,axiom,
    ! [L: code_integer,U: code_integer] : finite_finite2(code_integer,set_or3652927894154168847AtMost(code_integer,L,U)) ).

% finite_greaterThanAtMost_integer
tff(fact_2920_card__greaterThanAtMost,axiom,
    ! [L: nat,U: nat] : finite_card(nat,set_or3652927894154168847AtMost(nat,L,U)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),U),L) ).

% card_greaterThanAtMost
tff(fact_2921_greaterThanAtMost__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,L: B,U: B] :
          ( member(B,I,set_or3652927894154168847AtMost(B,L,U))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),I)
            & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),I),U) ) ) ) ).

% greaterThanAtMost_iff
tff(fact_2922_greaterThanAtMost__empty,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,K: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),K)
         => ( set_or3652927894154168847AtMost(B,K,L) = bot_bot(set(B)) ) ) ) ).

% greaterThanAtMost_empty
tff(fact_2923_greaterThanAtMost__empty__iff2,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [K: B,L: B] :
          ( ( bot_bot(set(B)) = set_or3652927894154168847AtMost(B,K,L) )
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),K),L) ) ) ).

% greaterThanAtMost_empty_iff2
tff(fact_2924_greaterThanAtMost__empty__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [K: B,L: B] :
          ( ( set_or3652927894154168847AtMost(B,K,L) = bot_bot(set(B)) )
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),K),L) ) ) ).

% greaterThanAtMost_empty_iff
tff(fact_2925_infinite__Ioc__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( ~ finite_finite2(B,set_or3652927894154168847AtMost(B,A3,B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2) ) ) ).

% infinite_Ioc_iff
tff(fact_2926_image__add__greaterThanAtMost,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [C2: B,A3: B,B2: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),C2)),set_or3652927894154168847AtMost(B,A3,B2)) = set_or3652927894154168847AtMost(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),A3),aa(B,B,aa(B,fun(B,B),plus_plus(B),C2),B2)) ) ).

% image_add_greaterThanAtMost
tff(fact_2927_Sup__greaterThanAtMost,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y)
         => ( aa(set(B),B,complete_Sup_Sup(B),set_or3652927894154168847AtMost(B,X2,Y)) = Y ) ) ) ).

% Sup_greaterThanAtMost
tff(fact_2928_Inf__greaterThanAtMost,axiom,
    ! [B: $tType] :
      ( ( comple6319245703460814977attice(B)
        & dense_linorder(B) )
     => ! [X2: B,Y: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),Y)
         => ( complete_Inf_Inf(B,set_or3652927894154168847AtMost(B,X2,Y)) = X2 ) ) ) ).

% Inf_greaterThanAtMost
tff(fact_2929_brk__rel__wf,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( wf(B,R4)
     => wf(product_prod($o,B),brk_rel(B,B,R4)) ) ).

% brk_rel_wf
tff(fact_2930_card__greaterThanAtMost__int,axiom,
    ! [L: int,U: int] : finite_card(int,set_or3652927894154168847AtMost(int,L,U)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),minus_minus(int),U),L)) ).

% card_greaterThanAtMost_int
tff(fact_2931_image__minus__const__greaterThanAtMost,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,A3: B,B2: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),minus_minus(B),C2)),set_or3652927894154168847AtMost(B,A3,B2)) = set_or7035219750837199246ssThan(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),A3)) ) ).

% image_minus_const_greaterThanAtMost
tff(fact_2932_image__diff__atLeastLessThan,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,A3: B,B2: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),minus_minus(B),C2)),set_or7035219750837199246ssThan(B,A3,B2)) = set_or3652927894154168847AtMost(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),A3)) ) ).

% image_diff_atLeastLessThan
tff(fact_2933_image__uminus__greaterThanAtMost,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B,Y: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),set_or3652927894154168847AtMost(B,X2,Y)) = set_or7035219750837199246ssThan(B,aa(B,B,uminus_uminus(B),Y),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_greaterThanAtMost
tff(fact_2934_image__uminus__atLeastLessThan,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B,Y: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),set_or7035219750837199246ssThan(B,X2,Y)) = set_or3652927894154168847AtMost(B,aa(B,B,uminus_uminus(B),Y),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_atLeastLessThan
tff(fact_2935_reduction__pairI,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),S2: set(product_prod(B,B))] :
      ( wf(B,R4)
     => ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),relcomp(B,B,B,R4,S2)),R4)
       => fun_reduction_pair(B,aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R4),S2)) ) ) ).

% reduction_pairI
tff(fact_2936_wo__rel_Omax2__equals1,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( ( bNF_We1388413361240627857o_max2(B,R,A3,B2) = A3 )
          <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),R) ) ) ) ) ).

% wo_rel.max2_equals1
tff(fact_2937_wo__rel_Omax2__equals2,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( ( bNF_We1388413361240627857o_max2(B,R,A3,B2) = B2 )
          <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R) ) ) ) ) ).

% wo_rel.max2_equals2
tff(fact_2938_wo__rel_Omax2__greater,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),bNF_We1388413361240627857o_max2(B,R,A3,B2)),R)
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),bNF_We1388413361240627857o_max2(B,R,A3,B2)),R) ) ) ) ) ).

% wo_rel.max2_greater
tff(fact_2939_wf__induct__rule,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),P: fun(B,$o),A3: B] :
      ( wf(B,R)
     => ( ! [X3: B] :
            ( ! [Y5: B] :
                ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R)
               => aa(B,$o,P,Y5) )
           => aa(B,$o,P,X3) )
       => aa(B,$o,P,A3) ) ) ).

% wf_induct_rule
tff(fact_2940_wf__eq__minimal,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( wf(B,R)
    <=> ! [Q6: set(B)] :
          ( ? [X4: B] : member(B,X4,Q6)
         => ? [X4: B] :
              ( member(B,X4,Q6)
              & ! [Y3: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y3),X4),R)
                 => ~ member(B,Y3,Q6) ) ) ) ) ).

% wf_eq_minimal
tff(fact_2941_wf__not__refl,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] :
      ( wf(B,R)
     => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3),R) ) ).

% wf_not_refl
tff(fact_2942_wf__not__sym,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,X2: B] :
      ( wf(B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),X2),R)
       => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),A3),R) ) ) ).

% wf_not_sym
tff(fact_2943_wf__irrefl,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] :
      ( wf(B,R)
     => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3),R) ) ).

% wf_irrefl
tff(fact_2944_wf__induct,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),P: fun(B,$o),A3: B] :
      ( wf(B,R)
     => ( ! [X3: B] :
            ( ! [Y5: B] :
                ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R)
               => aa(B,$o,P,Y5) )
           => aa(B,$o,P,X3) )
       => aa(B,$o,P,A3) ) ) ).

% wf_induct
tff(fact_2945_wf__asym,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,X2: B] :
      ( wf(B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),X2),R)
       => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),A3),R) ) ) ).

% wf_asym
tff(fact_2946_wfUNIVI,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ! [P4: fun(B,$o),X3: B] :
          ( ! [Xa3: B] :
              ( ! [Y4: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Xa3),R)
                 => aa(B,$o,P4,Y4) )
             => aa(B,$o,P4,Xa3) )
         => aa(B,$o,P4,X3) )
     => wf(B,R) ) ).

% wfUNIVI
tff(fact_2947_wfI__min,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( ! [X3: B,Q7: set(B)] :
          ( member(B,X3,Q7)
         => ? [Xa3: B] :
              ( member(B,Xa3,Q7)
              & ! [Y4: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Xa3),R4)
                 => ~ member(B,Y4,Q7) ) ) )
     => wf(B,R4) ) ).

% wfI_min
tff(fact_2948_wfE__min,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),X2: B,Q: set(B)] :
      ( wf(B,R4)
     => ( member(B,X2,Q)
       => ~ ! [Z3: B] :
              ( member(B,Z3,Q)
             => ~ ! [Y5: B] :
                    ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),Z3),R4)
                   => ~ member(B,Y5,Q) ) ) ) ) ).

% wfE_min
tff(fact_2949_wf__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( wf(B,R)
    <=> ! [P5: fun(B,$o)] :
          ( ! [X4: B] :
              ( ! [Y3: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y3),X4),R)
                 => aa(B,$o,P5,Y3) )
             => aa(B,$o,P5,X4) )
         => ! [X_1: B] : aa(B,$o,P5,X_1) ) ) ).

% wf_def
tff(fact_2950_wo__rel_Omax2__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( bNF_We1388413361240627857o_max2(B,R,A3,B2) = $ite(member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R),B2,A3) ) ) ).

% wo_rel.max2_def
tff(fact_2951_wo__rel_Owell__order__induct,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),P: fun(B,$o),A3: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( ! [X3: B] :
            ( ! [Y5: B] :
                ( ( ( Y5 != X3 )
                  & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R) )
               => aa(B,$o,P,Y5) )
           => aa(B,$o,P,X3) )
       => aa(B,$o,P,A3) ) ) ).

% wo_rel.well_order_induct
tff(fact_2952_Ioc__inj,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( set_or3652927894154168847AtMost(B,A3,B2) = set_or3652927894154168847AtMost(B,C2,D3) )
        <=> ( ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),D3),C2) )
            | ( ( A3 = C2 )
              & ( B2 = D3 ) ) ) ) ) ).

% Ioc_inj
tff(fact_2953_wo__rel_OTOTALS,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ! [X: B] :
          ( member(B,X,field2(B,R))
         => ! [Xa3: B] :
              ( member(B,Xa3,field2(B,R))
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa3),R)
                | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa3),X),R) ) ) ) ) ).

% wo_rel.TOTALS
tff(fact_2954_wo__rel_Omax2__greater__among,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),bNF_We1388413361240627857o_max2(B,R,A3,B2)),R)
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),bNF_We1388413361240627857o_max2(B,R,A3,B2)),R)
            & member(B,bNF_We1388413361240627857o_max2(B,R,A3,B2),aa(set(B),set(B),insert2(B,A3),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))) ) ) ) ) ).

% wo_rel.max2_greater_among
tff(fact_2955_wfE__min_H,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),Q: set(B)] :
      ( wf(B,R4)
     => ( ( Q != bot_bot(set(B)) )
       => ~ ! [Z3: B] :
              ( member(B,Z3,Q)
             => ~ ! [Y5: B] :
                    ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),Z3),R4)
                   => ~ member(B,Y5,Q) ) ) ) ) ).

% wfE_min'
tff(fact_2956_infinite__Ioc,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
         => ~ finite_finite2(B,set_or3652927894154168847AtMost(B,A3,B2)) ) ) ).

% infinite_Ioc
tff(fact_2957_Ioc__subset__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or3652927894154168847AtMost(B,A3,B2)),set_or3652927894154168847AtMost(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
            | ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% Ioc_subset_iff
tff(fact_2958_atLeastSucAtMost__greaterThanAtMost,axiom,
    ! [L: nat,U: nat] : set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,L),U) = set_or3652927894154168847AtMost(nat,L,U) ).

% atLeastSucAtMost_greaterThanAtMost
tff(fact_2959_ivl__disj__un__two_I6_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or3652927894154168847AtMost(B,L,M)),set_or3652927894154168847AtMost(B,M,U)) = set_or3652927894154168847AtMost(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(6)
tff(fact_2960_well__order__induct__imp,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),P: fun(B,$o),A3: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( ! [X3: B] :
            ( ! [Y5: B] :
                ( ( ( Y5 != X3 )
                  & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R) )
               => ( member(B,Y5,field2(B,R))
                 => aa(B,$o,P,Y5) ) )
           => ( member(B,X3,field2(B,R))
             => aa(B,$o,P,X3) ) )
       => ( member(B,A3,field2(B,R))
         => aa(B,$o,P,A3) ) ) ) ).

% well_order_induct_imp
tff(fact_2961_wf__bounded__measure,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),Ub: fun(B,nat),F: fun(B,nat)] :
      ( ! [A5: B,B3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A5),R)
         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,Ub,B3)),aa(B,nat,Ub,A5))
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,F,B3)),aa(B,nat,Ub,A5))
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,A5)),aa(B,nat,F,B3)) ) )
     => wf(B,R) ) ).

% wf_bounded_measure
tff(fact_2962_wfI,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B),B5: set(B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),B5)))
     => ( ! [X3: B,P4: fun(B,$o)] :
            ( ! [Xa3: B] :
                ( ! [Y4: B] :
                    ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Xa3),R)
                   => aa(B,$o,P4,Y4) )
               => aa(B,$o,P4,Xa3) )
           => ( member(B,X3,A4)
             => ( member(B,X3,B5)
               => aa(B,$o,P4,X3) ) ) )
       => wf(B,R) ) ) ).

% wfI
tff(fact_2963_ivl__disj__un__two_I8_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or1337092689740270186AtMost(B,L,M)),set_or3652927894154168847AtMost(B,M,U)) = set_or1337092689740270186AtMost(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(8)
tff(fact_2964_ivl__disj__un__one_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(B,set(B),set_ord_atMost(B),L)),set_or3652927894154168847AtMost(B,L,U)) = aa(B,set(B),set_ord_atMost(B),U) ) ) ) ).

% ivl_disj_un_one(3)
tff(fact_2965_atLeastPlusOneAtMost__greaterThanAtMost__int,axiom,
    ! [L: int,U: int] : set_or1337092689740270186AtMost(int,aa(int,int,aa(int,fun(int,int),plus_plus(int),L),one_one(int)),U) = set_or3652927894154168847AtMost(int,L,U) ).

% atLeastPlusOneAtMost_greaterThanAtMost_int
tff(fact_2966_ivl__disj__un__one_I5_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or3652927894154168847AtMost(B,L,U)),aa(B,set(B),set_ord_greaterThan(B),U)) = aa(B,set(B),set_ord_greaterThan(B),L) ) ) ) ).

% ivl_disj_un_one(5)
tff(fact_2967_wf__eq__minimal2,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( wf(B,R)
    <=> ! [A8: set(B)] :
          ( ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A8),field2(B,R))
            & ( A8 != bot_bot(set(B)) ) )
         => ? [X4: B] :
              ( member(B,X4,A8)
              & ! [Xa2: B] :
                  ( member(B,Xa2,A8)
                 => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),R) ) ) ) ) ).

% wf_eq_minimal2
tff(fact_2968_wf__bounded__set,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),Ub: fun(B,set(C)),F: fun(B,set(C))] :
      ( ! [A5: B,B3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A5),R)
         => ( finite_finite2(C,aa(B,set(C),Ub,A5))
            & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(B,set(C),Ub,B3)),aa(B,set(C),Ub,A5))
            & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(B,set(C),F,B3)),aa(B,set(C),Ub,A5))
            & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),aa(B,set(C),F,A5)),aa(B,set(C),F,B3)) ) )
     => wf(B,R) ) ).

% wf_bounded_set
tff(fact_2969_wo__rel_Ocases__Total,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B,Phi: fun(B,fun(B,$o))] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,A3),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))),field2(B,R))
       => ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
           => aa(B,$o,aa(B,fun(B,$o),Phi,A3),B2) )
         => ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),R)
             => aa(B,$o,aa(B,fun(B,$o),Phi,A3),B2) )
           => aa(B,$o,aa(B,fun(B,$o),Phi,A3),B2) ) ) ) ) ).

% wo_rel.cases_Total
tff(fact_2970_sum_Ohead,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),G),set_or3652927894154168847AtMost(nat,M,N))) ) ) ) ).

% sum.head
tff(fact_2971_prod_Ohead,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M: nat,N: nat,G: fun(nat,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
         => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),G),set_or3652927894154168847AtMost(nat,M,N))) ) ) ) ).

% prod.head
tff(fact_2972_greaterThanAtMost__subseteq__atLeastAtMost__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or3652927894154168847AtMost(B,A3,B2)),set_or1337092689740270186AtMost(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% greaterThanAtMost_subseteq_atLeastAtMost_iff
tff(fact_2973_greaterThanAtMost__subseteq__atLeastLessThan__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or3652927894154168847AtMost(B,A3,B2)),set_or7035219750837199246ssThan(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),D3) ) ) ) ) ).

% greaterThanAtMost_subseteq_atLeastLessThan_iff
tff(fact_2974_ivl__disj__un__two__touch_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or3652927894154168847AtMost(B,L,M)),set_or1337092689740270186AtMost(B,M,U)) = set_or3652927894154168847AtMost(B,L,U) ) ) ) ) ).

% ivl_disj_un_two_touch(3)
tff(fact_2975_greaterThanAtMost__eq__atLeastAtMost__diff,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [A3: B,B2: B] : set_or3652927894154168847AtMost(B,A3,B2) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),set_or1337092689740270186AtMost(B,A3,B2)),aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))) ) ).

% greaterThanAtMost_eq_atLeastAtMost_diff
tff(fact_2976_greaterThanLessThan__subseteq__greaterThanAtMost__iff,axiom,
    ! [B: $tType] :
      ( dense_linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or5935395276787703475ssThan(B,A3,B2)),set_or3652927894154168847AtMost(B,C2,D3))
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),B2)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),C2),A3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),D3) ) ) ) ) ).

% greaterThanLessThan_subseteq_greaterThanAtMost_iff
tff(fact_2977_ivl__disj__un__two_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or3652927894154168847AtMost(B,L,M)),set_or5935395276787703475ssThan(B,M,U)) = set_or5935395276787703475ssThan(B,L,U) ) ) ) ) ).

% ivl_disj_un_two(2)
tff(fact_2978_ivl__disj__un__two__touch_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,M: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),M)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),U)
           => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or3652927894154168847AtMost(B,L,M)),set_or7035219750837199246ssThan(B,M,U)) = set_or5935395276787703475ssThan(B,L,U) ) ) ) ) ).

% ivl_disj_un_two_touch(1)
tff(fact_2979_wf__bounded__supset,axiom,
    ! [B: $tType,S2: set(B)] :
      ( finite_finite2(B,S2)
     => wf(set(B),aa(fun(product_prod(set(B),set(B)),$o),set(product_prod(set(B),set(B))),collect(product_prod(set(B),set(B))),aa(fun(set(B),fun(set(B),$o)),fun(product_prod(set(B),set(B)),$o),product_case_prod(set(B),set(B),$o),aTP_Lamp_mj(set(B),fun(set(B),fun(set(B),$o)),S2)))) ) ).

% wf_bounded_supset
tff(fact_2980_atLeastPlusOneAtMost__greaterThanAtMost__integer,axiom,
    ! [L: code_integer,U: code_integer] : set_or1337092689740270186AtMost(code_integer,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),L),one_one(code_integer)),U) = set_or3652927894154168847AtMost(code_integer,L,U) ).

% atLeastPlusOneAtMost_greaterThanAtMost_integer
tff(fact_2981_ivl__disj__un__singleton_I5_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(B),set(B),insert2(B,L),bot_bot(set(B)))),set_or3652927894154168847AtMost(B,L,U)) = set_or1337092689740270186AtMost(B,L,U) ) ) ) ).

% ivl_disj_un_singleton(5)
tff(fact_2982_wf__iff__no__infinite__down__chain,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( wf(B,R)
    <=> ~ ? [F6: fun(nat,B)] :
          ! [I3: nat] : member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,F6,aa(nat,nat,suc,I3))),aa(nat,B,F6,I3)),R) ) ).

% wf_iff_no_infinite_down_chain
tff(fact_2983_wf__no__infinite__down__chainE,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),F: fun(nat,B)] :
      ( wf(B,R)
     => ~ ! [K3: nat] : member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,F,aa(nat,nat,suc,K3))),aa(nat,B,F,K3)),R) ) ).

% wf_no_infinite_down_chainE
tff(fact_2984_wo__rel_Ominim__least,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),B5: set(B),B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),field2(B,R))
       => ( member(B,B2,B5)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),bNF_We6954850376910717587_minim(B,R,B5)),B2),R) ) ) ) ).

% wo_rel.minim_least
tff(fact_2985_wo__rel_Oequals__minim,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),B5: set(B),A3: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),field2(B,R))
       => ( member(B,A3,B5)
         => ( ! [B3: B] :
                ( member(B,B3,B5)
               => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B3),R) )
           => ( A3 = bNF_We6954850376910717587_minim(B,R,B5) ) ) ) ) ) ).

% wo_rel.equals_minim
tff(fact_2986_dependent__wf__choice,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,B)),P: fun(fun(B,C),fun(B,fun(C,$o)))] :
      ( wf(B,R4)
     => ( ! [F3: fun(B,C),G3: fun(B,C),X3: B,R2: C] :
            ( ! [Z5: B] :
                ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z5),X3),R4)
               => ( aa(B,C,F3,Z5) = aa(B,C,G3,Z5) ) )
           => ( aa(C,$o,aa(B,fun(C,$o),aa(fun(B,C),fun(B,fun(C,$o)),P,F3),X3),R2)
            <=> aa(C,$o,aa(B,fun(C,$o),aa(fun(B,C),fun(B,fun(C,$o)),P,G3),X3),R2) ) )
       => ( ! [X3: B,F3: fun(B,C)] :
              ( ! [Y5: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R4)
                 => aa(C,$o,aa(B,fun(C,$o),aa(fun(B,C),fun(B,fun(C,$o)),P,F3),Y5),aa(B,C,F3,Y5)) )
             => ? [X_12: C] : aa(C,$o,aa(B,fun(C,$o),aa(fun(B,C),fun(B,fun(C,$o)),P,F3),X3),X_12) )
         => ? [F3: fun(B,C)] :
            ! [X: B] : aa(C,$o,aa(B,fun(C,$o),aa(fun(B,C),fun(B,fun(C,$o)),P,F3),X),aa(B,C,F3,X)) ) ) ) ).

% dependent_wf_choice
tff(fact_2987_of__rat__neg__one,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ( field_char_0_of_rat(B,aa(rat,rat,uminus_uminus(rat),one_one(rat))) = aa(B,B,uminus_uminus(B),one_one(B)) ) ) ).

% of_rat_neg_one
tff(fact_2988_Ref__Time_Oupdate__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),V: B] : ref_update(B,R,V) = heap_Time_heap(product_unit,aa(B,fun(heap_ext(product_unit),product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_mk(ref(B),fun(B,fun(heap_ext(product_unit),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),R),V)) ) ).

% Ref_Time.update_def
tff(fact_2989_sum__div__partition,axiom,
    ! [B: $tType,C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [A4: set(B),F: fun(B,C),B2: C] :
          ( finite_finite2(B,A4)
         => ( aa(C,C,aa(C,fun(C,C),divide_divide(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),A4)),B2) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),aa(C,fun(B,C),aTP_Lamp_ml(fun(B,C),fun(C,fun(B,C)),F),B2)),aa(set(B),set(B),inf_inf(set(B),A4),aa(fun(B,$o),set(B),collect(B),aa(C,fun(B,$o),aTP_Lamp_mm(fun(B,C),fun(C,fun(B,$o)),F),B2))))),aa(C,C,aa(C,fun(C,C),divide_divide(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),inf_inf(set(B),A4),aa(fun(B,$o),set(B),collect(B),aa(C,fun(B,$o),aTP_Lamp_mn(fun(B,C),fun(C,fun(B,$o)),F),B2))))),B2)) ) ) ) ).

% sum_div_partition
tff(fact_2990_bsqr__max2,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A1: B,A22: B,B1: B,B22: B] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( member(product_prod(product_prod(B,B),product_prod(B,B)),aa(product_prod(B,B),product_prod(product_prod(B,B),product_prod(B,B)),aa(product_prod(B,B),fun(product_prod(B,B),product_prod(product_prod(B,B),product_prod(B,B))),product_Pair(product_prod(B,B),product_prod(B,B)),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),A22)),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B1),B22)),bNF_Wellorder_bsqr(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),bNF_We1388413361240627857o_max2(B,R,A1,A22)),bNF_We1388413361240627857o_max2(B,R,B1,B22)),R) ) ) ).

% bsqr_max2
tff(fact_2991_UN__atLeast__UNIV,axiom,
    aa(set(set(nat)),set(nat),complete_Sup_Sup(set(nat)),aa(set(nat),set(set(nat)),image2(nat,set(nat),set_ord_atLeast(nat)),top_top(set(nat)))) = top_top(set(nat)) ).

% UN_atLeast_UNIV
tff(fact_2992_atLeast__eq__iff,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [X2: B,Y: B] :
          ( ( aa(B,set(B),set_ord_atLeast(B),X2) = aa(B,set(B),set_ord_atLeast(B),Y) )
        <=> ( X2 = Y ) ) ) ).

% atLeast_eq_iff
tff(fact_2993_unit__abs__eta__conv,axiom,
    ! [B: $tType,F: fun(product_unit,B)] : aTP_Lamp_mo(fun(product_unit,B),fun(product_unit,B),F) = F ).

% unit_abs_eta_conv
tff(fact_2994_inf__Some,axiom,
    ! [B: $tType] :
      ( inf(B)
     => ! [X2: B,Y: B] : aa(option(B),option(B),inf_inf(option(B),aa(B,option(B),some(B),X2)),aa(B,option(B),some(B),Y)) = aa(B,option(B),some(B),aa(B,B,inf_inf(B,X2),Y)) ) ).

% inf_Some
tff(fact_2995_atLeast__iff,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [I: B,K: B] :
          ( member(B,I,aa(B,set(B),set_ord_atLeast(B),K))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),K),I) ) ) ).

% atLeast_iff
tff(fact_2996_Inf__atLeast,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B] : complete_Inf_Inf(B,aa(B,set(B),set_ord_atLeast(B),X2)) = X2 ) ).

% Inf_atLeast
tff(fact_2997_atLeast__subset__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [X2: B,Y: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atLeast(B),X2)),aa(B,set(B),set_ord_atLeast(B),Y))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y),X2) ) ) ).

% atLeast_subset_iff
tff(fact_2998_image__add__atLeast,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [K: B,I: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),K)),aa(B,set(B),set_ord_atLeast(B),I)) = aa(B,set(B),set_ord_atLeast(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),K),I)) ) ).

% image_add_atLeast
tff(fact_2999_Sup__atLeast,axiom,
    ! [B: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [X2: B] : aa(set(B),B,complete_Sup_Sup(B),aa(B,set(B),set_ord_atLeast(B),X2)) = top_top(B) ) ).

% Sup_atLeast
tff(fact_3000_inter__compl__diff__conv,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] : aa(set(B),set(B),inf_inf(set(B),A4),aa(set(B),set(B),uminus_uminus(set(B)),B5)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5) ).

% inter_compl_diff_conv
tff(fact_3001_Int__atMost,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atMost(B),A3)),aa(B,set(B),set_ord_atMost(B),B2)) = aa(B,set(B),set_ord_atMost(B),aa(B,B,ord_min(B,A3),B2)) ) ).

% Int_atMost
tff(fact_3002_Compl__lessThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [K: B] : aa(set(B),set(B),uminus_uminus(set(B)),aa(B,set(B),set_ord_lessThan(B),K)) = aa(B,set(B),set_ord_atLeast(B),K) ) ).

% Compl_lessThan
tff(fact_3003_Compl__atLeast,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [K: B] : aa(set(B),set(B),uminus_uminus(set(B)),aa(B,set(B),set_ord_atLeast(B),K)) = aa(B,set(B),set_ord_lessThan(B),K) ) ).

% Compl_atLeast
tff(fact_3004_one__eq__of__rat__iff,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: rat] :
          ( ( one_one(B) = field_char_0_of_rat(B,A3) )
        <=> ( one_one(rat) = A3 ) ) ) ).

% one_eq_of_rat_iff
tff(fact_3005_of__rat__eq__1__iff,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: rat] :
          ( ( field_char_0_of_rat(B,A3) = one_one(B) )
        <=> ( A3 = one_one(rat) ) ) ) ).

% of_rat_eq_1_iff
tff(fact_3006_of__rat__1,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ( field_char_0_of_rat(B,one_one(rat)) = one_one(B) ) ) ).

% of_rat_1
tff(fact_3007_atLeast__0,axiom,
    aa(nat,set(nat),set_ord_atLeast(nat),zero_zero(nat)) = top_top(set(nat)) ).

% atLeast_0
tff(fact_3008_Icc__subset__Ici__iff,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [L: B,Ha: B,L4: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),set_or1337092689740270186AtMost(B,L,Ha)),aa(B,set(B),set_ord_atLeast(B),L4))
        <=> ( ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),Ha)
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L4),L) ) ) ) ).

% Icc_subset_Ici_iff
tff(fact_3009_Int__atLeastAtMost,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),set_or1337092689740270186AtMost(B,A3,B2)),set_or1337092689740270186AtMost(B,C2,D3)) = set_or1337092689740270186AtMost(B,aa(B,B,ord_max(B,A3),C2),aa(B,B,ord_min(B,B2),D3)) ) ).

% Int_atLeastAtMost
tff(fact_3010_Int__atLeastLessThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),set_or7035219750837199246ssThan(B,A3,B2)),set_or7035219750837199246ssThan(B,C2,D3)) = set_or7035219750837199246ssThan(B,aa(B,B,ord_max(B,A3),C2),aa(B,B,ord_min(B,B2),D3)) ) ).

% Int_atLeastLessThan
tff(fact_3011_Int__atLeastAtMostR1,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [B2: B,C2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atMost(B),B2)),set_or1337092689740270186AtMost(B,C2,D3)) = set_or1337092689740270186AtMost(B,C2,aa(B,B,ord_min(B,B2),D3)) ) ).

% Int_atLeastAtMostR1
tff(fact_3012_Int__atLeastAtMostL1,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),set_or1337092689740270186AtMost(B,A3,B2)),aa(B,set(B),set_ord_atMost(B),D3)) = set_or1337092689740270186AtMost(B,A3,aa(B,B,ord_min(B,B2),D3)) ) ).

% Int_atLeastAtMostL1
tff(fact_3013_image__minus__const__atLeast,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,A3: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),minus_minus(B),C2)),aa(B,set(B),set_ord_atLeast(B),A3)) = aa(B,set(B),set_ord_atMost(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),A3)) ) ).

% image_minus_const_atLeast
tff(fact_3014_image__minus__const__AtMost,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [C2: B,B2: B] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),minus_minus(B),C2)),aa(B,set(B),set_ord_atMost(B),B2)) = aa(B,set(B),set_ord_atLeast(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),C2),B2)) ) ).

% image_minus_const_AtMost
tff(fact_3015_image__uminus__atLeast,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),aa(B,set(B),set_ord_atLeast(B),X2)) = aa(B,set(B),set_ord_atMost(B),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_atLeast
tff(fact_3016_image__uminus__atMost,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [X2: B] : aa(set(B),set(B),image2(B,B,uminus_uminus(B)),aa(B,set(B),set_ord_atMost(B),X2)) = aa(B,set(B),set_ord_atLeast(B),aa(B,B,uminus_uminus(B),X2)) ) ).

% image_uminus_atMost
tff(fact_3017_Int__atLeastAtMostL2,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B] : aa(set(B),set(B),inf_inf(set(B),set_or1337092689740270186AtMost(B,A3,B2)),aa(B,set(B),set_ord_atLeast(B),C2)) = set_or1337092689740270186AtMost(B,aa(B,B,ord_max(B,A3),C2),B2) ) ).

% Int_atLeastAtMostL2
tff(fact_3018_Int__atLeastAtMostR2,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,C2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atLeast(B),A3)),set_or1337092689740270186AtMost(B,C2,D3)) = set_or1337092689740270186AtMost(B,aa(B,B,ord_max(B,A3),C2),D3) ) ).

% Int_atLeastAtMostR2
tff(fact_3019_Int__greaterThanAtMost,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),set_or3652927894154168847AtMost(B,A3,B2)),set_or3652927894154168847AtMost(B,C2,D3)) = set_or3652927894154168847AtMost(B,aa(B,B,ord_max(B,A3),C2),aa(B,B,ord_min(B,B2),D3)) ) ).

% Int_greaterThanAtMost
tff(fact_3020_Int__greaterThanLessThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] : aa(set(B),set(B),inf_inf(set(B),set_or5935395276787703475ssThan(B,A3,B2)),set_or5935395276787703475ssThan(B,C2,D3)) = set_or5935395276787703475ssThan(B,aa(B,B,ord_max(B,A3),C2),aa(B,B,ord_min(B,B2),D3)) ) ).

% Int_greaterThanLessThan
tff(fact_3021_one__le__of__rat__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [R: rat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),field_char_0_of_rat(B,R))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less_eq(rat),one_one(rat)),R) ) ) ).

% one_le_of_rat_iff
tff(fact_3022_of__rat__le__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [R: rat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),field_char_0_of_rat(B,R)),one_one(B))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less_eq(rat),R),one_one(rat)) ) ) ).

% of_rat_le_1_iff
tff(fact_3023_one__less__of__rat__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [R: rat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),field_char_0_of_rat(B,R))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less(rat),one_one(rat)),R) ) ) ).

% one_less_of_rat_iff
tff(fact_3024_of__rat__less__1__iff,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [R: rat] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),field_char_0_of_rat(B,R)),one_one(B))
        <=> aa(rat,$o,aa(rat,fun(rat,$o),ord_less(rat),R),one_one(rat)) ) ) ).

% of_rat_less_1_iff
tff(fact_3025_atLeastLessThan__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [L: B,U: B] : set_or7035219750837199246ssThan(B,L,U) = aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atLeast(B),L)),aa(B,set(B),set_ord_lessThan(B),U)) ) ).

% atLeastLessThan_def
tff(fact_3026_well__order__on__domain,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),A3: B,B2: B] :
      ( order_well_order_on(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => ( member(B,A3,A4)
          & member(B,B2,A4) ) ) ) ).

% well_order_on_domain
tff(fact_3027_Inf__unit__def,axiom,
    ! [Uu: set(product_unit)] : complete_Inf_Inf(product_unit,Uu) = product_Unity ).

% Inf_unit_def
tff(fact_3028_Sup__unit__def,axiom,
    ! [Uu: set(product_unit)] : aa(set(product_unit),product_unit,complete_Sup_Sup(product_unit),Uu) = product_Unity ).

% Sup_unit_def
tff(fact_3029_Times__Int__distrib1,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(B),C5: set(C)] : product_Sigma(B,C,aa(set(B),set(B),inf_inf(set(B),A4),B5),aTP_Lamp_jm(set(C),fun(B,set(C)),C5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))),product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),C5))) ).

% Times_Int_distrib1
tff(fact_3030_Sigma__Int__distrib2,axiom,
    ! [C: $tType,B: $tType,I4: set(B),A4: fun(B,set(C)),B5: fun(B,set(C))] : product_Sigma(B,C,I4,aa(fun(B,set(C)),fun(B,set(C)),aTP_Lamp_mp(fun(B,set(C)),fun(fun(B,set(C)),fun(B,set(C))),A4),B5)) = aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),product_Sigma(B,C,I4,A4)),product_Sigma(B,C,I4,B5)) ).

% Sigma_Int_distrib2
tff(fact_3031_Times__Int__Times,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C),C5: set(B),D4: set(C)] : aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5))),product_Sigma(B,C,C5,aTP_Lamp_jm(set(C),fun(B,set(C)),D4))) = product_Sigma(B,C,aa(set(B),set(B),inf_inf(set(B),A4),C5),aa(set(C),fun(B,set(C)),aTP_Lamp_mq(set(C),fun(set(C),fun(B,set(C))),B5),D4)) ).

% Times_Int_Times
tff(fact_3032_Sigma__Int__distrib1,axiom,
    ! [C: $tType,B: $tType,I4: set(B),J4: set(B),C5: fun(B,set(C))] : product_Sigma(B,C,aa(set(B),set(B),inf_inf(set(B),I4),J4),C5) = aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),product_Sigma(B,C,I4,C5)),product_Sigma(B,C,J4,C5)) ).

% Sigma_Int_distrib1
tff(fact_3033_old_Ounit_Oexhaust,axiom,
    ! [Y: product_unit] : Y = product_Unity ).

% old.unit.exhaust
tff(fact_3034_top__unit__def,axiom,
    top_top(product_unit) = product_Unity ).

% top_unit_def
tff(fact_3035_uminus__unit__def,axiom,
    ! [Uu: product_unit] : aa(product_unit,product_unit,uminus_uminus(product_unit),Uu) = product_Unity ).

% uminus_unit_def
tff(fact_3036_bot__unit__def,axiom,
    bot_bot(product_unit) = product_Unity ).

% bot_unit_def
tff(fact_3037_ivl__disj__int__one_I8_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or7035219750837199246ssThan(B,L,U)),aa(B,set(B),set_ord_atLeast(B),U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(8)
tff(fact_3038_sup__unit__def,axiom,
    ! [Uu: product_unit,Uv: product_unit] : aa(product_unit,product_unit,aa(product_unit,fun(product_unit,product_unit),sup_sup(product_unit),Uu),Uv) = product_Unity ).

% sup_unit_def
tff(fact_3039_atLeastAtMost__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [L: B,U: B] : set_or1337092689740270186AtMost(B,L,U) = aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atLeast(B),L)),aa(B,set(B),set_ord_atMost(B),U)) ) ).

% atLeastAtMost_def
tff(fact_3040_ivl__disj__int__one_I6_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or5935395276787703475ssThan(B,L,U)),aa(B,set(B),set_ord_atLeast(B),U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(6)
tff(fact_3041_disjointI,axiom,
    ! [B: $tType,A3: set(B),B2: set(B)] :
      ( ! [X3: B] :
          ( member(B,X3,A3)
         => ~ member(B,X3,B2) )
     => ( aa(set(B),set(B),inf_inf(set(B),A3),B2) = bot_bot(set(B)) ) ) ).

% disjointI
tff(fact_3042_inter__eq__subsetI,axiom,
    ! [B: $tType,S2: set(B),S5: set(B),A4: set(B),B5: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S2),S5)
     => ( ( aa(set(B),set(B),inf_inf(set(B),A4),S5) = aa(set(B),set(B),inf_inf(set(B),B5),S5) )
       => ( aa(set(B),set(B),inf_inf(set(B),A4),S2) = aa(set(B),set(B),inf_inf(set(B),B5),S2) ) ) ) ).

% inter_eq_subsetI
tff(fact_3043_not__empty__eq__Ici__eq__empty,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [L: B] : bot_bot(set(B)) != aa(B,set(B),set_ord_atLeast(B),L) ) ).

% not_empty_eq_Ici_eq_empty
tff(fact_3044_infinite__Ici,axiom,
    ! [B: $tType] :
      ( ( linorder(B)
        & no_top(B) )
     => ! [A3: B] : ~ finite_finite2(B,aa(B,set(B),set_ord_atLeast(B),A3)) ) ).

% infinite_Ici
tff(fact_3045_not__UNIV__eq__Ici,axiom,
    ! [B: $tType] :
      ( no_bot(B)
     => ! [L4: B] : top_top(set(B)) != aa(B,set(B),set_ord_atLeast(B),L4) ) ).

% not_UNIV_eq_Ici
tff(fact_3046_not__Ici__eq__Icc,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [L4: B,L: B,Ha: B] : aa(B,set(B),set_ord_atLeast(B),L4) != set_or1337092689740270186AtMost(B,L,Ha) ) ).

% not_Ici_eq_Icc
tff(fact_3047_not__Iic__eq__Ici,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [Ha: B,L4: B] : aa(B,set(B),set_ord_atMost(B),Ha) != aa(B,set(B),set_ord_atLeast(B),L4) ) ).

% not_Iic_eq_Ici
tff(fact_3048_atMost__Int__atLeast,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [N: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atMost(B),N)),aa(B,set(B),set_ord_atLeast(B),N)) = aa(set(B),set(B),insert2(B,N),bot_bot(set(B))) ) ).

% atMost_Int_atLeast
tff(fact_3049_atLeast__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [L: B] : aa(B,set(B),set_ord_atLeast(B),L) = aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),ord_less_eq(B),L)) ) ).

% atLeast_def
tff(fact_3050_inf__option__def,axiom,
    ! [B: $tType] :
      ( inf(B)
     => ! [X2: option(B),Y: option(B)] : aa(option(B),option(B),inf_inf(option(B),X2),Y) = aa(option(B),option(B),aa(fun(B,option(B)),fun(option(B),option(B)),aa(option(B),fun(fun(B,option(B)),fun(option(B),option(B))),case_option(option(B),B),none(B)),aTP_Lamp_ms(option(B),fun(B,option(B)),Y)),X2) ) ).

% inf_option_def
tff(fact_3051_translation__Int,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,S: set(B),T2: set(B)] : aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),aa(set(B),set(B),inf_inf(set(B),S),T2)) = aa(set(B),set(B),inf_inf(set(B),aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),S)),aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),T2)) ) ).

% translation_Int
tff(fact_3052_disjoint__mono,axiom,
    ! [B: $tType,A3: set(B),A6: set(B),B2: set(B),B4: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A3),A6)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B2),B4)
       => ( ( aa(set(B),set(B),inf_inf(set(B),A6),B4) = bot_bot(set(B)) )
         => ( aa(set(B),set(B),inf_inf(set(B),A3),B2) = bot_bot(set(B)) ) ) ) ) ).

% disjoint_mono
tff(fact_3053_disjoint__alt__simp2,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5) != A4 )
    <=> ( aa(set(B),set(B),inf_inf(set(B),A4),B5) != bot_bot(set(B)) ) ) ).

% disjoint_alt_simp2
tff(fact_3054_disjoint__alt__simp1,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5) = A4 )
    <=> ( aa(set(B),set(B),inf_inf(set(B),A4),B5) = bot_bot(set(B)) ) ) ).

% disjoint_alt_simp1
tff(fact_3055_ivl__disj__int__two_I3_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or7035219750837199246ssThan(B,L,M)),set_or7035219750837199246ssThan(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(3)
tff(fact_3056_ivl__disj__int__two_I6_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or3652927894154168847AtMost(B,L,M)),set_or3652927894154168847AtMost(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(6)
tff(fact_3057_greaterThan__Int__greaterThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_lessThan(B),A3)),aa(B,set(B),set_ord_lessThan(B),B2)) = aa(B,set(B),set_ord_lessThan(B),aa(B,B,ord_min(B,A3),B2)) ) ).

% greaterThan_Int_greaterThan
tff(fact_3058_atLeast__eq__UNIV__iff,axiom,
    ! [B: $tType] :
      ( order_bot(B)
     => ! [X2: B] :
          ( ( aa(B,set(B),set_ord_atLeast(B),X2) = top_top(set(B)) )
        <=> ( X2 = bot_bot(B) ) ) ) ).

% atLeast_eq_UNIV_iff
tff(fact_3059_not__UNIV__le__Ici,axiom,
    ! [B: $tType] :
      ( no_bot(B)
     => ! [L: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),top_top(set(B))),aa(B,set(B),set_ord_atLeast(B),L)) ) ).

% not_UNIV_le_Ici
tff(fact_3060_UNIV__unit,axiom,
    top_top(set(product_unit)) = aa(set(product_unit),set(product_unit),insert2(product_unit,product_Unity),bot_bot(set(product_unit))) ).

% UNIV_unit
tff(fact_3061_not__Ici__le__Icc,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [L: B,L4: B,H2: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atLeast(B),L)),set_or1337092689740270186AtMost(B,L4,H2)) ) ).

% not_Ici_le_Icc
tff(fact_3062_lessThan__Int__lessThan,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_greaterThan(B),A3)),aa(B,set(B),set_ord_greaterThan(B),B2)) = aa(B,set(B),set_ord_greaterThan(B),aa(B,B,ord_max(B,A3),B2)) ) ).

% lessThan_Int_lessThan
tff(fact_3063_not__Iic__le__Ici,axiom,
    ! [B: $tType] :
      ( no_bot(B)
     => ! [Ha: B,L4: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atMost(B),Ha)),aa(B,set(B),set_ord_atLeast(B),L4)) ) ).

% not_Iic_le_Ici
tff(fact_3064_not__Ici__le__Iic,axiom,
    ! [B: $tType] :
      ( no_top(B)
     => ! [L: B,H2: B] : ~ aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atLeast(B),L)),aa(B,set(B),set_ord_atMost(B),H2)) ) ).

% not_Ici_le_Iic
tff(fact_3065_translation__subtract__Int,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B,S: set(B),T2: set(B)] : aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),aa(set(B),set(B),inf_inf(set(B),S),T2)) = aa(set(B),set(B),inf_inf(set(B),aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),S)),aa(set(B),set(B),image2(B,B,aTP_Lamp_go(B,fun(B,B),A3)),T2)) ) ).

% translation_subtract_Int
tff(fact_3066_of__rat__add,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [A3: rat,B2: rat] : field_char_0_of_rat(B,aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),A3),B2)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),field_char_0_of_rat(B,A3)),field_char_0_of_rat(B,B2)) ) ).

% of_rat_add
tff(fact_3067_Ioi__le__Ico,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A3: B] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_greaterThan(B),A3)),aa(B,set(B),set_ord_atLeast(B),A3)) ) ).

% Ioi_le_Ico
tff(fact_3068_atLeast__Suc__greaterThan,axiom,
    ! [K: nat] : aa(nat,set(nat),set_ord_atLeast(nat),aa(nat,nat,suc,K)) = aa(nat,set(nat),set_ord_greaterThan(nat),K) ).

% atLeast_Suc_greaterThan
tff(fact_3069_ivl__disj__int__two_I7_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or7035219750837199246ssThan(B,L,M)),set_or1337092689740270186AtMost(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(7)
tff(fact_3070_disjoint__alt__simp3,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5)),A4)
    <=> ( aa(set(B),set(B),inf_inf(set(B),A4),B5) != bot_bot(set(B)) ) ) ).

% disjoint_alt_simp3
tff(fact_3071_Ioc__disjoint,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B,C2: B,D3: B] :
          ( ( aa(set(B),set(B),inf_inf(set(B),set_or3652927894154168847AtMost(B,A3,B2)),set_or3652927894154168847AtMost(B,C2,D3)) = bot_bot(set(B)) )
        <=> ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),A3)
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),D3),C2)
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),B2),C2)
            | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),D3),A3) ) ) ) ).

% Ioc_disjoint
tff(fact_3072_ivl__disj__int__one_I4_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_lessThan(B),L)),set_or1337092689740270186AtMost(B,L,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(4)
tff(fact_3073_ivl__disj__int__one_I2_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_lessThan(B),L)),set_or7035219750837199246ssThan(B,L,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(2)
tff(fact_3074_wait__def,axiom,
    ! [N: nat] : heap_Time_wait(N) = aa(fun(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(product_unit),heap_Time_Heap2(product_unit),aTP_Lamp_mt(nat,fun(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),N)) ).

% wait_def
tff(fact_3075_ivl__disj__int__two_I8_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or1337092689740270186AtMost(B,L,M)),set_or3652927894154168847AtMost(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(8)
tff(fact_3076_ivl__disj__int__two_I5_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or5935395276787703475ssThan(B,L,M)),set_or1337092689740270186AtMost(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(5)
tff(fact_3077_ivl__disj__int__two_I4_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or1337092689740270186AtMost(B,L,M)),set_or5935395276787703475ssThan(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(4)
tff(fact_3078_ivl__disj__int__two_I1_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or5935395276787703475ssThan(B,L,M)),set_or7035219750837199246ssThan(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(1)
tff(fact_3079_ivl__disj__int__one_I3_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atMost(B),L)),set_or3652927894154168847AtMost(B,L,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(3)
tff(fact_3080_ivl__disj__int__one_I7_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or1337092689740270186AtMost(B,L,U)),aa(B,set(B),set_ord_greaterThan(B),U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(7)
tff(fact_3081_ivl__disj__int__one_I1_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_atMost(B),L)),set_or5935395276787703475ssThan(B,L,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(1)
tff(fact_3082_ivl__disj__int__two_I2_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,M: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or3652927894154168847AtMost(B,L,M)),set_or5935395276787703475ssThan(B,M,U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_two(2)
tff(fact_3083_ivl__disj__int__one_I5_J,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [L: B,U: B] : aa(set(B),set(B),inf_inf(set(B),set_or3652927894154168847AtMost(B,L,U)),aa(B,set(B),set_ord_greaterThan(B),U)) = bot_bot(set(B)) ) ).

% ivl_disj_int_one(5)
tff(fact_3084_ivl__disj__un__one_I8_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or7035219750837199246ssThan(B,L,U)),aa(B,set(B),set_ord_atLeast(B),U)) = aa(B,set(B),set_ord_atLeast(B),L) ) ) ) ).

% ivl_disj_un_one(8)
tff(fact_3085_prod_Ointer__restrict,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(B),G: fun(B,C),B5: set(B)] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),aa(set(B),set(B),inf_inf(set(B),A4),B5)) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),aa(set(B),fun(B,C),aTP_Lamp_mu(fun(B,C),fun(set(B),fun(B,C)),G),B5)),A4) ) ) ) ).

% prod.inter_restrict
tff(fact_3086_greaterThanAtMost__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [L: B,U: B] : set_or3652927894154168847AtMost(B,L,U) = aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_greaterThan(B),L)),aa(B,set(B),set_ord_atMost(B),U)) ) ).

% greaterThanAtMost_def
tff(fact_3087_greaterThanLessThan__eq,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [A3: B,B2: B] : set_or5935395276787703475ssThan(B,A3,B2) = aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_greaterThan(B),A3)),aa(B,set(B),set_ord_lessThan(B),B2)) ) ).

% greaterThanLessThan_eq
tff(fact_3088_greaterThanLessThan__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [L: B,U: B] : set_or5935395276787703475ssThan(B,L,U) = aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_greaterThan(B),L)),aa(B,set(B),set_ord_lessThan(B),U)) ) ).

% greaterThanLessThan_def
tff(fact_3089_Ici__subset__Ioi__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A3: B,B2: B] :
          ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(B,set(B),set_ord_atLeast(B),A3)),aa(B,set(B),set_ord_greaterThan(B),B2))
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),B2),A3) ) ) ).

% Ici_subset_Ioi_iff
tff(fact_3090_execute__assert_H,axiom,
    ! [P: $o,Ha: heap_ext(product_unit)] :
      aa(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(product_unit),fun(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(product_unit),refine_Imp_assert((P))),Ha) = $ite((P),aa(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),some(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),aa(product_unit,fun(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),product_Pair(product_unit,product_prod(heap_ext(product_unit),nat)),product_Unity),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),zero_zero(nat)))),none(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))) ).

% execute_assert'
tff(fact_3091_sum_Ounion__inter,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),B5: set(B),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(B,B5)
           => ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),inf_inf(set(B),A4),B5))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),B5)) ) ) ) ) ).

% sum.union_inter
tff(fact_3092_sum_OInt__Diff,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),G: fun(B,C),B5: set(B)] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),inf_inf(set(B),A4),B5))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5))) ) ) ) ).

% sum.Int_Diff
tff(fact_3093_prod_Omono__neutral__cong,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [T5: set(B),S2: set(B),Ha: fun(B,C),G: fun(B,C)] :
          ( finite_finite2(B,T5)
         => ( finite_finite2(B,S2)
           => ( ! [I2: B] :
                  ( member(B,I2,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),T5),S2))
                 => ( aa(B,C,Ha,I2) = one_one(C) ) )
             => ( ! [I2: B] :
                    ( member(B,I2,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),T5))
                   => ( aa(B,C,G,I2) = one_one(C) ) )
               => ( ! [X3: B] :
                      ( member(B,X3,aa(set(B),set(B),inf_inf(set(B),S2),T5))
                     => ( aa(B,C,G,X3) = aa(B,C,Ha,X3) ) )
                 => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),S2) = aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),Ha),T5) ) ) ) ) ) ) ) ).

% prod.mono_neutral_cong
tff(fact_3094_Iio__Int__singleton,axiom,
    ! [B: $tType] :
      ( order(B)
     => ! [K: B,X2: B] :
          aa(set(B),set(B),inf_inf(set(B),aa(B,set(B),set_ord_lessThan(B),K)),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))) = $ite(aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),K),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))),bot_bot(set(B))) ) ).

% Iio_Int_singleton
tff(fact_3095_card__Un__Int,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(B,B5)
       => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,A4)),finite_card(B,B5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))),finite_card(B,aa(set(B),set(B),inf_inf(set(B),A4),B5))) ) ) ) ).

% card_Un_Int
tff(fact_3096_sum_OIf__cases,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),P: fun(B,$o),Ha: fun(B,C),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),aa(fun(B,C),fun(B,C),aa(fun(B,C),fun(fun(B,C),fun(B,C)),aTP_Lamp_mv(fun(B,$o),fun(fun(B,C),fun(fun(B,C),fun(B,C))),P),Ha),G)),A4) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),Ha),aa(set(B),set(B),inf_inf(set(B),A4),aa(fun(B,$o),set(B),collect(B),P)))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),inf_inf(set(B),A4),aa(set(B),set(B),uminus_uminus(set(B)),aa(fun(B,$o),set(B),collect(B),P))))) ) ) ) ).

% sum.If_cases
tff(fact_3097_ivl__disj__un__singleton_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(B),set(B),insert2(B,L),bot_bot(set(B)))),aa(B,set(B),set_ord_greaterThan(B),L)) = aa(B,set(B),set_ord_atLeast(B),L) ) ).

% ivl_disj_un_singleton(1)
tff(fact_3098_ivl__disj__un__one_I7_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or1337092689740270186AtMost(B,L,U)),aa(B,set(B),set_ord_greaterThan(B),U)) = aa(B,set(B),set_ord_atLeast(B),L) ) ) ) ).

% ivl_disj_un_one(7)
tff(fact_3099_ivl__disj__un__one_I6_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: B,U: B] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),L),U)
         => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_or5935395276787703475ssThan(B,L,U)),aa(B,set(B),set_ord_atLeast(B),U)) = aa(B,set(B),set_ord_greaterThan(B),L) ) ) ) ).

% ivl_disj_un_one(6)
tff(fact_3100_Linear__order__Well__order__iff,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_679001287576687338der_on(B,field2(B,R),R)
     => ( order_well_order_on(B,field2(B,R),R)
      <=> ! [A8: set(B)] :
            ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A8),field2(B,R))
           => ( ( A8 != bot_bot(set(B)) )
             => ? [X4: B] :
                  ( member(B,X4,A8)
                  & ! [Xa2: B] :
                      ( member(B,Xa2,A8)
                     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R) ) ) ) ) ) ) ).

% Linear_order_Well_order_iff
tff(fact_3101_sum_Ounion__inter__neutral,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),B5: set(B),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(B,B5)
           => ( ! [X3: B] :
                  ( member(B,X3,aa(set(B),set(B),inf_inf(set(B),A4),B5))
                 => ( aa(B,C,G,X3) = zero_zero(C) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),B5)) ) ) ) ) ) ).

% sum.union_inter_neutral
tff(fact_3102_sum__Un,axiom,
    ! [C: $tType,B: $tType] :
      ( ab_group_add(C)
     => ! [A4: set(B),B5: set(B),F: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(B,B5)
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(C,C,aa(C,fun(C,C),minus_minus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),A4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),B5))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),inf_inf(set(B),A4),B5))) ) ) ) ) ).

% sum_Un
tff(fact_3103_sum_Ounion__disjoint,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),B5: set(B),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(B,B5)
           => ( ( aa(set(B),set(B),inf_inf(set(B),A4),B5) = bot_bot(set(B)) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),A4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),B5)) ) ) ) ) ) ).

% sum.union_disjoint
tff(fact_3104_prod_Ounion__inter__neutral,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [A4: set(B),B5: set(B),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(B,B5)
           => ( ! [X3: B] :
                  ( member(B,X3,aa(set(B),set(B),inf_inf(set(B),A4),B5))
                 => ( aa(B,C,G,X3) = one_one(C) ) )
             => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),A4)),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),B5)) ) ) ) ) ) ).

% prod.union_inter_neutral
tff(fact_3105_execute__update,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),V: B,Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(product_unit),fun(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(product_unit),ref_update(B,R,V)),Ha) = aa(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),some(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),aa(product_unit,fun(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),product_Pair(product_unit,product_prod(heap_ext(product_unit),nat)),product_Unity),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),ref_set(B,R,V,Ha)),one_one(nat)))) ) ).

% execute_update
tff(fact_3106_sum_Ounion__diff2,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),B5: set(B),G: fun(B,C)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(B,B5)
           => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),B5),A4)))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),aa(set(B),set(B),inf_inf(set(B),A4),B5))) ) ) ) ) ).

% sum.union_diff2
tff(fact_3107_sum__Un2,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: set(B),B5: set(B),F: fun(B,C)] :
          ( finite_finite2(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),B5),A4)))),aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),F),aa(set(B),set(B),inf_inf(set(B),A4),B5))) ) ) ) ).

% sum_Un2
tff(fact_3108_card__Un__disjoint,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(B,B5)
       => ( ( aa(set(B),set(B),inf_inf(set(B),A4),B5) = bot_bot(set(B)) )
         => ( finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,A4)),finite_card(B,B5)) ) ) ) ) ).

% card_Un_disjoint
tff(fact_3109_sum__Un__nat,axiom,
    ! [B: $tType,A4: set(B),B5: set(B),F: fun(B,nat)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(B,B5)
       => ( aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),F),A4)),aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),F),B5))),aa(set(B),nat,aa(fun(B,nat),fun(set(B),nat),groups7311177749621191930dd_sum(B,nat),F),aa(set(B),set(B),inf_inf(set(B),A4),B5))) ) ) ) ).

% sum_Un_nat
tff(fact_3110_atLeast__Suc,axiom,
    ! [K: nat] : aa(nat,set(nat),set_ord_atLeast(nat),aa(nat,nat,suc,K)) = aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),minus_minus(set(nat)),aa(nat,set(nat),set_ord_atLeast(nat),K)),aa(set(nat),set(nat),insert2(nat,K),bot_bot(set(nat)))) ).

% atLeast_Suc
tff(fact_3111_old_Ounit_Orec,axiom,
    ! [B: $tType,F1: B] : product_rec_unit(B,F1,product_Unity) = F1 ).

% old.unit.rec
tff(fact_3112_default__unit__def,axiom,
    default_default(product_unit) = product_Unity ).

% default_unit_def
tff(fact_3113_CODE__ABORT__def,axiom,
    ! [B: $tType,F: fun(product_unit,B)] : cODE_ABORT(B,F) = aa(product_unit,B,F,product_Unity) ).

% CODE_ABORT_def
tff(fact_3114_Inf__fin_Oeq__fold_H,axiom,
    ! [B: $tType] :
      ( semilattice_inf(B)
     => ! [A4: set(B)] : lattic7752659483105999362nf_fin(B,A4) = aa(option(B),B,the2(B),finite_fold(B,option(B),aTP_Lamp_mw(B,fun(option(B),option(B))),none(B),A4)) ) ).

% Inf_fin.eq_fold'
tff(fact_3115_image__split__eq__Sigma,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(D,B),G: fun(D,C),A4: set(D)] : aa(set(D),set(product_prod(B,C)),image2(D,product_prod(B,C),aa(fun(D,C),fun(D,product_prod(B,C)),aTP_Lamp_mx(fun(D,B),fun(fun(D,C),fun(D,product_prod(B,C))),F),G)),A4) = product_Sigma(B,C,aa(set(D),set(B),image2(D,B,F),A4),aa(set(D),fun(B,set(C)),aa(fun(D,C),fun(set(D),fun(B,set(C))),aTP_Lamp_my(fun(D,B),fun(fun(D,C),fun(set(D),fun(B,set(C)))),F),G),A4)) ).

% image_split_eq_Sigma
tff(fact_3116_atLeast__empty__triv,axiom,
    ! [B: $tType] : aa(set(B),set(set(B)),set_ord_atLeast(set(B)),bot_bot(set(B))) = top_top(set(set(B))) ).

% atLeast_empty_triv
tff(fact_3117_inf__None__2,axiom,
    ! [B: $tType] :
      ( inf(B)
     => ! [X2: option(B)] : aa(option(B),option(B),inf_inf(option(B),X2),none(B)) = none(B) ) ).

% inf_None_2
tff(fact_3118_inf__None__1,axiom,
    ! [B: $tType] :
      ( inf(B)
     => ! [Y: option(B)] : aa(option(B),option(B),inf_inf(option(B),none(B)),Y) = none(B) ) ).

% inf_None_1
tff(fact_3119_vimage__id,axiom,
    ! [B: $tType] : vimage(B,B,id(B)) = id(set(B)) ).

% vimage_id
tff(fact_3120_set_Ocomp,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,D),G: fun(D,B)] : aa(fun(set(B),set(D)),fun(set(B),set(C)),aa(fun(set(D),set(C)),fun(fun(set(B),set(D)),fun(set(B),set(C))),comp(set(D),set(C),set(B)),vimage(C,D,F)),vimage(D,B,G)) = vimage(C,B,aa(fun(C,D),fun(C,B),aa(fun(D,B),fun(fun(C,D),fun(C,B)),comp(D,B,C),G),F)) ).

% set.comp
tff(fact_3121_set_Ocompositionality,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),G: fun(C,D),Set: set(D)] : aa(set(C),set(B),vimage(B,C,F),aa(set(D),set(C),vimage(C,D,G),Set)) = aa(set(D),set(B),vimage(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),F)),Set) ).

% set.compositionality
tff(fact_3122_vimage__comp,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),G: fun(C,D),X2: set(D)] : aa(set(C),set(B),vimage(B,C,F),aa(set(D),set(C),vimage(C,D,G),X2)) = aa(set(D),set(B),vimage(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),F)),X2) ).

% vimage_comp
tff(fact_3123_inf__unit__def,axiom,
    ! [Uu: product_unit,Uv: product_unit] : aa(product_unit,product_unit,inf_inf(product_unit,Uu),Uv) = product_Unity ).

% inf_unit_def
tff(fact_3124_inf__Int__eq2,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(B,C)),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),inf_inf(fun(B,fun(C,$o)),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R4)),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),S2)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),R4),S2)) ) ).

% inf_Int_eq2
tff(fact_3125_surj__image__vimage__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),A4: set(B)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ( aa(set(C),set(B),image2(C,B,F),aa(set(B),set(C),vimage(C,B,F),A4)) = A4 ) ) ).

% surj_image_vimage_eq
tff(fact_3126_set_Oidentity,axiom,
    ! [B: $tType] : vimage(B,B,aTP_Lamp_ay(B,B)) = id(set(B)) ).

% set.identity
tff(fact_3127_vimage__Times,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,product_prod(C,D)),A4: set(C),B5: set(D)] : aa(set(product_prod(C,D)),set(B),vimage(B,product_prod(C,D),F),product_Sigma(C,D,A4,aTP_Lamp_mz(set(D),fun(C,set(D)),B5))) = aa(set(B),set(B),inf_inf(set(B),aa(set(C),set(B),vimage(B,C,aa(fun(B,product_prod(C,D)),fun(B,C),aa(fun(product_prod(C,D),C),fun(fun(B,product_prod(C,D)),fun(B,C)),comp(product_prod(C,D),C,B),product_fst(C,D)),F)),A4)),aa(set(D),set(B),vimage(B,D,aa(fun(B,product_prod(C,D)),fun(B,D),aa(fun(product_prod(C,D),D),fun(fun(B,product_prod(C,D)),fun(B,D)),comp(product_prod(C,D),D,B),product_snd(C,D)),F)),B5)) ).

% vimage_Times
tff(fact_3128_Pair__vimage__Sigma,axiom,
    ! [C: $tType,B: $tType,X2: C,A4: set(C),F: fun(C,set(B))] :
      aa(set(product_prod(C,B)),set(B),vimage(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2)),product_Sigma(C,B,A4,F)) = $ite(member(C,X2,A4),aa(C,set(B),F,X2),bot_bot(set(B))) ).

% Pair_vimage_Sigma
tff(fact_3129_surj__vimage__empty,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),A4: set(B)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ( ( aa(set(B),set(C),vimage(C,B,F),A4) = bot_bot(set(C)) )
      <=> ( A4 = bot_bot(set(B)) ) ) ) ).

% surj_vimage_empty
tff(fact_3130_vimage__subsetD,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),B5: set(B),A4: set(C)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),vimage(C,B,F),B5)),A4)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),aa(set(C),set(B),image2(C,B,F),A4)) ) ) ).

% vimage_subsetD
tff(fact_3131_vimage__fst,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] : aa(set(B),set(product_prod(B,C)),vimage(product_prod(B,C),B,product_fst(B,C)),A4) = product_Sigma(B,C,A4,aTP_Lamp_jn(B,set(C))) ).

% vimage_fst
tff(fact_3132_vimage__snd,axiom,
    ! [B: $tType,C: $tType,A4: set(C)] : aa(set(C),set(product_prod(B,C)),vimage(product_prod(B,C),C,product_snd(B,C)),A4) = product_Sigma(B,C,top_top(set(B)),aTP_Lamp_jm(set(C),fun(B,set(C)),A4)) ).

% vimage_snd
tff(fact_3133_Inf__fin_Oinfinite,axiom,
    ! [B: $tType] :
      ( semilattice_inf(B)
     => ! [A4: set(B)] :
          ( ~ finite_finite2(B,A4)
         => ( lattic7752659483105999362nf_fin(B,A4) = aa(option(B),B,the2(B),none(B)) ) ) ) ).

% Inf_fin.infinite
tff(fact_3134_rtrancl__last__visit__node,axiom,
    ! [B: $tType,S: B,S3: B,R4: set(product_prod(B,B)),Sh: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),S),S3),transitive_rtrancl(B,R4))
     => ( ( ( S != Sh )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),S),S3),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_na(B,fun(B,set(B)),Sh))))) )
        | ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),S),Sh),transitive_rtrancl(B,R4))
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Sh),S3),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_na(B,fun(B,set(B)),Sh))))) ) ) ) ).

% rtrancl_last_visit_node
tff(fact_3135_floor__rat__def,axiom,
    ! [X2: rat] : archim6421214686448440834_floor(rat,X2) = the(int,aTP_Lamp_nb(rat,fun(int,$o),X2)) ).

% floor_rat_def
tff(fact_3136_rat__floor__lemma,axiom,
    ! [A3: int,B2: int] :
      ( aa(rat,$o,aa(rat,fun(rat,$o),ord_less_eq(rat),aa(int,rat,ring_1_of_int(rat),aa(int,int,aa(int,fun(int,int),divide_divide(int),A3),B2))),aa(int,rat,aa(int,fun(int,rat),fract,A3),B2))
      & aa(rat,$o,aa(rat,fun(rat,$o),ord_less(rat),aa(int,rat,aa(int,fun(int,rat),fract,A3),B2)),aa(int,rat,ring_1_of_int(rat),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),divide_divide(int),A3),B2)),one_one(int)))) ) ).

% rat_floor_lemma
tff(fact_3137_num__of__integer_Otransfer,axiom,
    aa(fun(code_integer,num),$o,aa(fun(int,num),fun(fun(code_integer,num),$o),bNF_rel_fun(int,code_integer,num,num,code_pcr_integer,fequal(num)),aa(fun(int,nat),fun(int,num),aa(fun(nat,num),fun(fun(int,nat),fun(int,num)),comp(nat,num,int),num_of_nat),nat2)),code_num_of_integer) ).

% num_of_integer.transfer
tff(fact_3138_prod__decode__triangle__add,axiom,
    ! [K: nat,M: nat] : nat_prod_decode(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_triangle(K)),M)) = nat_prod_decode_aux(K,M) ).

% prod_decode_triangle_add
tff(fact_3139_wf__insert,axiom,
    ! [B: $tType,Y: B,X2: B,R: set(product_prod(B,B))] :
      ( wf(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2)),R))
    <=> ( wf(B,R)
        & ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R)) ) ) ).

% wf_insert
tff(fact_3140_add__rat,axiom,
    ! [B2: int,D3: int,A3: int,C2: int] :
      ( ( B2 != zero_zero(int) )
     => ( ( D3 != zero_zero(int) )
       => ( aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),aa(int,rat,aa(int,fun(int,rat),fract,A3),B2)),aa(int,rat,aa(int,fun(int,rat),fract,C2),D3)) = aa(int,rat,aa(int,fun(int,rat),fract,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),A3),D3)),aa(int,int,aa(int,fun(int,int),times_times(int),C2),B2))),aa(int,int,aa(int,fun(int,int),times_times(int),B2),D3)) ) ) ) ).

% add_rat
tff(fact_3141_r__le__rtrancl,axiom,
    ! [B: $tType,S2: set(product_prod(B,B))] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),S2),transitive_rtrancl(B,S2)) ).

% r_le_rtrancl
tff(fact_3142_rtrancl__mono__mp,axiom,
    ! [B: $tType,U3: set(product_prod(B,B)),V5: set(product_prod(B,B)),X2: product_prod(B,B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),U3),V5)
     => ( member(product_prod(B,B),X2,transitive_rtrancl(B,U3))
       => member(product_prod(B,B),X2,transitive_rtrancl(B,V5)) ) ) ).

% rtrancl_mono_mp
tff(fact_3143_rtrancl__mono__rightI,axiom,
    ! [B: $tType,S2: set(product_prod(B,B)),S5: set(product_prod(B,B))] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),S2),S5)
     => aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),S2),transitive_rtrancl(B,S5)) ) ).

% rtrancl_mono_rightI
tff(fact_3144_converse__rtranclE_H,axiom,
    ! [B: $tType,U: B,V: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_rtrancl(B,R4))
     => ( ( U != V )
       => ~ ! [Vh: B] :
              ( ( U != Vh )
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),Vh),R4)
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Vh),V),transitive_rtrancl(B,R4)) ) ) ) ) ).

% converse_rtranclE'
tff(fact_3145_rtrancl_Ocases,axiom,
    ! [B: $tType,A1: B,A22: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),A22),transitive_rtrancl(B,R))
     => ( ( A22 != A1 )
       => ~ ! [B3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),B3),transitive_rtrancl(B,R))
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A22),R) ) ) ) ).

% rtrancl.cases
tff(fact_3146_rtrancl_Osimps,axiom,
    ! [B: $tType,A1: B,A22: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),A22),transitive_rtrancl(B,R))
    <=> ( ? [A7: B] :
            ( ( A1 = A7 )
            & ( A22 = A7 ) )
        | ? [A7: B,B7: B,C4: B] :
            ( ( A1 = A7 )
            & ( A22 = C4 )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),B7),transitive_rtrancl(B,R))
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B7),C4),R) ) ) ) ).

% rtrancl.simps
tff(fact_3147_rtrancl_Ortrancl__refl,axiom,
    ! [B: $tType,A3: B,R: set(product_prod(B,B))] : member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3),transitive_rtrancl(B,R)) ).

% rtrancl.rtrancl_refl
tff(fact_3148_rtrancl_Ortrancl__into__rtrancl,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),R)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_rtrancl(B,R)) ) ) ).

% rtrancl.rtrancl_into_rtrancl
tff(fact_3149_rtranclE,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R))
     => ( ( A3 != B2 )
       => ~ ! [Y4: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),Y4),transitive_rtrancl(B,R))
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),B2),R) ) ) ) ).

% rtranclE
tff(fact_3150_rtrancl__trans,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),Z2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),transitive_rtrancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),transitive_rtrancl(B,R)) ) ) ).

% rtrancl_trans
tff(fact_3151_rtrancl__induct,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),P: fun(B,$o)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R))
     => ( aa(B,$o,P,A3)
       => ( ! [Y4: B,Z3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),Y4),transitive_rtrancl(B,R))
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
               => ( aa(B,$o,P,Y4)
                 => aa(B,$o,P,Z3) ) ) )
         => aa(B,$o,P,B2) ) ) ) ).

% rtrancl_induct
tff(fact_3152_converse__rtranclE,axiom,
    ! [B: $tType,X2: B,Z2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),transitive_rtrancl(B,R))
     => ( ( X2 != Z2 )
       => ~ ! [Y4: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),R)
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),transitive_rtrancl(B,R)) ) ) ) ).

% converse_rtranclE
tff(fact_3153_converse__rtrancl__induct,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),P: fun(B,$o)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R))
     => ( aa(B,$o,P,B2)
       => ( ! [Y4: B,Z3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z3),B2),transitive_rtrancl(B,R))
               => ( aa(B,$o,P,Z3)
                 => aa(B,$o,P,Y4) ) ) )
         => aa(B,$o,P,A3) ) ) ) ).

% converse_rtrancl_induct
tff(fact_3154_converse__rtrancl__into__rtrancl,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),transitive_rtrancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_rtrancl(B,R)) ) ) ).

% converse_rtrancl_into_rtrancl
tff(fact_3155_in__rtrancl__insert,axiom,
    ! [B: $tType,X2: product_prod(B,B),R4: set(product_prod(B,B)),R: product_prod(B,B)] :
      ( member(product_prod(B,B),X2,transitive_rtrancl(B,R4))
     => member(product_prod(B,B),X2,transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),R),R4))) ) ).

% in_rtrancl_insert
tff(fact_3156_integer_Orep__transfer,axiom,
    aa(fun(code_integer,int),$o,aa(fun(int,int),fun(fun(code_integer,int),$o),bNF_rel_fun(int,code_integer,int,int,code_pcr_integer,fequal(int)),aTP_Lamp_cm(int,int)),code_int_of_integer) ).

% integer.rep_transfer
tff(fact_3157_integer_Oid__abs__transfer,axiom,
    aa(fun(int,code_integer),$o,aa(fun(int,int),fun(fun(int,code_integer),$o),bNF_rel_fun(int,int,int,code_integer,fequal(int),code_pcr_integer),aTP_Lamp_cm(int,int)),code_integer_of_int) ).

% integer.id_abs_transfer
tff(fact_3158_rtrancl__Un__separator__converseE,axiom,
    ! [B: $tType,A3: B,B2: B,P: set(product_prod(B,B)),Q: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),P),Q)))
     => ( ! [X3: B,Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),B2),transitive_rtrancl(B,P))
           => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),X3),Q)
             => ( Y4 = X3 ) ) )
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,P)) ) ) ).

% rtrancl_Un_separator_converseE
tff(fact_3159_rtrancl__Un__separatorE,axiom,
    ! [B: $tType,A3: B,B2: B,P: set(product_prod(B,B)),Q: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),P),Q)))
     => ( ! [X3: B,Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),X3),transitive_rtrancl(B,P))
           => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),Q)
             => ( X3 = Y4 ) ) )
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,P)) ) ) ).

% rtrancl_Un_separatorE
tff(fact_3160_zero__integer_Otransfer,axiom,
    aa(code_integer,$o,aa(int,fun(code_integer,$o),code_pcr_integer,zero_zero(int)),zero_zero(code_integer)) ).

% zero_integer.transfer
tff(fact_3161_converse__rtrancl__induct2,axiom,
    ! [B: $tType,C: $tType,Ax: B,Ay: C,Bx: B,By: C,R: set(product_prod(product_prod(B,C),product_prod(B,C))),P: fun(B,fun(C,$o))] :
      ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By)),transitive_rtrancl(product_prod(B,C),R))
     => ( aa(C,$o,aa(B,fun(C,$o),P,Bx),By)
       => ( ! [A5: B,B3: C,Aa2: B,Ba: C] :
              ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba)),R)
             => ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By)),transitive_rtrancl(product_prod(B,C),R))
               => ( aa(C,$o,aa(B,fun(C,$o),P,Aa2),Ba)
                 => aa(C,$o,aa(B,fun(C,$o),P,A5),B3) ) ) )
         => aa(C,$o,aa(B,fun(C,$o),P,Ax),Ay) ) ) ) ).

% converse_rtrancl_induct2
tff(fact_3162_converse__rtranclE2,axiom,
    ! [C: $tType,B: $tType,Xa: B,Xb: C,Za2: B,Zb: C,R: set(product_prod(product_prod(B,C),product_prod(B,C)))] :
      ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa),Xb)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Za2),Zb)),transitive_rtrancl(product_prod(B,C),R))
     => ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa),Xb) != aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Za2),Zb) )
       => ~ ! [A5: B,B3: C] :
              ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa),Xb)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),R)
             => ~ member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Za2),Zb)),transitive_rtrancl(product_prod(B,C),R)) ) ) ) ).

% converse_rtranclE2
tff(fact_3163_rtrancl__induct2,axiom,
    ! [B: $tType,C: $tType,Ax: B,Ay: C,Bx: B,By: C,R: set(product_prod(product_prod(B,C),product_prod(B,C))),P: fun(B,fun(C,$o))] :
      ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By)),transitive_rtrancl(product_prod(B,C),R))
     => ( aa(C,$o,aa(B,fun(C,$o),P,Ax),Ay)
       => ( ! [A5: B,B3: C,Aa2: B,Ba: C] :
              ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),transitive_rtrancl(product_prod(B,C),R))
             => ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba)),R)
               => ( aa(C,$o,aa(B,fun(C,$o),P,A5),B3)
                 => aa(C,$o,aa(B,fun(C,$o),P,Aa2),Ba) ) ) )
         => aa(C,$o,aa(B,fun(C,$o),P,Bx),By) ) ) ) ).

% rtrancl_induct2
tff(fact_3164_rtrancl__sub__insert__rtrancl,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),X2: product_prod(B,B)] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),transitive_rtrancl(B,R4)),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),X2),R4))) ).

% rtrancl_sub_insert_rtrancl
tff(fact_3165_plus__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),plus_plus(int)),plus_plus(code_integer)) ).

% plus_integer.transfer
tff(fact_3166_quotient__of__eq,axiom,
    ! [A3: int,B2: int,P3: int,Q3: int] :
      ( ( quotient_of(aa(int,rat,aa(int,fun(int,rat),fract,A3),B2)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) )
     => ( aa(int,rat,aa(int,fun(int,rat),fract,P3),Q3) = aa(int,rat,aa(int,fun(int,rat),fract,A3),B2) ) ) ).

% quotient_of_eq
tff(fact_3167_less__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,$o)),$o,aa(fun(int,fun(int,$o)),fun(fun(code_integer,fun(code_integer,$o)),$o),bNF_rel_fun(int,code_integer,fun(int,$o),fun(code_integer,$o),code_pcr_integer,bNF_rel_fun(int,code_integer,$o,$o,code_pcr_integer,fequal($o))),ord_less(int)),ord_less(code_integer)) ).

% less_integer.transfer
tff(fact_3168_one__integer_Otransfer,axiom,
    aa(code_integer,$o,aa(int,fun(code_integer,$o),code_pcr_integer,one_one(int)),one_one(code_integer)) ).

% one_integer.transfer
tff(fact_3169_less__eq__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,$o)),$o,aa(fun(int,fun(int,$o)),fun(fun(code_integer,fun(code_integer,$o)),$o),bNF_rel_fun(int,code_integer,fun(int,$o),fun(code_integer,$o),code_pcr_integer,bNF_rel_fun(int,code_integer,$o,$o,code_pcr_integer,fequal($o))),ord_less_eq(int)),ord_less_eq(code_integer)) ).

% less_eq_integer.transfer
tff(fact_3170_uminus__integer_Otransfer,axiom,
    aa(fun(code_integer,code_integer),$o,aa(fun(int,int),fun(fun(code_integer,code_integer),$o),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer),uminus_uminus(int)),uminus_uminus(code_integer)) ).

% uminus_integer.transfer
tff(fact_3171_times__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),times_times(int)),times_times(code_integer)) ).

% times_integer.transfer
tff(fact_3172_minus__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),minus_minus(int)),minus_minus(code_integer)) ).

% minus_integer.transfer
tff(fact_3173_abs__integer_Otransfer,axiom,
    aa(fun(code_integer,code_integer),$o,aa(fun(int,int),fun(fun(code_integer,code_integer),$o),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer),abs_abs(int)),abs_abs(code_integer)) ).

% abs_integer.transfer
tff(fact_3174_nat__of__integer_Otransfer,axiom,
    aa(fun(code_integer,nat),$o,aa(fun(int,nat),fun(fun(code_integer,nat),$o),bNF_rel_fun(int,code_integer,nat,nat,code_pcr_integer,fequal(nat)),nat2),code_nat_of_integer) ).

% nat_of_integer.transfer
tff(fact_3175_normalize__eq,axiom,
    ! [A3: int,B2: int,P3: int,Q3: int] :
      ( ( normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),B2)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) )
     => ( aa(int,rat,aa(int,fun(int,rat),fract,P3),Q3) = aa(int,rat,aa(int,fun(int,rat),fract,A3),B2) ) ) ).

% normalize_eq
tff(fact_3176_integer__of__nat_Otransfer,axiom,
    aa(fun(nat,code_integer),$o,aa(fun(nat,int),fun(fun(nat,code_integer),$o),bNF_rel_fun(nat,nat,int,code_integer,fequal(nat),code_pcr_integer),semiring_1_of_nat(int)),code_integer_of_nat) ).

% integer_of_nat.transfer
tff(fact_3177_divide__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),divide_divide(int)),divide_divide(code_integer)) ).

% divide_integer.transfer
tff(fact_3178_modulo__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),modulo_modulo(int)),modulo_modulo(code_integer)) ).

% modulo_integer.transfer
tff(fact_3179_sgn__integer_Otransfer,axiom,
    aa(fun(code_integer,code_integer),$o,aa(fun(int,int),fun(fun(code_integer,code_integer),$o),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer),sgn_sgn(int)),sgn_sgn(code_integer)) ).

% sgn_integer.transfer
tff(fact_3180_dup_Otransfer,axiom,
    aa(fun(code_integer,code_integer),$o,aa(fun(int,int),fun(fun(code_integer,code_integer),$o),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer),aTP_Lamp_hf(int,int)),code_dup) ).

% dup.transfer
tff(fact_3181_take__bit__integer_Otransfer,axiom,
    aa(fun(nat,fun(code_integer,code_integer)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(code_integer,code_integer)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),fequal(nat),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se2584673776208193580ke_bit(int)),bit_se2584673776208193580ke_bit(code_integer)) ).

% take_bit_integer.transfer
tff(fact_3182_not__integer_Otransfer,axiom,
    aa(fun(code_integer,code_integer),$o,aa(fun(int,int),fun(fun(code_integer,code_integer),$o),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer),bit_ri4277139882892585799ns_not(int)),bit_ri4277139882892585799ns_not(code_integer)) ).

% not_integer.transfer
tff(fact_3183_and__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se5824344872417868541ns_and(int)),bit_se5824344872417868541ns_and(code_integer)) ).

% and_integer.transfer
tff(fact_3184_bit__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(nat,$o)),$o,aa(fun(int,fun(nat,$o)),fun(fun(code_integer,fun(nat,$o)),$o),bNF_rel_fun(int,code_integer,fun(nat,$o),fun(nat,$o),code_pcr_integer,fequal(fun(nat,$o))),bit_se5641148757651400278ts_bit(int)),bit_se5641148757651400278ts_bit(code_integer)) ).

% bit_integer.transfer
tff(fact_3185_or__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se1065995026697491101ons_or(int)),bit_se1065995026697491101ons_or(code_integer)) ).

% or_integer.transfer
tff(fact_3186_xor__integer_Otransfer,axiom,
    aa(fun(code_integer,fun(code_integer,code_integer)),$o,aa(fun(int,fun(int,int)),fun(fun(code_integer,fun(code_integer,code_integer)),$o),bNF_rel_fun(int,code_integer,fun(int,int),fun(code_integer,code_integer),code_pcr_integer,bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se5824344971392196577ns_xor(int)),bit_se5824344971392196577ns_xor(code_integer)) ).

% xor_integer.transfer
tff(fact_3187_drop__bit__integer_Otransfer,axiom,
    aa(fun(nat,fun(code_integer,code_integer)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(code_integer,code_integer)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),fequal(nat),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se4197421643247451524op_bit(int)),bit_se4197421643247451524op_bit(code_integer)) ).

% drop_bit_integer.transfer
tff(fact_3188_push__bit__integer_Otransfer,axiom,
    aa(fun(nat,fun(code_integer,code_integer)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(code_integer,code_integer)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),fequal(nat),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se4730199178511100633sh_bit(int)),bit_se4730199178511100633sh_bit(code_integer)) ).

% push_bit_integer.transfer
tff(fact_3189_mask__integer_Otransfer,axiom,
    aa(fun(nat,code_integer),$o,aa(fun(nat,int),fun(fun(nat,code_integer),$o),bNF_rel_fun(nat,nat,int,code_integer,fequal(nat),code_pcr_integer),bit_se2239418461657761734s_mask(int)),bit_se2239418461657761734s_mask(code_integer)) ).

% mask_integer.transfer
tff(fact_3190_unset__bit__integer_Otransfer,axiom,
    aa(fun(nat,fun(code_integer,code_integer)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(code_integer,code_integer)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),fequal(nat),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se2638667681897837118et_bit(int)),bit_se2638667681897837118et_bit(code_integer)) ).

% unset_bit_integer.transfer
tff(fact_3191_set__bit__integer_Otransfer,axiom,
    aa(fun(nat,fun(code_integer,code_integer)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(code_integer,code_integer)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),fequal(nat),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se5668285175392031749et_bit(int)),bit_se5668285175392031749et_bit(code_integer)) ).

% set_bit_integer.transfer
tff(fact_3192_division__segment__integer_Otransfer,axiom,
    aa(fun(code_integer,code_integer),$o,aa(fun(int,int),fun(fun(code_integer,code_integer),$o),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer),euclid7384307370059645450egment(int)),euclid7384307370059645450egment(code_integer)) ).

% division_segment_integer.transfer
tff(fact_3193_flip__bit__integer_Otransfer,axiom,
    aa(fun(nat,fun(code_integer,code_integer)),$o,aa(fun(nat,fun(int,int)),fun(fun(nat,fun(code_integer,code_integer)),$o),bNF_rel_fun(nat,nat,fun(int,int),fun(code_integer,code_integer),fequal(nat),bNF_rel_fun(int,code_integer,int,code_integer,code_pcr_integer,code_pcr_integer)),bit_se8732182000553998342ip_bit(int)),bit_se8732182000553998342ip_bit(code_integer)) ).

% flip_bit_integer.transfer
tff(fact_3194_euclidean__size__integer_Otransfer,axiom,
    aa(fun(code_integer,nat),$o,aa(fun(int,nat),fun(fun(code_integer,nat),$o),bNF_rel_fun(int,code_integer,nat,nat,code_pcr_integer,fequal(nat)),euclid6346220572633701492n_size(int)),euclid6346220572633701492n_size(code_integer)) ).

% euclidean_size_integer.transfer
tff(fact_3195_trancl__subset__Sigma__aux,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),A4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R))
     => ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))
       => ( ( A3 = B2 )
          | member(B,A3,A4) ) ) ) ).

% trancl_subset_Sigma_aux
tff(fact_3196_Restr__rtrancl__mono,axiom,
    ! [B: $tType,V: B,W: B,E4: set(product_prod(B,B)),U3: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),E4),product_Sigma(B,B,U3,aTP_Lamp_ma(set(B),fun(B,set(B)),U3)))))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_rtrancl(B,E4)) ) ).

% Restr_rtrancl_mono
tff(fact_3197_quotient__of__Fract,axiom,
    ! [A3: int,B2: int] : quotient_of(aa(int,rat,aa(int,fun(int,rat),fract,A3),B2)) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),A3),B2)) ).

% quotient_of_Fract
tff(fact_3198_sub_Otransfer,axiom,
    aa(fun(num,fun(num,code_integer)),$o,aa(fun(num,fun(num,int)),fun(fun(num,fun(num,code_integer)),$o),bNF_rel_fun(num,num,fun(num,int),fun(num,code_integer),fequal(num),bNF_rel_fun(num,num,int,code_integer,fequal(num),code_pcr_integer)),aTP_Lamp_hm(num,fun(num,int))),code_sub) ).

% sub.transfer
tff(fact_3199_rtrancl__mapI,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: B,E4: set(product_prod(B,B)),F: fun(B,C)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,E4))
     => member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,F,A3)),aa(B,C,F,B2)),transitive_rtrancl(C,aa(set(product_prod(B,B)),set(product_prod(C,C)),image2(product_prod(B,B),product_prod(C,C),pairself(B,C,F)),E4))) ) ).

% rtrancl_mapI
tff(fact_3200_Fract_Oabs__eq,axiom,
    ! [Xa: int,X2: int] :
      aa(int,rat,aa(int,fun(int,rat),fract,Xa),X2) = aa(product_prod(int,int),rat,abs_Rat,
        $ite(X2 = zero_zero(int),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Xa),X2))) ).

% Fract.abs_eq
tff(fact_3201_rtrancl__last__touch,axiom,
    ! [B: $tType,Q3: B,Q4: B,R4: set(product_prod(B,B)),S2: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Q4),transitive_rtrancl(B,R4))
     => ( member(B,Q3,S2)
       => ~ ! [Qt: B] :
              ( member(B,Qt,S2)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Qt),transitive_rtrancl(B,R4))
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Qt),Q4),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_ma(set(B),fun(B,set(B)),S2))))) ) ) ) ) ).

% rtrancl_last_touch
tff(fact_3202_rtrancl__last__visit_H,axiom,
    ! [B: $tType,Q3: B,Q4: B,R4: set(product_prod(B,B)),S2: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Q4),transitive_rtrancl(B,R4))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Q4),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_ma(set(B),fun(B,set(B)),S2)))))
       => ~ ! [Qt: B] :
              ( member(B,Qt,S2)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Qt),transitive_rtrancl(B,R4))
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Qt),Q4),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_ma(set(B),fun(B,set(B)),S2))))) ) ) ) ) ).

% rtrancl_last_visit'
tff(fact_3203_rtrancl__insert,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] : transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2)),R)) = aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),transitive_rtrancl(B,R)),aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aa(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o))),aTP_Lamp_nc(B,fun(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o)))),A3),B2),R)))) ).

% rtrancl_insert
tff(fact_3204_Fract_Otransfer,axiom,
    aa(fun(int,fun(int,rat)),$o,aa(fun(int,fun(int,product_prod(int,int))),fun(fun(int,fun(int,rat)),$o),bNF_rel_fun(int,int,fun(int,product_prod(int,int)),fun(int,rat),fequal(int),bNF_rel_fun(int,int,product_prod(int,int),rat,fequal(int),pcr_rat)),aTP_Lamp_kx(int,fun(int,product_prod(int,int)))),fract) ).

% Fract.transfer
tff(fact_3205_Fract__add__one,axiom,
    ! [N: int,M: int] :
      ( ( N != zero_zero(int) )
     => ( aa(int,rat,aa(int,fun(int,rat),fract,aa(int,int,aa(int,fun(int,int),plus_plus(int),M),N)),N) = aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),aa(int,rat,aa(int,fun(int,rat),fract,M),N)),one_one(rat)) ) ) ).

% Fract_add_one
tff(fact_3206_Fract__def,axiom,
    fract = aa(fun(int,fun(int,product_prod(int,int))),fun(int,fun(int,rat)),map_fun(int,int,fun(int,product_prod(int,int)),fun(int,rat),id(int),map_fun(int,int,product_prod(int,int),rat,id(int),abs_Rat)),aTP_Lamp_kx(int,fun(int,product_prod(int,int)))) ).

% Fract_def
tff(fact_3207_old_Orec__unit__def,axiom,
    ! [B: $tType,X: B,Xa3: product_unit] : product_rec_unit(B,X,Xa3) = the(B,product_rec_set_unit(B,X,Xa3)) ).

% old.rec_unit_def
tff(fact_3208_old_Orec__prod__def,axiom,
    ! [D: $tType,C: $tType,B: $tType,X: fun(B,fun(C,D)),Xa3: product_prod(B,C)] : product_rec_prod(B,C,D,X,Xa3) = the(D,product_rec_set_prod(B,C,D,X,Xa3)) ).

% old.rec_prod_def
tff(fact_3209_list__decode_Opinduct,axiom,
    ! [A0: nat,P: fun(nat,$o)] :
      ( aa(nat,$o,accp(nat,nat_list_decode_rel),A0)
     => ( ( aa(nat,$o,accp(nat,nat_list_decode_rel),zero_zero(nat))
         => aa(nat,$o,P,zero_zero(nat)) )
       => ( ! [N3: nat] :
              ( aa(nat,$o,accp(nat,nat_list_decode_rel),aa(nat,nat,suc,N3))
             => ( ! [X: nat,Y5: nat] :
                    ( ( aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X),Y5) = nat_prod_decode(N3) )
                   => aa(nat,$o,P,Y5) )
               => aa(nat,$o,P,aa(nat,nat,suc,N3)) ) )
         => aa(nat,$o,P,A0) ) ) ) ).

% list_decode.pinduct
tff(fact_3210_rtrancl__restrictI,axiom,
    ! [B: $tType,U: B,V: B,E4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),E4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_ma(set(B),fun(B,set(B)),R4)))))
     => ( ~ member(B,U,R4)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_rtrancl(B,rel_restrict(B,E4,R4))) ) ) ).

% rtrancl_restrictI
tff(fact_3211_inj__on__vimage__singleton,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),A3: C] :
      ( inj_on(B,C,F,A4)
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),inf_inf(set(B),aa(set(C),set(B),vimage(B,C,F),aa(set(C),set(C),insert2(C,A3),bot_bot(set(C))))),A4)),aa(set(B),set(B),insert2(B,the(B,aa(C,fun(B,$o),aa(set(B),fun(C,fun(B,$o)),aTP_Lamp_nd(fun(B,C),fun(set(B),fun(C,fun(B,$o))),F),A4),A3))),bot_bot(set(B)))) ) ).

% inj_on_vimage_singleton
tff(fact_3212_inj__on__empty,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] : inj_on(B,C,F,bot_bot(set(B))) ).

% inj_on_empty
tff(fact_3213_inj__uminus,axiom,
    ! [B: $tType] :
      ( ordered_ab_group_add(B)
     => ! [A4: set(B)] : inj_on(B,B,uminus_uminus(B),A4) ) ).

% inj_uminus
tff(fact_3214_rel__restrict__empty,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : rel_restrict(B,R4,bot_bot(set(B))) = R4 ).

% rel_restrict_empty
tff(fact_3215_The__split__eq,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: C] : the(product_prod(B,C),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(C,fun(B,fun(C,$o)),aTP_Lamp_ne(B,fun(C,fun(B,fun(C,$o))),X2),Y))) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y) ).

% The_split_eq
tff(fact_3216_inj__apfst,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,D)] :
      ( inj_on(product_prod(B,C),product_prod(D,C),product_apfst(B,D,C,F),top_top(set(product_prod(B,C))))
    <=> inj_on(B,D,F,top_top(set(B))) ) ).

% inj_apfst
tff(fact_3217_inj__apsnd,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,D)] :
      ( inj_on(product_prod(B,C),product_prod(B,D),aa(fun(C,D),fun(product_prod(B,C),product_prod(B,D)),product_apsnd(C,D,B),F),top_top(set(product_prod(B,C))))
    <=> inj_on(C,D,F,top_top(set(C))) ) ).

% inj_apsnd
tff(fact_3218_inj__on__apfst,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,D),A4: set(B)] :
      ( inj_on(product_prod(B,C),product_prod(D,C),product_apfst(B,D,C,F),product_Sigma(B,C,A4,aTP_Lamp_jn(B,set(C))))
    <=> inj_on(B,D,F,A4) ) ).

% inj_on_apfst
tff(fact_3219_inj__on__apsnd,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,D),A4: set(C)] :
      ( inj_on(product_prod(B,C),product_prod(B,D),aa(fun(C,D),fun(product_prod(B,C),product_prod(B,D)),product_apsnd(C,D,B),F),product_Sigma(B,C,top_top(set(B)),aTP_Lamp_jm(set(C),fun(B,set(C)),A4)))
    <=> inj_on(C,D,F,A4) ) ).

% inj_on_apsnd
tff(fact_3220_inj__on__insert,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A3: B,A4: set(B)] :
      ( inj_on(B,C,F,aa(set(B),set(B),insert2(B,A3),A4))
    <=> ( inj_on(B,C,F,A4)
        & ~ member(C,aa(B,C,F,A3),aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))))) ) ) ).

% inj_on_insert
tff(fact_3221_inj__on__Int,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( ( inj_on(B,C,F,A4)
        | inj_on(B,C,F,B5) )
     => inj_on(B,C,F,aa(set(B),set(B),inf_inf(set(B),A4),B5)) ) ).

% inj_on_Int
tff(fact_3222_fun_Oinj__map,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => inj_on(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),F),top_top(set(fun(D,B)))) ) ).

% fun.inj_map
tff(fact_3223_inj__on__imageI2,axiom,
    ! [C: $tType,D: $tType,B: $tType,F2: fun(D,C),F: fun(B,D),A4: set(B)] :
      ( inj_on(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F2),F),A4)
     => inj_on(B,D,F,A4) ) ).

% inj_on_imageI2
tff(fact_3224_inj__on__of__nat,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N5: set(nat)] : inj_on(nat,B,semiring_1_of_nat(B),N5) ) ).

% inj_on_of_nat
tff(fact_3225_inj__on__add,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [A3: B,A4: set(B)] : inj_on(B,B,aa(B,fun(B,B),plus_plus(B),A3),A4) ) ).

% inj_on_add
tff(fact_3226_inj__on__image__iff,axiom,
    ! [C: $tType,B: $tType,A4: set(B),G: fun(B,C),F: fun(B,B)] :
      ( ! [X3: B] :
          ( member(B,X3,A4)
         => ! [Xa4: B] :
              ( member(B,Xa4,A4)
             => ( ( aa(B,C,G,aa(B,B,F,X3)) = aa(B,C,G,aa(B,B,F,Xa4)) )
              <=> ( aa(B,C,G,X3) = aa(B,C,G,Xa4) ) ) ) )
     => ( inj_on(B,B,F,A4)
       => ( inj_on(B,C,G,aa(set(B),set(B),image2(B,B,F),A4))
        <=> inj_on(B,C,G,A4) ) ) ) ).

% inj_on_image_iff
tff(fact_3227_inj__on__id2,axiom,
    ! [B: $tType,A4: set(B)] : inj_on(B,B,aTP_Lamp_ay(B,B),A4) ).

% inj_on_id2
tff(fact_3228_inj__on__inverseI,axiom,
    ! [C: $tType,B: $tType,A4: set(B),G: fun(C,B),F: fun(B,C)] :
      ( ! [X3: B] :
          ( member(B,X3,A4)
         => ( aa(C,B,G,aa(B,C,F,X3)) = X3 ) )
     => inj_on(B,C,F,A4) ) ).

% inj_on_inverseI
tff(fact_3229_inj__on__contraD,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: B,Y: B] :
      ( inj_on(B,C,F,A4)
     => ( ( X2 != Y )
       => ( member(B,X2,A4)
         => ( member(B,Y,A4)
           => ( aa(B,C,F,X2) != aa(B,C,F,Y) ) ) ) ) ) ).

% inj_on_contraD
tff(fact_3230_inj__on__eq__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: B,Y: B] :
      ( inj_on(B,C,F,A4)
     => ( member(B,X2,A4)
       => ( member(B,Y,A4)
         => ( ( aa(B,C,F,X2) = aa(B,C,F,Y) )
          <=> ( X2 = Y ) ) ) ) ) ).

% inj_on_eq_iff
tff(fact_3231_inj__on__cong,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,C),G: fun(B,C)] :
      ( ! [A5: B] :
          ( member(B,A5,A4)
         => ( aa(B,C,F,A5) = aa(B,C,G,A5) ) )
     => ( inj_on(B,C,F,A4)
      <=> inj_on(B,C,G,A4) ) ) ).

% inj_on_cong
tff(fact_3232_inj__on__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,A4)
    <=> ! [X4: B] :
          ( member(B,X4,A4)
         => ! [Xa2: B] :
              ( member(B,Xa2,A4)
             => ( ( aa(B,C,F,X4) = aa(B,C,F,Xa2) )
               => ( X4 = Xa2 ) ) ) ) ) ).

% inj_on_def
tff(fact_3233_inj__onI,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,C)] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,A4)
         => ( member(B,Y4,A4)
           => ( ( aa(B,C,F,X3) = aa(B,C,F,Y4) )
             => ( X3 = Y4 ) ) ) )
     => inj_on(B,C,F,A4) ) ).

% inj_onI
tff(fact_3234_inj__onD,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: B,Y: B] :
      ( inj_on(B,C,F,A4)
     => ( ( aa(B,C,F,X2) = aa(B,C,F,Y) )
       => ( member(B,X2,A4)
         => ( member(B,Y,A4)
           => ( X2 = Y ) ) ) ) ) ).

% inj_onD
tff(fact_3235_inj__on__diff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,A4)
     => inj_on(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5)) ) ).

% inj_on_diff
tff(fact_3236_inj__on__id,axiom,
    ! [B: $tType,A4: set(B)] : inj_on(B,B,id(B),A4) ).

% inj_on_id
tff(fact_3237_inj__Some,axiom,
    ! [B: $tType,A4: set(B)] : inj_on(B,option(B),some(B),A4) ).

% inj_Some
tff(fact_3238_inj__on__subset,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,A4)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),A4)
       => inj_on(B,C,F,B5) ) ) ).

% inj_on_subset
tff(fact_3239_subset__inj__on,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),B5: set(B),A4: set(B)] :
      ( inj_on(B,C,F,B5)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
       => inj_on(B,C,F,A4) ) ) ).

% subset_inj_on
tff(fact_3240_inj__fun,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => inj_on(B,fun(D,C),aTP_Lamp_nf(fun(B,C),fun(B,fun(D,C)),F),top_top(set(B))) ) ).

% inj_fun
tff(fact_3241_inj__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
    <=> ! [X4: B,Y3: B] :
          ( ( aa(B,C,F,X4) = aa(B,C,F,Y3) )
         => ( X4 = Y3 ) ) ) ).

% inj_def
tff(fact_3242_inj__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),X2: B,Y: B] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( ( aa(B,C,F,X2) = aa(B,C,F,Y) )
      <=> ( X2 = Y ) ) ) ).

% inj_eq
tff(fact_3243_injI,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( ! [X3: B,Y4: B] :
          ( ( aa(B,C,F,X3) = aa(B,C,F,Y4) )
         => ( X3 = Y4 ) )
     => inj_on(B,C,F,top_top(set(B))) ) ).

% injI
tff(fact_3244_injD,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),X2: B,Y: B] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( ( aa(B,C,F,X2) = aa(B,C,F,Y) )
       => ( X2 = Y ) ) ) ).

% injD
tff(fact_3245_inj__swap,axiom,
    ! [C: $tType,B: $tType,A4: set(product_prod(B,C))] : inj_on(product_prod(B,C),product_prod(C,B),product_swap(B,C),A4) ).

% inj_swap
tff(fact_3246_inj__on__convol__ident,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),X7: set(B)] : inj_on(B,product_prod(B,C),aTP_Lamp_ng(fun(B,C),fun(B,product_prod(B,C)),F),X7) ).

% inj_on_convol_ident
tff(fact_3247_inj__Pair_I1_J,axiom,
    ! [C: $tType,B: $tType,C2: fun(B,C),S2: set(B)] : inj_on(B,product_prod(B,C),aTP_Lamp_ng(fun(B,C),fun(B,product_prod(B,C)),C2),S2) ).

% inj_Pair(1)
tff(fact_3248_inj__Pair_I2_J,axiom,
    ! [C: $tType,B: $tType,C2: fun(B,C),S2: set(B)] : inj_on(B,product_prod(C,B),aTP_Lamp_nh(fun(B,C),fun(B,product_prod(C,B)),C2),S2) ).

% inj_Pair(2)
tff(fact_3249_inj__on__add_H,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [A3: B,A4: set(B)] : inj_on(B,B,aTP_Lamp_ni(B,fun(B,B),A3),A4) ) ).

% inj_on_add'
tff(fact_3250_rel__restrict__lift,axiom,
    ! [B: $tType,X2: B,Y: B,E4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),rel_restrict(B,E4,R4))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),E4) ) ).

% rel_restrict_lift
tff(fact_3251_rel__restrictI,axiom,
    ! [B: $tType,X2: B,R4: set(B),Y: B,E4: set(product_prod(B,B))] :
      ( ~ member(B,X2,R4)
     => ( ~ member(B,Y,R4)
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),E4)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),rel_restrict(B,E4,R4)) ) ) ) ).

% rel_restrictI
tff(fact_3252_rel__restrict__notR_I1_J,axiom,
    ! [B: $tType,X2: B,Y: B,A4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),rel_restrict(B,A4,R4))
     => ~ member(B,X2,R4) ) ).

% rel_restrict_notR(1)
tff(fact_3253_rel__restrict__notR_I2_J,axiom,
    ! [B: $tType,X2: B,Y: B,A4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),rel_restrict(B,A4,R4))
     => ~ member(B,Y,R4) ) ).

% rel_restrict_notR(2)
tff(fact_3254_rel__restrict__union,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B),B5: set(B)] : rel_restrict(B,R4,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = rel_restrict(B,rel_restrict(B,R4,A4),B5) ).

% rel_restrict_union
tff(fact_3255_rel__restrict__sub,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),rel_restrict(B,R4,A4)),R4) ).

% rel_restrict_sub
tff(fact_3256_rel__restrict__mono,axiom,
    ! [B: $tType,A4: set(product_prod(B,B)),B5: set(product_prod(B,B)),R4: set(B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),A4),B5)
     => aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),rel_restrict(B,A4,R4)),rel_restrict(B,B5,R4)) ) ).

% rel_restrict_mono
tff(fact_3257_finite__rel__restrict,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] :
      ( finite_finite2(product_prod(B,B),R4)
     => finite_finite2(product_prod(B,B),rel_restrict(B,R4,A4)) ) ).

% finite_rel_restrict
tff(fact_3258_option_Oinj__map,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => inj_on(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),top_top(set(option(B)))) ) ).

% option.inj_map
tff(fact_3259_linorder__inj__onI,axiom,
    ! [C: $tType,B: $tType] :
      ( order(B)
     => ! [A4: set(B),F: fun(B,C)] :
          ( ! [X3: B,Y4: B] :
              ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X3),Y4)
             => ( member(B,X3,A4)
               => ( member(B,Y4,A4)
                 => ( aa(B,C,F,X3) != aa(B,C,F,Y4) ) ) ) )
         => ( ! [X3: B,Y4: B] :
                ( member(B,X3,A4)
               => ( member(B,Y4,A4)
                 => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X3),Y4)
                    | aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Y4),X3) ) ) )
           => inj_on(B,C,F,A4) ) ) ) ).

% linorder_inj_onI
tff(fact_3260_linorder__injI,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [F: fun(B,C)] :
          ( ! [X3: B,Y4: B] :
              ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X3),Y4)
             => ( aa(B,C,F,X3) != aa(B,C,F,Y4) ) )
         => inj_on(B,C,F,top_top(set(B))) ) ) ).

% linorder_injI
tff(fact_3261_inj__add__left,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [A3: B] : inj_on(B,B,aa(B,fun(B,B),plus_plus(B),A3),top_top(set(B))) ) ).

% inj_add_left
tff(fact_3262_inj__on__image__eq__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),C5: set(B),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,C5)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),C5)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),C5)
         => ( ( aa(set(B),set(C),image2(B,C,F),A4) = aa(set(B),set(C),image2(B,C,F),B5) )
          <=> ( A4 = B5 ) ) ) ) ) ).

% inj_on_image_eq_iff
tff(fact_3263_inj__on__image__mem__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),B5: set(B),A3: B,A4: set(B)] :
      ( inj_on(B,C,F,B5)
     => ( member(B,A3,B5)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
         => ( member(C,aa(B,C,F,A3),aa(set(B),set(C),image2(B,C,F),A4))
          <=> member(B,A3,A4) ) ) ) ) ).

% inj_on_image_mem_iff
tff(fact_3264_inj__img__insertE,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: C,B5: set(C)] :
      ( inj_on(B,C,F,A4)
     => ( ~ member(C,X2,B5)
       => ( ( aa(set(C),set(C),insert2(C,X2),B5) = aa(set(B),set(C),image2(B,C,F),A4) )
         => ~ ! [X5: B,A9: set(B)] :
                ( ~ member(B,X5,A9)
               => ( ( A4 = aa(set(B),set(B),insert2(B,X5),A9) )
                 => ( ( X2 = aa(B,C,F,X5) )
                   => ( B5 != aa(set(B),set(C),image2(B,C,F),A9) ) ) ) ) ) ) ) ).

% inj_img_insertE
tff(fact_3265_range__ex1__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),B2: C] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( member(C,B2,aa(set(B),set(C),image2(B,C,F),top_top(set(B))))
      <=> ? [X4: B] :
            ( ( B2 = aa(B,C,F,X4) )
            & ! [Y3: B] :
                ( ( B2 = aa(B,C,F,Y3) )
               => ( Y3 = X4 ) ) ) ) ) ).

% range_ex1_eq
tff(fact_3266_inj__image__eq__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( ( aa(set(B),set(C),image2(B,C,F),A4) = aa(set(B),set(C),image2(B,C,F),B5) )
      <=> ( A4 = B5 ) ) ) ).

% inj_image_eq_iff
tff(fact_3267_inj__image__mem__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A3: B,A4: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( member(C,aa(B,C,F,A3),aa(set(B),set(C),image2(B,C,F),A4))
      <=> member(B,A3,A4) ) ) ).

% inj_image_mem_iff
tff(fact_3268_comp__inj__on,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,C),A4: set(B),G: fun(C,D)] :
      ( inj_on(B,C,F,A4)
     => ( inj_on(C,D,G,aa(set(B),set(C),image2(B,C,F),A4))
       => inj_on(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),F),A4) ) ) ).

% comp_inj_on
tff(fact_3269_inj__on__imageI,axiom,
    ! [C: $tType,D: $tType,B: $tType,G: fun(D,C),F: fun(B,D),A4: set(B)] :
      ( inj_on(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),G),F),A4)
     => inj_on(D,C,G,aa(set(B),set(D),image2(B,D,F),A4)) ) ).

% inj_on_imageI
tff(fact_3270_comp__inj__on__iff,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,C),A4: set(B),F2: fun(C,D)] :
      ( inj_on(B,C,F,A4)
     => ( inj_on(C,D,F2,aa(set(B),set(C),image2(B,C,F),A4))
      <=> inj_on(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F),A4) ) ) ).

% comp_inj_on_iff
tff(fact_3271_inj__on__Un__image__eq__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))
     => ( ( aa(set(B),set(C),image2(B,C,F),A4) = aa(set(B),set(C),image2(B,C,F),B5) )
      <=> ( A4 = B5 ) ) ) ).

% inj_on_Un_image_eq_iff
tff(fact_3272_inj__compose,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),G: fun(D,B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( inj_on(D,B,G,top_top(set(D)))
       => inj_on(D,C,aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),F),G),top_top(set(D))) ) ) ).

% inj_compose
tff(fact_3273_inj__on__strict__subset,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),B5: set(B),A4: set(B)] :
      ( inj_on(B,C,F,B5)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),A4),B5)
       => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,F),B5)) ) ) ).

% inj_on_strict_subset
tff(fact_3274_inj__on__fun__updI,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),Y: C,X2: B] :
      ( inj_on(B,C,F,A4)
     => ( ~ member(C,Y,aa(set(B),set(C),image2(B,C,F),A4))
       => inj_on(B,C,fun_upd(B,C,F,X2,Y),A4) ) ) ).

% inj_on_fun_updI
tff(fact_3275_inj__on__fst__map__to__set,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : inj_on(product_prod(B,C),B,product_fst(B,C),map_to_set(B,C,M)) ).

% inj_on_fst_map_to_set
tff(fact_3276_inj__diff__right,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [A3: B] : inj_on(B,B,aTP_Lamp_go(B,fun(B,B),A3),top_top(set(B))) ) ).

% inj_diff_right
tff(fact_3277_inj__singleton,axiom,
    ! [B: $tType,A4: set(B)] : inj_on(B,set(B),aTP_Lamp_nj(B,set(B)),A4) ).

% inj_singleton
tff(fact_3278_finite__Collect,axiom,
    ! [B: $tType,C: $tType,S2: set(B),F: fun(C,B)] :
      ( finite_finite2(B,S2)
     => ( inj_on(C,B,F,top_top(set(C)))
       => finite_finite2(C,aa(fun(C,$o),set(C),collect(C),aa(fun(C,B),fun(C,$o),aTP_Lamp_nk(set(B),fun(fun(C,B),fun(C,$o)),S2),F))) ) ) ).

% finite_Collect
tff(fact_3279_swap__inj__on,axiom,
    ! [C: $tType,B: $tType,A4: set(product_prod(B,C))] : inj_on(product_prod(B,C),product_prod(C,B),aa(fun(B,fun(C,product_prod(C,B))),fun(product_prod(B,C),product_prod(C,B)),product_case_prod(B,C,product_prod(C,B)),aTP_Lamp_it(B,fun(C,product_prod(C,B)))),A4) ).

% swap_inj_on
tff(fact_3280_rel__restrict__mono2,axiom,
    ! [B: $tType,R4: set(B),S2: set(B),A4: set(product_prod(B,B))] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),R4),S2)
     => aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),rel_restrict(B,A4,S2)),rel_restrict(B,A4,R4)) ) ).

% rel_restrict_mono2
tff(fact_3281_inj__image__subset__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,F),B5))
      <=> aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5) ) ) ).

% inj_image_subset_iff
tff(fact_3282_inj__on__image__Int,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),C5: set(B),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,C5)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),C5)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),C5)
         => ( aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),inf_inf(set(B),A4),B5)) = aa(set(C),set(C),inf_inf(set(C),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,F),B5)) ) ) ) ) ).

% inj_on_image_Int
tff(fact_3283_image__Int,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),inf_inf(set(B),A4),B5)) = aa(set(C),set(C),inf_inf(set(C),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,F),B5)) ) ) ).

% image_Int
tff(fact_3284_inj__on__image__set__diff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),C5: set(B),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,C5)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5)),C5)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),C5)
         => ( aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,F),B5)) ) ) ) ) ).

% inj_on_image_set_diff
tff(fact_3285_sum_Oreindex,axiom,
    ! [C: $tType,D: $tType,B: $tType] :
      ( comm_monoid_add(D)
     => ! [Ha: fun(B,C),A4: set(B),G: fun(C,D)] :
          ( inj_on(B,C,Ha,A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),G),aa(set(B),set(C),image2(B,C,Ha),A4)) = aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7311177749621191930dd_sum(B,D),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),Ha)),A4) ) ) ) ).

% sum.reindex
tff(fact_3286_image__set__diff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,F),B5)) ) ) ).

% image_set_diff
tff(fact_3287_prod_Oreindex,axiom,
    ! [C: $tType,D: $tType,B: $tType] :
      ( comm_monoid_mult(D)
     => ! [Ha: fun(B,C),A4: set(B),G: fun(C,D)] :
          ( inj_on(B,C,Ha,A4)
         => ( aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),aa(set(B),set(C),image2(B,C,Ha),A4)) = aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7121269368397514597t_prod(B,D),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),Ha)),A4) ) ) ) ).

% prod.reindex
tff(fact_3288_inj__vimage__image__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(set(C),set(B),vimage(B,C,F),aa(set(B),set(C),image2(B,C,F),A4)) = A4 ) ) ).

% inj_vimage_image_eq
tff(fact_3289_rel__restrict__def,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : rel_restrict(B,R4,A4) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(set(B),fun(B,fun(B,$o)),aTP_Lamp_nl(set(product_prod(B,B)),fun(set(B),fun(B,fun(B,$o))),R4),A4))) ).

% rel_restrict_def
tff(fact_3290_finite__imp__inj__to__nat__seg_H,axiom,
    ! [B: $tType,A4: set(B)] :
      ( finite_finite2(B,A4)
     => ~ ! [F3: fun(B,nat)] :
            ( ? [N3: nat] : aa(set(B),set(nat),image2(B,nat,F3),A4) = aa(fun(nat,$o),set(nat),collect(nat),aTP_Lamp_cw(nat,fun(nat,$o),N3))
           => ~ inj_on(B,nat,F3,A4) ) ) ).

% finite_imp_inj_to_nat_seg'
tff(fact_3291_set__to__map__inverse,axiom,
    ! [C: $tType,B: $tType,S2: set(product_prod(B,C))] :
      ( inj_on(product_prod(B,C),B,product_fst(B,C),S2)
     => ( map_to_set(B,C,set_to_map(B,C,S2)) = S2 ) ) ).

% set_to_map_inverse
tff(fact_3292_rel__restrict__Int__empty,axiom,
    ! [B: $tType,A4: set(B),R4: set(product_prod(B,B))] :
      ( ( aa(set(B),set(B),inf_inf(set(B),A4),field2(B,R4)) = bot_bot(set(B)) )
     => ( rel_restrict(B,R4,A4) = R4 ) ) ).

% rel_restrict_Int_empty
tff(fact_3293_Field__rel__restrict,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),field2(B,rel_restrict(B,R4,A4))),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),field2(B,R4)),A4)) ).

% Field_rel_restrict
tff(fact_3294_vimage__subsetI,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),B5: set(C),A4: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(B),set(C),image2(B,C,F),A4))
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(C),set(B),vimage(B,C,F),B5)),A4) ) ) ).

% vimage_subsetI
tff(fact_3295_inj__image__Compl__subset,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),uminus_uminus(set(B)),A4))),aa(set(C),set(C),uminus_uminus(set(C)),aa(set(B),set(C),image2(B,C,F),A4))) ) ).

% inj_image_Compl_subset
tff(fact_3296_The__case__prod,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o))] : the(product_prod(B,C),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),P)) = the(product_prod(B,C),aTP_Lamp_nm(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),P)) ).

% The_case_prod
tff(fact_3297_inj__on__disjoint__Un,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),G: fun(B,C),B5: set(B)] :
      ( inj_on(B,C,F,A4)
     => ( inj_on(B,C,G,B5)
       => ( ( aa(set(C),set(C),inf_inf(set(C),aa(set(B),set(C),image2(B,C,F),A4)),aa(set(B),set(C),image2(B,C,G),B5)) = bot_bot(set(C)) )
         => inj_on(B,C,aa(fun(B,C),fun(B,C),aa(set(B),fun(fun(B,C),fun(B,C)),aTP_Lamp_nn(fun(B,C),fun(set(B),fun(fun(B,C),fun(B,C))),F),A4),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) ) ) ) ).

% inj_on_disjoint_Un
tff(fact_3298_set__to__map__simp,axiom,
    ! [C: $tType,B: $tType,S2: set(product_prod(B,C)),K: B,V: C] :
      ( inj_on(product_prod(B,C),B,product_fst(B,C),S2)
     => ( ( aa(B,option(C),set_to_map(B,C,S2),K) = aa(C,option(C),some(C),V) )
      <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V),S2) ) ) ).

% set_to_map_simp
tff(fact_3299_rel__restrict__compl,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),rel_restrict(B,R4,A4)),rel_restrict(B,R4,aa(set(B),set(B),uminus_uminus(set(B)),A4))) = bot_bot(set(product_prod(B,B))) ).

% rel_restrict_compl
tff(fact_3300_homo__rel__restrict__mono,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),B5: set(B),A4: set(B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),product_Sigma(B,B,B5,aTP_Lamp_ma(set(B),fun(B,set(B)),B5)))
     => aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),rel_restrict(B,R4,A4)),product_Sigma(B,B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),B5),A4),aa(set(B),fun(B,set(B)),aTP_Lamp_no(set(B),fun(set(B),fun(B,set(B))),B5),A4))) ) ).

% homo_rel_restrict_mono
tff(fact_3301_rel__restrict__alt__def,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : rel_restrict(B,R4,A4) = aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R4),product_Sigma(B,B,aa(set(B),set(B),uminus_uminus(set(B)),A4),aTP_Lamp_np(set(B),fun(B,set(B)),A4))) ).

% rel_restrict_alt_def
tff(fact_3302_inj__on__Un,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(B)] :
      ( inj_on(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))
    <=> ( inj_on(B,C,F,A4)
        & inj_on(B,C,F,B5)
        & ( aa(set(C),set(C),inf_inf(set(C),aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),B5))),aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),B5),A4))) = bot_bot(set(C)) ) ) ) ).

% inj_on_Un
tff(fact_3303_inj__vimage__singleton,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A3: C] :
      ( inj_on(B,C,F,top_top(set(B)))
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(C),set(B),vimage(B,C,F),aa(set(C),set(C),insert2(C,A3),bot_bot(set(C))))),aa(set(B),set(B),insert2(B,the(B,aa(C,fun(B,$o),aTP_Lamp_nq(fun(B,C),fun(C,fun(B,$o)),F),A3))),bot_bot(set(B)))) ) ).

% inj_vimage_singleton
tff(fact_3304_If__the__inv__into__f__f,axiom,
    ! [C: $tType,B: $tType,I: B,C5: set(B),G: fun(B,C),X2: B] :
      ( member(B,I,C5)
     => ( inj_on(B,C,G,C5)
       => ( aa(B,B,aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),aa(B,fun(C,B),aa(fun(B,C),fun(B,fun(C,B)),aTP_Lamp_nr(set(B),fun(fun(B,C),fun(B,fun(C,B))),C5),G),X2)),G),I) = aa(B,B,id(B),I) ) ) ) ).

% If_the_inv_into_f_f
tff(fact_3305_ran__map__upd__Some,axiom,
    ! [C: $tType,B: $tType,M: fun(C,option(B)),X2: C,Y: B,Z2: B] :
      ( ( aa(C,option(B),M,X2) = aa(B,option(B),some(B),Y) )
     => ( inj_on(C,option(B),M,dom(C,B,M))
       => ( ~ member(B,Z2,ran(C,B,M))
         => ( ran(C,B,fun_upd(C,option(B),M,X2,aa(B,option(B),some(B),Z2))) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),ran(C,B,M)),aa(set(B),set(B),insert2(B,Y),bot_bot(set(B))))),aa(set(B),set(B),insert2(B,Z2),bot_bot(set(B)))) ) ) ) ) ).

% ran_map_upd_Some
tff(fact_3306_trancl__multi__insert,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),X7: set(B),M: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),R),product_Sigma(B,B,X7,aTP_Lamp_ns(B,fun(B,set(B)),M)))))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
       => ~ ! [X3: B] :
              ( member(B,X3,X7)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),X3),transitive_rtrancl(B,R))
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),M),B2),transitive_rtrancl(B,R)) ) ) ) ) ).

% trancl_multi_insert
tff(fact_3307_trancl__multi__insert2,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),M: B,X7: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),R),product_Sigma(B,B,aa(set(B),set(B),insert2(B,M),bot_bot(set(B))),aTP_Lamp_ma(set(B),fun(B,set(B)),X7)))))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
       => ~ ! [X3: B] :
              ( member(B,X3,X7)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),M),transitive_rtrancl(B,R))
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),B2),transitive_rtrancl(B,R)) ) ) ) ) ).

% trancl_multi_insert2
tff(fact_3308_the__inv__f__o__f__id,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),Z2: B] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(B,B,aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),the_inv_into(B,C,top_top(set(B)),F)),F),Z2) = aa(B,B,id(B),Z2) ) ) ).

% the_inv_f_o_f_id
tff(fact_3309_restrict__map__self,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : restrict_map(B,C,M,dom(B,C,M)) = M ).

% restrict_map_self
tff(fact_3310_same__fst__trancl,axiom,
    ! [C: $tType,B: $tType,P: fun(B,$o),R4: fun(B,set(product_prod(C,C)))] : transitive_trancl(product_prod(B,C),same_fst(B,C,P,R4)) = same_fst(B,C,P,aTP_Lamp_nt(fun(B,set(product_prod(C,C))),fun(B,set(product_prod(C,C))),R4)) ).

% same_fst_trancl
tff(fact_3311_dom__eq__empty__conv,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C))] :
      ( ( dom(B,C,F) = bot_bot(set(B)) )
    <=> ! [X4: B] : aa(B,option(C),F,X4) = none(C) ) ).

% dom_eq_empty_conv
tff(fact_3312_fun__upd__None__if__notin__dom,axiom,
    ! [C: $tType,B: $tType,K: B,M: fun(B,option(C))] :
      ( ~ member(B,K,dom(B,C,M))
     => ( fun_upd(B,option(C),M,K,none(C)) = M ) ) ).

% fun_upd_None_if_notin_dom
tff(fact_3313_the__inv__into__onto,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,A4)
     => ( aa(set(C),set(B),image2(C,B,the_inv_into(B,C,A4,F)),aa(set(B),set(C),image2(B,C,F),A4)) = A4 ) ) ).

% the_inv_into_onto
tff(fact_3314_dom__empty,axiom,
    ! [C: $tType,B: $tType] : dom(B,C,aTP_Lamp_hj(B,option(C))) = bot_bot(set(B)) ).

% dom_empty
tff(fact_3315_map__update__eta__repair_I1_J,axiom,
    ! [C: $tType,B: $tType,K: B,V: C,M: fun(B,option(C))] : dom(B,C,aa(fun(B,option(C)),fun(B,option(C)),aa(C,fun(fun(B,option(C)),fun(B,option(C))),aTP_Lamp_nu(B,fun(C,fun(fun(B,option(C)),fun(B,option(C)))),K),V),M)) = aa(set(B),set(B),insert2(B,K),dom(B,C,M)) ).

% map_update_eta_repair(1)
tff(fact_3316_dom__const_H,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] : dom(B,C,aTP_Lamp_nv(fun(B,C),fun(B,option(C)),F)) = top_top(set(B)) ).

% dom_const'
tff(fact_3317_dom__mmupd,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),K2: set(B),V: C] : dom(B,C,map_mmupd(B,C,M,K2,V)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),dom(B,C,M)),K2) ).

% dom_mmupd
tff(fact_3318_trancl__single,axiom,
    ! [B: $tType,A3: B,B2: B] : transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2)),bot_bot(set(product_prod(B,B))))) = aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2)),bot_bot(set(product_prod(B,B)))) ).

% trancl_single
tff(fact_3319_restrict__map__inv,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),X: B] : aa(B,option(C),restrict_map(B,C,F,aa(set(B),set(B),uminus_uminus(set(B)),dom(B,C,F))),X) = none(C) ).

% restrict_map_inv
tff(fact_3320_dom__fun__upd,axiom,
    ! [C: $tType,B: $tType,F: fun(B,option(C)),X2: B,Y: option(C)] :
      dom(B,C,fun_upd(B,option(C),F,X2,Y)) = $ite(Y = none(C),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),dom(B,C,F)),aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))),aa(set(B),set(B),insert2(B,X2),dom(B,C,F))) ).

% dom_fun_upd
tff(fact_3321_domI,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),A3: C,B2: B] :
      ( ( aa(C,option(B),M,A3) = aa(B,option(B),some(B),B2) )
     => member(C,A3,dom(C,B,M)) ) ).

% domI
tff(fact_3322_domD,axiom,
    ! [B: $tType,C: $tType,A3: B,M: fun(B,option(C))] :
      ( member(B,A3,dom(B,C,M))
     => ? [B3: C] : aa(B,option(C),M,A3) = aa(C,option(C),some(C),B3) ) ).

% domD
tff(fact_3323_domIff,axiom,
    ! [B: $tType,C: $tType,A3: B,M: fun(B,option(C))] :
      ( member(B,A3,dom(B,C,M))
    <=> ( aa(B,option(C),M,A3) != none(C) ) ) ).

% domIff
tff(fact_3324_nempty__dom,axiom,
    ! [C: $tType,B: $tType,E2: fun(B,option(C))] :
      ( ~ ! [X: B] : aa(B,option(C),E2,X) = none(C)
     => ~ ! [M4: B] : ~ member(B,M4,dom(B,C,E2)) ) ).

% nempty_dom
tff(fact_3325_trancl__sub,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),transitive_trancl(B,R4)) ).

% trancl_sub
tff(fact_3326_trancl__mono__mp,axiom,
    ! [B: $tType,U3: set(product_prod(B,B)),V5: set(product_prod(B,B)),X2: product_prod(B,B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),U3),V5)
     => ( member(product_prod(B,B),X2,transitive_trancl(B,U3))
       => member(product_prod(B,B),X2,transitive_trancl(B,V5)) ) ) ).

% trancl_mono_mp
tff(fact_3327_trancl_Ocases,axiom,
    ! [B: $tType,A1: B,A22: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),A22),transitive_trancl(B,R))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),A22),R)
       => ~ ! [B3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),B3),transitive_trancl(B,R))
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A22),R) ) ) ) ).

% trancl.cases
tff(fact_3328_trancl_Osimps,axiom,
    ! [B: $tType,A1: B,A22: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A1),A22),transitive_trancl(B,R))
    <=> ( ? [A7: B,B7: B] :
            ( ( A1 = A7 )
            & ( A22 = B7 )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),B7),R) )
        | ? [A7: B,B7: B,C4: B] :
            ( ( A1 = A7 )
            & ( A22 = C4 )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),B7),transitive_trancl(B,R))
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B7),C4),R) ) ) ) ).

% trancl.simps
tff(fact_3329_trancl_Or__into__trancl,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R)) ) ).

% trancl.r_into_trancl
tff(fact_3330_tranclE,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => ~ ! [C3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C3),transitive_trancl(B,R))
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),C3),B2),R) ) ) ) ).

% tranclE
tff(fact_3331_trancl__trans,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),Z2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),transitive_trancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),transitive_trancl(B,R)) ) ) ).

% trancl_trans
tff(fact_3332_trancl__induct,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),P: fun(B,$o)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
     => ( ! [Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),Y4),R)
           => aa(B,$o,P,Y4) )
       => ( ! [Y4: B,Z3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),Y4),transitive_trancl(B,R))
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
               => ( aa(B,$o,P,Y4)
                 => aa(B,$o,P,Z3) ) ) )
         => aa(B,$o,P,B2) ) ) ) ).

% trancl_induct
tff(fact_3333_r__r__into__trancl,axiom,
    ! [B: $tType,A3: B,B2: B,R4: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R4)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),R4)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_trancl(B,R4)) ) ) ).

% r_r_into_trancl
tff(fact_3334_converse__tranclE,axiom,
    ! [B: $tType,X2: B,Z2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),transitive_trancl(B,R))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),R)
       => ~ ! [Y4: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),R)
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),transitive_trancl(B,R)) ) ) ) ).

% converse_tranclE
tff(fact_3335_irrefl__trancl__rD,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: B,Y: B] :
      ( ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),transitive_trancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
       => ( X2 != Y ) ) ) ).

% irrefl_trancl_rD
tff(fact_3336_Transitive__Closure_Otrancl__into__trancl,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),R)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_trancl(B,R)) ) ) ).

% Transitive_Closure.trancl_into_trancl
tff(fact_3337_trancl__into__trancl2,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),transitive_trancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_trancl(B,R)) ) ) ).

% trancl_into_trancl2
tff(fact_3338_trancl__trans__induct,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),P: fun(B,fun(B,$o))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,R))
     => ( ! [X3: B,Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R)
           => aa(B,$o,aa(B,fun(B,$o),P,X3),Y4) )
       => ( ! [X3: B,Y4: B,Z3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),transitive_trancl(B,R))
             => ( aa(B,$o,aa(B,fun(B,$o),P,X3),Y4)
               => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),transitive_trancl(B,R))
                 => ( aa(B,$o,aa(B,fun(B,$o),P,Y4),Z3)
                   => aa(B,$o,aa(B,fun(B,$o),P,X3),Z3) ) ) ) )
         => aa(B,$o,aa(B,fun(B,$o),P,X2),Y) ) ) ) ).

% trancl_trans_induct
tff(fact_3339_converse__trancl__induct,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),P: fun(B,$o)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
     => ( ! [Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),B2),R)
           => aa(B,$o,P,Y4) )
       => ( ! [Y4: B,Z3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z3),B2),transitive_trancl(B,R))
               => ( aa(B,$o,P,Z3)
                 => aa(B,$o,P,Y4) ) ) )
         => aa(B,$o,P,A3) ) ) ) ).

% converse_trancl_induct
tff(fact_3340_dom__def,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : dom(B,C,M) = aa(fun(B,$o),set(B),collect(B),aTP_Lamp_nw(fun(B,option(C)),fun(B,$o),M)) ).

% dom_def
tff(fact_3341_the__inv__into__f__f,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: B] :
      ( inj_on(B,C,F,A4)
     => ( member(B,X2,A4)
       => ( aa(C,B,the_inv_into(B,C,A4,F),aa(B,C,F,X2)) = X2 ) ) ) ).

% the_inv_into_f_f
tff(fact_3342_the__inv__into__f__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: B,Y: C] :
      ( inj_on(B,C,F,A4)
     => ( ( aa(B,C,F,X2) = Y )
       => ( member(B,X2,A4)
         => ( aa(C,B,the_inv_into(B,C,A4,F),Y) = X2 ) ) ) ) ).

% the_inv_into_f_eq
tff(fact_3343_insert__dom,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),X2: C,Y: B] :
      ( ( aa(C,option(B),F,X2) = aa(B,option(B),some(B),Y) )
     => ( aa(set(C),set(C),insert2(C,X2),dom(C,B,F)) = dom(C,B,F) ) ) ).

% insert_dom
tff(fact_3344_trancl__rtrancl__trancl,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),transitive_rtrancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_trancl(B,R)) ) ) ).

% trancl_rtrancl_trancl
tff(fact_3345_rtrancl__trancl__trancl,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),Z2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),transitive_trancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),transitive_trancl(B,R)) ) ) ).

% rtrancl_trancl_trancl
tff(fact_3346_rtrancl__into__trancl2,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),transitive_rtrancl(B,R))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_trancl(B,R)) ) ) ).

% rtrancl_into_trancl2
tff(fact_3347_rtrancl__into__trancl1,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),C2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),C2),R)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),C2),transitive_trancl(B,R)) ) ) ).

% rtrancl_into_trancl1
tff(fact_3348_rtrancl__eq__or__trancl,axiom,
    ! [B: $tType,X2: B,Y: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R4))
    <=> ( ( X2 = Y )
        | ( ( X2 != Y )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,R4)) ) ) ) ).

% rtrancl_eq_or_trancl
tff(fact_3349_trancl__into__rtrancl,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R)) ) ).

% trancl_into_rtrancl
tff(fact_3350_tranclD2,axiom,
    ! [B: $tType,X2: B,Y: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,R4))
     => ? [Z3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z3),transitive_rtrancl(B,R4))
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z3),Y),R4) ) ) ).

% tranclD2
tff(fact_3351_rtranclD,axiom,
    ! [B: $tType,A3: B,B2: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_rtrancl(B,R4))
     => ( ( A3 = B2 )
        | ( ( A3 != B2 )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,R4)) ) ) ) ).

% rtranclD
tff(fact_3352_tranclD,axiom,
    ! [B: $tType,X2: B,Y: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,R4))
     => ? [Z3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z3),R4)
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z3),Y),transitive_rtrancl(B,R4)) ) ) ).

% tranclD
tff(fact_3353_map__dom__ran__finite,axiom,
    ! [C: $tType,B: $tType,M2: fun(B,option(C))] :
      ( finite_finite2(B,dom(B,C,M2))
     => finite_finite2(C,ran(B,C,M2)) ) ).

% map_dom_ran_finite
tff(fact_3354_rel__restrict__trancl__notR_I2_J,axiom,
    ! [B: $tType,V: B,W: B,E4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_trancl(B,rel_restrict(B,E4,R4)))
     => ~ member(B,W,R4) ) ).

% rel_restrict_trancl_notR(2)
tff(fact_3355_rel__restrict__trancl__notR_I1_J,axiom,
    ! [B: $tType,V: B,W: B,E4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_trancl(B,rel_restrict(B,E4,R4)))
     => ~ member(B,V,R4) ) ).

% rel_restrict_trancl_notR(1)
tff(fact_3356_rel__restrict__trancl__mem,axiom,
    ! [B: $tType,A3: B,B2: B,A4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,rel_restrict(B,A4,R4)))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),rel_restrict(B,transitive_trancl(B,A4),R4)) ) ).

% rel_restrict_trancl_mem
tff(fact_3357_trancl__induct2,axiom,
    ! [B: $tType,C: $tType,Ax: B,Ay: C,Bx: B,By: C,R: set(product_prod(product_prod(B,C),product_prod(B,C))),P: fun(B,fun(C,$o))] :
      ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By)),transitive_trancl(product_prod(B,C),R))
     => ( ! [A5: B,B3: C] :
            ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),R)
           => aa(C,$o,aa(B,fun(C,$o),P,A5),B3) )
       => ( ! [A5: B,B3: C,Aa2: B,Ba: C] :
              ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),transitive_trancl(product_prod(B,C),R))
             => ( member(product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C)),aa(product_prod(B,C),fun(product_prod(B,C),product_prod(product_prod(B,C),product_prod(B,C))),product_Pair(product_prod(B,C),product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba)),R)
               => ( aa(C,$o,aa(B,fun(C,$o),P,A5),B3)
                 => aa(C,$o,aa(B,fun(C,$o),P,Aa2),Ba) ) ) )
         => aa(C,$o,aa(B,fun(C,$o),P,Bx),By) ) ) ) ).

% trancl_induct2
tff(fact_3358_card__map__to__set,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : finite_card(product_prod(B,C),map_to_set(B,C,M)) = finite_card(B,dom(B,C,M)) ).

% card_map_to_set
tff(fact_3359_trancl__sub__insert__trancl,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),X2: product_prod(B,B)] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),transitive_trancl(B,R4)),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),X2),R4))) ).

% trancl_sub_insert_trancl
tff(fact_3360_rel__restrict__trancl__sub,axiom,
    ! [B: $tType,A4: set(product_prod(B,B)),R4: set(B)] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),transitive_trancl(B,rel_restrict(B,A4,R4))),rel_restrict(B,transitive_trancl(B,A4),R4)) ).

% rel_restrict_trancl_sub
tff(fact_3361_le__map__dom__mono,axiom,
    ! [C: $tType,B: $tType] :
      ( preorder(C)
     => ! [M: fun(B,option(C)),M7: fun(B,option(C))] :
          ( aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),M),M7)
         => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),dom(B,C,M)),dom(B,C,M7)) ) ) ).

% le_map_dom_mono
tff(fact_3362_the__inv__into__def,axiom,
    ! [C: $tType,B: $tType,A4: set(C),F: fun(C,B),X: B] : aa(B,C,the_inv_into(C,B,A4,F),X) = the(C,aa(B,fun(C,$o),aa(fun(C,B),fun(B,fun(C,$o)),aTP_Lamp_nx(set(C),fun(fun(C,B),fun(B,fun(C,$o))),A4),F),X)) ).

% the_inv_into_def
tff(fact_3363_finite__map__freshness,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C))] :
      ( finite_finite2(B,dom(B,C,F))
     => ( ~ finite_finite2(B,top_top(set(B)))
       => ? [X3: B] : aa(B,option(C),F,X3) = none(C) ) ) ).

% finite_map_freshness
tff(fact_3364_dom__minus,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),X2: C,A4: set(C)] :
      ( ( aa(C,option(B),F,X2) = none(B) )
     => ( aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),dom(C,B,F)),aa(set(C),set(C),insert2(C,X2),A4)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),dom(C,B,F)),A4) ) ) ).

% dom_minus
tff(fact_3365_restrict__map__eq_I1_J,axiom,
    ! [B: $tType,C: $tType,M: fun(C,option(B)),A4: set(C),K: C] :
      ( ( aa(C,option(B),restrict_map(C,B,M,A4),K) = none(B) )
    <=> ~ member(C,K,aa(set(C),set(C),inf_inf(set(C),dom(C,B,M)),A4)) ) ).

% restrict_map_eq(1)
tff(fact_3366_map__card__eq__iff,axiom,
    ! [C: $tType,B: $tType,M2: fun(B,option(C)),X2: B,Y: B] :
      ( finite_finite2(B,dom(B,C,M2))
     => ( ( finite_card(B,dom(B,C,M2)) = finite_card(C,ran(B,C,M2)) )
       => ( member(B,X2,dom(B,C,M2))
         => ( ( aa(B,option(C),M2,X2) = aa(B,option(C),M2,Y) )
          <=> ( X2 = Y ) ) ) ) ) ).

% map_card_eq_iff
tff(fact_3367_wf__linord__ex__has__least,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),P: fun(C,$o),K: C,M: fun(C,B)] :
      ( wf(B,R)
     => ( ! [X3: B,Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),transitive_trancl(B,R))
          <=> ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),X3),transitive_rtrancl(B,R)) )
       => ( aa(C,$o,P,K)
         => ? [X3: C] :
              ( aa(C,$o,P,X3)
              & ! [Y5: C] :
                  ( aa(C,$o,P,Y5)
                 => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(C,B,M,X3)),aa(C,B,M,Y5)),transitive_rtrancl(B,R)) ) ) ) ) ) ).

% wf_linord_ex_has_least
tff(fact_3368_trancl__union__outside,axiom,
    ! [B: $tType,V: B,W: B,E4: set(product_prod(B,B)),U3: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),E4),U3)))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_trancl(B,E4))
       => ? [X3: B,Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),X3),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),E4),U3)))
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),U3)
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),W),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),E4),U3))) ) ) ) ).

% trancl_union_outside
tff(fact_3369_trancl__over__edgeE,axiom,
    ! [B: $tType,U: B,W: B,V1: B,V22: B,E4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),W),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V1),V22)),E4)))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),W),transitive_trancl(B,E4))
       => ~ ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V1),transitive_rtrancl(B,E4))
           => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V22),W),transitive_rtrancl(B,E4)) ) ) ) ).

% trancl_over_edgeE
tff(fact_3370_finite__map__to__set,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] :
      ( finite_finite2(product_prod(B,C),map_to_set(B,C,M))
    <=> finite_finite2(B,dom(B,C,M)) ) ).

% finite_map_to_set
tff(fact_3371_map__to__set__dom,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : dom(B,C,M) = aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),map_to_set(B,C,M)) ).

% map_to_set_dom
tff(fact_3372_inj__on__the__inv__into,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,A4)
     => inj_on(C,B,the_inv_into(B,C,A4,F),aa(set(B),set(C),image2(B,C,F),A4)) ) ).

% inj_on_the_inv_into
tff(fact_3373_f__the__inv__into__f,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),Y: C] :
      ( inj_on(B,C,F,A4)
     => ( member(C,Y,aa(set(B),set(C),image2(B,C,F),A4))
       => ( aa(B,C,F,aa(C,B,the_inv_into(B,C,A4,F),Y)) = Y ) ) ) ).

% f_the_inv_into_f
tff(fact_3374_the__inv__f__f,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),X2: B] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(C,B,the_inv_into(B,C,top_top(set(B)),F),aa(B,C,F,X2)) = X2 ) ) ).

% the_inv_f_f
tff(fact_3375_set__to__map__dom,axiom,
    ! [C: $tType,B: $tType,S2: set(product_prod(B,C))] : dom(B,C,set_to_map(B,C,S2)) = aa(set(product_prod(B,C)),set(B),image2(product_prod(B,C),B,product_fst(B,C)),S2) ).

% set_to_map_dom
tff(fact_3376_Restr__trancl__mono,axiom,
    ! [B: $tType,V: B,W: B,E4: set(product_prod(B,B)),U3: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),E4),product_Sigma(B,B,U3,aTP_Lamp_ma(set(B),fun(B,set(B)),U3)))))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V),W),transitive_trancl(B,E4)) ) ).

% Restr_trancl_mono
tff(fact_3377_inj__on__map__the,axiom,
    ! [C: $tType,B: $tType,D4: set(B),M: fun(B,option(C))] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),D4),dom(B,C,M))
     => ( inj_on(B,option(C),M,D4)
       => inj_on(B,C,aa(fun(B,option(C)),fun(B,C),aa(fun(option(C),C),fun(fun(B,option(C)),fun(B,C)),comp(option(C),C,B),the2(C)),M),D4) ) ) ).

% inj_on_map_the
tff(fact_3378_finite__Map__induct,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),P: fun(fun(B,option(C)),$o)] :
      ( finite_finite2(B,dom(B,C,M))
     => ( aa(fun(B,option(C)),$o,P,aTP_Lamp_hj(B,option(C)))
       => ( ! [K3: B,V4: C,M4: fun(B,option(C))] :
              ( finite_finite2(B,dom(B,C,M4))
             => ( ~ member(B,K3,dom(B,C,M4))
               => ( aa(fun(B,option(C)),$o,P,M4)
                 => aa(fun(B,option(C)),$o,P,fun_upd(B,option(C),M4,K3,aa(C,option(C),some(C),V4))) ) ) )
         => aa(fun(B,option(C)),$o,P,M) ) ) ) ).

% finite_Map_induct
tff(fact_3379_ran__is__image,axiom,
    ! [B: $tType,C: $tType,M2: fun(C,option(B))] : ran(C,B,M2) = aa(set(C),set(B),image2(C,B,aa(fun(C,option(B)),fun(C,B),aa(fun(option(B),B),fun(fun(C,option(B)),fun(C,B)),comp(option(B),B,C),the2(B)),M2)),dom(C,B,M2)) ).

% ran_is_image
tff(fact_3380_graph__eq__to__snd__dom,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : graph(B,C,M) = aa(set(B),set(product_prod(B,C)),image2(B,product_prod(B,C),aTP_Lamp_ny(fun(B,option(C)),fun(B,product_prod(B,C)),M)),dom(B,C,M)) ).

% graph_eq_to_snd_dom
tff(fact_3381_trancl__insert2,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B))] : transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2)),R)) = aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),transitive_trancl(B,R)),aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aa(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o))),aTP_Lamp_nz(B,fun(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o)))),A3),B2),R)))) ).

% trancl_insert2
tff(fact_3382_rel__restrict__Sigma__sub,axiom,
    ! [B: $tType,A4: set(B),R4: set(B)] : aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),rel_restrict(B,transitive_trancl(B,product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4))),R4)),transitive_trancl(B,product_Sigma(B,B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),R4),aa(set(B),fun(B,set(B)),aTP_Lamp_no(set(B),fun(set(B),fun(B,set(B))),A4),R4)))) ).

% rel_restrict_Sigma_sub
tff(fact_3383_the__inv__into__into,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: C,B5: set(B)] :
      ( inj_on(B,C,F,A4)
     => ( member(C,X2,aa(set(B),set(C),image2(B,C,F),A4))
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
         => member(B,aa(C,B,the_inv_into(B,C,A4,F),X2),B5) ) ) ) ).

% the_inv_into_into
tff(fact_3384_the__inv__into__comp,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(B,C),G: fun(D,B),A4: set(D),X2: C] :
      ( inj_on(B,C,F,aa(set(D),set(B),image2(D,B,G),A4))
     => ( inj_on(D,B,G,A4)
       => ( member(C,X2,aa(set(B),set(C),image2(B,C,F),aa(set(D),set(B),image2(D,B,G),A4)))
         => ( aa(C,D,the_inv_into(D,C,A4,aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),F),G)),X2) = aa(C,D,aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),the_inv_into(D,B,A4,G)),the_inv_into(B,C,aa(set(D),set(B),image2(D,B,G),A4),F)),X2) ) ) ) ) ).

% the_inv_into_comp
tff(fact_3385_dom__eq__singleton__conv,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),X2: B] :
      ( ( dom(B,C,F) = aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))) )
    <=> ? [V3: C] : F = fun_upd(B,option(C),aTP_Lamp_hj(B,option(C)),X2,aa(C,option(C),some(C),V3)) ) ).

% dom_eq_singleton_conv
tff(fact_3386_rtrancl__last__visit,axiom,
    ! [B: $tType,Q3: B,Q4: B,R4: set(product_prod(B,B)),S2: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Q4),transitive_rtrancl(B,R4))
     => ( ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Q4),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_ma(set(B),fun(B,set(B)),S2)))))
       => ~ ! [Qt: B] :
              ( member(B,Qt,S2)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),Qt),transitive_trancl(B,R4))
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Qt),Q4),transitive_rtrancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),R4),product_Sigma(B,B,top_top(set(B)),aTP_Lamp_ma(set(B),fun(B,set(B)),S2))))) ) ) ) ) ).

% rtrancl_last_visit
tff(fact_3387_trancl__insert,axiom,
    ! [B: $tType,Y: B,X2: B,R: set(product_prod(B,B))] : transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2)),R)) = aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),transitive_trancl(B,R)),aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aa(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o))),aTP_Lamp_nc(B,fun(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o)))),Y),X2),R)))) ).

% trancl_insert
tff(fact_3388_finite__trancl__ntranl,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( finite_finite2(product_prod(B,B),R4)
     => ( transitive_trancl(B,R4) = transitive_ntrancl(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(product_prod(B,B),R4)),one_one(nat)),R4) ) ) ).

% finite_trancl_ntranl
tff(fact_3389_ran__add,axiom,
    ! [C: $tType,B: $tType,F: fun(B,option(C)),G: fun(B,option(C))] :
      ( ( aa(set(B),set(B),inf_inf(set(B),dom(B,C,F)),dom(B,C,G)) = bot_bot(set(B)) )
     => ( ran(B,C,map_add(B,C,F,G)) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),ran(B,C,F)),ran(B,C,G)) ) ) ).

% ran_add
tff(fact_3390_eq__f__restr__ss__eq,axiom,
    ! [C: $tType,B: $tType,S: set(B),F: fun(fun(B,option(C)),fun(B,option(C))),A4: fun(B,option(C))] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S),dom(B,C,aa(fun(B,option(C)),fun(B,option(C)),F,A4)))
     => ( ( A4 = restrict_map(B,C,aa(fun(B,option(C)),fun(B,option(C)),F,A4),aa(set(B),set(B),uminus_uminus(set(B)),S)) )
      <=> ( map_le(B,C,A4,aa(fun(B,option(C)),fun(B,option(C)),F,A4))
          & ( S = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),dom(B,C,aa(fun(B,option(C)),fun(B,option(C)),F,A4))),dom(B,C,A4)) ) ) ) ) ).

% eq_f_restr_ss_eq
tff(fact_3391_eq__f__restr__conv,axiom,
    ! [C: $tType,B: $tType,S: set(B),F: fun(fun(B,option(C)),fun(B,option(C))),A4: fun(B,option(C))] :
      ( ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),S),dom(B,C,aa(fun(B,option(C)),fun(B,option(C)),F,A4)))
        & ( A4 = restrict_map(B,C,aa(fun(B,option(C)),fun(B,option(C)),F,A4),aa(set(B),set(B),uminus_uminus(set(B)),S)) ) )
    <=> ( map_le(B,C,A4,aa(fun(B,option(C)),fun(B,option(C)),F,A4))
        & ( S = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),dom(B,C,aa(fun(B,option(C)),fun(B,option(C)),F,A4))),dom(B,C,A4)) ) ) ) ).

% eq_f_restr_conv
tff(fact_3392_type__copy__set__map0,axiom,
    ! [B: $tType,C: $tType,E: $tType,F4: $tType,D: $tType,G2: $tType,Rep: fun(B,C),Abs: fun(C,B),S2: fun(C,set(E)),M2: fun(D,C),F: fun(F4,E),S5: fun(D,set(F4)),G: fun(G2,D)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( ( aa(fun(D,C),fun(D,set(E)),aa(fun(C,set(E)),fun(fun(D,C),fun(D,set(E))),comp(C,set(E),D),S2),M2) = aa(fun(D,set(F4)),fun(D,set(E)),aa(fun(set(F4),set(E)),fun(fun(D,set(F4)),fun(D,set(E))),comp(set(F4),set(E),D),image2(F4,E,F)),S5) )
       => ( aa(fun(G2,B),fun(G2,set(E)),aa(fun(B,set(E)),fun(fun(G2,B),fun(G2,set(E))),comp(B,set(E),G2),aa(fun(B,C),fun(B,set(E)),aa(fun(C,set(E)),fun(fun(B,C),fun(B,set(E))),comp(C,set(E),B),S2),Rep)),aa(fun(G2,D),fun(G2,B),aa(fun(D,B),fun(fun(G2,D),fun(G2,B)),comp(D,B,G2),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Abs),M2)),G)) = aa(fun(G2,set(F4)),fun(G2,set(E)),aa(fun(set(F4),set(E)),fun(fun(G2,set(F4)),fun(G2,set(E))),comp(set(F4),set(E),G2),image2(F4,E,F)),aa(fun(G2,D),fun(G2,set(F4)),aa(fun(D,set(F4)),fun(fun(G2,D),fun(G2,set(F4))),comp(D,set(F4),G2),S5),G)) ) ) ) ).

% type_copy_set_map0
tff(fact_3393_map__add__find__right,axiom,
    ! [C: $tType,B: $tType,N: fun(C,option(B)),K: C,Xx: B,M: fun(C,option(B))] :
      ( ( aa(C,option(B),N,K) = aa(B,option(B),some(B),Xx) )
     => ( aa(C,option(B),map_add(C,B,M,N),K) = aa(B,option(B),some(B),Xx) ) ) ).

% map_add_find_right
tff(fact_3394_map__add__eq__empty__iff,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),G: fun(B,option(C))] :
      ( ! [X4: B] : aa(B,option(C),map_add(B,C,F,G),X4) = none(C)
    <=> ( ! [X4: B] : aa(B,option(C),F,X4) = none(C)
        & ! [X4: B] : aa(B,option(C),G,X4) = none(C) ) ) ).

% map_add_eq_empty_iff
tff(fact_3395_map__add__None,axiom,
    ! [C: $tType,B: $tType,M: fun(C,option(B)),N: fun(C,option(B)),K: C] :
      ( ( aa(C,option(B),map_add(C,B,M,N),K) = none(B) )
    <=> ( ( aa(C,option(B),N,K) = none(B) )
        & ( aa(C,option(B),M,K) = none(B) ) ) ) ).

% map_add_None
tff(fact_3396_empty__map__add,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : map_add(B,C,aTP_Lamp_hj(B,option(C)),M) = M ).

% empty_map_add
tff(fact_3397_map__add__empty,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C))] : map_add(B,C,M,aTP_Lamp_hj(B,option(C))) = M ).

% map_add_empty
tff(fact_3398_empty__eq__map__add__iff,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),G: fun(B,option(C))] :
      ( ( aTP_Lamp_hj(B,option(C)) = map_add(B,C,F,G) )
    <=> ( ! [X4: B] : aa(B,option(C),F,X4) = none(C)
        & ! [X4: B] : aa(B,option(C),G,X4) = none(C) ) ) ).

% empty_eq_map_add_iff
tff(fact_3399_map__add__upd,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),G: fun(B,option(C)),X2: B,Y: C] : map_add(B,C,F,fun_upd(B,option(C),G,X2,aa(C,option(C),some(C),Y))) = fun_upd(B,option(C),map_add(B,C,F,G),X2,aa(C,option(C),some(C),Y)) ).

% map_add_upd
tff(fact_3400_map__add__upd__left,axiom,
    ! [B: $tType,C: $tType,M: B,E22: fun(B,option(C)),E1: fun(B,option(C)),U1: C] :
      ( ~ member(B,M,dom(B,C,E22))
     => ( map_add(B,C,fun_upd(B,option(C),E1,M,aa(C,option(C),some(C),U1)),E22) = fun_upd(B,option(C),map_add(B,C,E1,E22),M,aa(C,option(C),some(C),U1)) ) ) ).

% map_add_upd_left
tff(fact_3401_le__map__mmupd__not__dom,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),K2: set(B),V: C] : map_le(B,C,M,map_mmupd(B,C,M,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),K2),dom(B,C,M)),V)) ).

% le_map_mmupd_not_dom
tff(fact_3402_map__add__find__left,axiom,
    ! [B: $tType,C: $tType,G: fun(C,option(B)),K: C,F: fun(C,option(B))] :
      ( ( aa(C,option(B),G,K) = none(B) )
     => ( aa(C,option(B),map_add(C,B,F,G),K) = aa(C,option(B),F,K) ) ) ).

% map_add_find_left
tff(fact_3403_map__add__left__None,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),K: C,G: fun(C,option(B))] :
      ( ( aa(C,option(B),F,K) = none(B) )
     => ( aa(C,option(B),map_add(C,B,F,G),K) = aa(C,option(B),G,K) ) ) ).

% map_add_left_None
tff(fact_3404_map__leI,axiom,
    ! [C: $tType,B: $tType,M1: fun(B,option(C)),M22: fun(B,option(C))] :
      ( ! [X3: B,V4: C] :
          ( ( aa(B,option(C),M1,X3) = aa(C,option(C),some(C),V4) )
         => ( aa(B,option(C),M22,X3) = aa(C,option(C),some(C),V4) ) )
     => map_le(B,C,M1,M22) ) ).

% map_leI
tff(fact_3405_map__leD,axiom,
    ! [B: $tType,C: $tType,M1: fun(B,option(C)),M22: fun(B,option(C)),K: B,V: C] :
      ( map_le(B,C,M1,M22)
     => ( ( aa(B,option(C),M1,K) = aa(C,option(C),some(C),V) )
       => ( aa(B,option(C),M22,K) = aa(C,option(C),some(C),V) ) ) ) ).

% map_leD
tff(fact_3406_map__add__first__le,axiom,
    ! [C: $tType,B: $tType] :
      ( order(C)
     => ! [M: fun(B,option(C)),M7: fun(B,option(C)),N: fun(B,option(C))] :
          ( aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),M),M7)
         => aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),map_add(B,C,M,N)),map_add(B,C,M7,N)) ) ) ).

% map_add_first_le
tff(fact_3407_map__le__empty,axiom,
    ! [C: $tType,B: $tType,G: fun(B,option(C))] : map_le(B,C,aTP_Lamp_hj(B,option(C)),G) ).

% map_le_empty
tff(fact_3408_map__add__Some__iff,axiom,
    ! [C: $tType,B: $tType,M: fun(C,option(B)),N: fun(C,option(B)),K: C,X2: B] :
      ( ( aa(C,option(B),map_add(C,B,M,N),K) = aa(B,option(B),some(B),X2) )
    <=> ( ( aa(C,option(B),N,K) = aa(B,option(B),some(B),X2) )
        | ( ( aa(C,option(B),N,K) = none(B) )
          & ( aa(C,option(B),M,K) = aa(B,option(B),some(B),X2) ) ) ) ) ).

% map_add_Some_iff
tff(fact_3409_map__add__SomeD,axiom,
    ! [C: $tType,B: $tType,M: fun(C,option(B)),N: fun(C,option(B)),K: C,X2: B] :
      ( ( aa(C,option(B),map_add(C,B,M,N),K) = aa(B,option(B),some(B),X2) )
     => ( ( aa(C,option(B),N,K) = aa(B,option(B),some(B),X2) )
        | ( ( aa(C,option(B),N,K) = none(B) )
          & ( aa(C,option(B),M,K) = aa(B,option(B),some(B),X2) ) ) ) ) ).

% map_add_SomeD
tff(fact_3410_type__copy__map__comp0__undo,axiom,
    ! [F4: $tType,B: $tType,D: $tType,C: $tType,E: $tType,G2: $tType,Rep: fun(B,C),Abs: fun(C,B),Rep2: fun(D,E),Abs2: fun(E,D),Rep3: fun(F4,G2),Abs3: fun(G2,F4),M2: fun(G2,E),M13: fun(C,E),M24: fun(G2,C)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( type_definition(D,E,Rep2,Abs2,top_top(set(E)))
       => ( type_definition(F4,G2,Rep3,Abs3,top_top(set(G2)))
         => ( ( aa(fun(F4,G2),fun(F4,D),aa(fun(G2,D),fun(fun(F4,G2),fun(F4,D)),comp(G2,D,F4),aa(fun(G2,E),fun(G2,D),aa(fun(E,D),fun(fun(G2,E),fun(G2,D)),comp(E,D,G2),Abs2),M2)),Rep3) = aa(fun(F4,B),fun(F4,D),aa(fun(B,D),fun(fun(F4,B),fun(F4,D)),comp(B,D,F4),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),aa(fun(C,E),fun(C,D),aa(fun(E,D),fun(fun(C,E),fun(C,D)),comp(E,D,C),Abs2),M13)),Rep)),aa(fun(F4,G2),fun(F4,B),aa(fun(G2,B),fun(fun(F4,G2),fun(F4,B)),comp(G2,B,F4),aa(fun(G2,C),fun(G2,B),aa(fun(C,B),fun(fun(G2,C),fun(G2,B)),comp(C,B,G2),Abs),M24)),Rep3)) )
           => ( aa(fun(G2,C),fun(G2,E),aa(fun(C,E),fun(fun(G2,C),fun(G2,E)),comp(C,E,G2),M13),M24) = M2 ) ) ) ) ) ).

% type_copy_map_comp0_undo
tff(fact_3411_type__copy__map__comp0,axiom,
    ! [G2: $tType,E: $tType,C: $tType,B: $tType,D: $tType,F4: $tType,Rep: fun(B,C),Abs: fun(C,B),M2: fun(D,E),M13: fun(C,E),M24: fun(D,C),F: fun(E,G2),G: fun(F4,D)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( ( M2 = aa(fun(D,C),fun(D,E),aa(fun(C,E),fun(fun(D,C),fun(D,E)),comp(C,E,D),M13),M24) )
       => ( aa(fun(F4,D),fun(F4,G2),aa(fun(D,G2),fun(fun(F4,D),fun(F4,G2)),comp(D,G2,F4),aa(fun(D,E),fun(D,G2),aa(fun(E,G2),fun(fun(D,E),fun(D,G2)),comp(E,G2,D),F),M2)),G) = aa(fun(F4,B),fun(F4,G2),aa(fun(B,G2),fun(fun(F4,B),fun(F4,G2)),comp(B,G2,F4),aa(fun(B,C),fun(B,G2),aa(fun(C,G2),fun(fun(B,C),fun(B,G2)),comp(C,G2,B),aa(fun(C,E),fun(C,G2),aa(fun(E,G2),fun(fun(C,E),fun(C,G2)),comp(E,G2,C),F),M13)),Rep)),aa(fun(F4,D),fun(F4,B),aa(fun(D,B),fun(fun(F4,D),fun(F4,B)),comp(D,B,F4),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Abs),M24)),G)) ) ) ) ).

% type_copy_map_comp0
tff(fact_3412_upd__None__map__le,axiom,
    ! [C: $tType,B: $tType,F: fun(B,option(C)),X2: B] : map_le(B,C,fun_upd(B,option(C),F,X2,none(C)),F) ).

% upd_None_map_le
tff(fact_3413_map__add__def,axiom,
    ! [C: $tType,B: $tType,M1: fun(B,option(C)),M22: fun(B,option(C)),X: B] : aa(B,option(C),map_add(B,C,M1,M22),X) = aa(option(C),option(C),aa(fun(C,option(C)),fun(option(C),option(C)),aa(option(C),fun(fun(C,option(C)),fun(option(C),option(C))),case_option(option(C),C),aa(B,option(C),M1,X)),some(C)),aa(B,option(C),M22,X)) ).

% map_add_def
tff(fact_3414_map__add__left__comm,axiom,
    ! [C: $tType,B: $tType,A4: fun(B,option(C)),B5: fun(B,option(C)),C5: fun(B,option(C))] :
      ( ( aa(set(B),set(B),inf_inf(set(B),dom(B,C,A4)),dom(B,C,B5)) = bot_bot(set(B)) )
     => ( map_add(B,C,A4,map_add(B,C,B5,C5)) = map_add(B,C,B5,map_add(B,C,A4,C5)) ) ) ).

% map_add_left_comm
tff(fact_3415_type__copy__map__id0,axiom,
    ! [C: $tType,B: $tType,Rep: fun(B,C),Abs: fun(C,B),M2: fun(C,C)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( ( M2 = id(C) )
       => ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),aa(fun(C,C),fun(C,B),aa(fun(C,B),fun(fun(C,C),fun(C,B)),comp(C,B,C),Abs),M2)),Rep) = id(B) ) ) ) ).

% type_copy_map_id0
tff(fact_3416_type__copy__Abs__o__Rep,axiom,
    ! [C: $tType,B: $tType,Rep: fun(B,C),Abs: fun(C,B)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),Abs),Rep) = id(B) ) ) ).

% type_copy_Abs_o_Rep
tff(fact_3417_type__copy__Rep__o__Abs,axiom,
    ! [B: $tType,C: $tType,Rep: fun(B,C),Abs: fun(C,B)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( aa(fun(C,B),fun(C,C),aa(fun(B,C),fun(fun(C,B),fun(C,C)),comp(B,C,C),Rep),Abs) = id(C) ) ) ).

% type_copy_Rep_o_Abs
tff(fact_3418_type__definition__integer,axiom,
    type_definition(code_integer,int,code_int_of_integer,code_integer_of_int,top_top(set(int))) ).

% type_definition_integer
tff(fact_3419_map__le__imp__upd__le,axiom,
    ! [B: $tType,C: $tType,M1: fun(B,option(C)),M22: fun(B,option(C)),X2: B,Y: C] :
      ( map_le(B,C,M1,M22)
     => map_le(B,C,fun_upd(B,option(C),M1,X2,none(C)),fun_upd(B,option(C),M22,X2,aa(C,option(C),some(C),Y))) ) ).

% map_le_imp_upd_le
tff(fact_3420_map__add__distinct__le,axiom,
    ! [C: $tType,B: $tType] :
      ( preorder(C)
     => ! [M: fun(B,option(C)),M7: fun(B,option(C)),N: fun(B,option(C)),N2: fun(B,option(C))] :
          ( aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),M),M7)
         => ( aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),N),N2)
           => ( ( aa(set(B),set(B),inf_inf(set(B),dom(B,C,M7)),dom(B,C,N2)) = bot_bot(set(B)) )
             => aa(fun(B,option(C)),$o,aa(fun(B,option(C)),fun(fun(B,option(C)),$o),ord_less_eq(fun(B,option(C))),map_add(B,C,M,N)),map_add(B,C,M7,N2)) ) ) ) ) ).

% map_add_distinct_le
tff(fact_3421_map__mmupd__update__less,axiom,
    ! [B: $tType,C: $tType,K2: set(B),K8: set(B),M: fun(B,option(C)),V: C] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),K2),K8)
     => map_le(B,C,map_mmupd(B,C,M,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),K2),dom(B,C,M)),V),map_mmupd(B,C,M,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),K8),dom(B,C,M)),V)) ) ).

% map_mmupd_update_less
tff(fact_3422_trancl__set__ntrancl,axiom,
    ! [B: $tType,Xsa: list(product_prod(B,B))] : transitive_trancl(B,aa(list(product_prod(B,B)),set(product_prod(B,B)),set2(product_prod(B,B)),Xsa)) = transitive_ntrancl(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(product_prod(B,B),aa(list(product_prod(B,B)),set(product_prod(B,B)),set2(product_prod(B,B)),Xsa))),one_one(nat)),aa(list(product_prod(B,B)),set(product_prod(B,B)),set2(product_prod(B,B)),Xsa)) ).

% trancl_set_ntrancl
tff(fact_3423_pred__nat__trancl__eq__le,axiom,
    ! [M: nat,N: nat] :
      ( member(product_prod(nat,nat),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),M),N),transitive_rtrancl(nat,pred_nat))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N) ) ).

% pred_nat_trancl_eq_le
tff(fact_3424_less__eq,axiom,
    ! [M: nat,N: nat] :
      ( member(product_prod(nat,nat),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),M),N),transitive_trancl(nat,pred_nat))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N) ) ).

% less_eq
tff(fact_3425_Gcd__fin__def,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ( semiring_gcd_Gcd_fin(B) = bounde2362111253966948842tice_F(B,gcd_gcd(B),zero_zero(B),one_one(B)) ) ) ).

% Gcd_fin_def
tff(fact_3426_relImage__def,axiom,
    ! [B: $tType,C: $tType,R4: set(product_prod(C,C)),F: fun(C,B)] : bNF_Gr4221423524335903396lImage(C,B,R4,F) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(C,B),fun(product_prod(B,B),$o),aTP_Lamp_oa(set(product_prod(C,C)),fun(fun(C,B),fun(product_prod(B,B),$o)),R4),F)) ).

% relImage_def
tff(fact_3427_set__map__filter,axiom,
    ! [B: $tType,C: $tType,G: fun(C,option(B)),Xsa: list(C)] : aa(list(B),set(B),set2(B),map_filter(C,B,G,Xsa)) = aa(fun(B,$o),set(B),collect(B),aa(list(C),fun(B,$o),aTP_Lamp_ob(fun(C,option(B)),fun(list(C),fun(B,$o)),G),Xsa)) ).

% set_map_filter
tff(fact_3428_ran__map__of,axiom,
    ! [B: $tType,C: $tType,Xsa: list(product_prod(C,B))] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),ran(C,B,map_of(C,B,Xsa))),aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),aa(list(product_prod(C,B)),set(product_prod(C,B)),set2(product_prod(C,B)),Xsa))) ).

% ran_map_of
tff(fact_3429_trancl__restrict__reachable,axiom,
    ! [B: $tType,U: B,V: B,E4: set(product_prod(B,B)),S2: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_trancl(B,E4))
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,E4,S2)),S2)
       => ( member(B,U,S2)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_trancl(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),E4),product_Sigma(B,B,S2,aTP_Lamp_ma(set(B),fun(B,set(B)),S2))))) ) ) ) ).

% trancl_restrict_reachable
tff(fact_3430_pair__vimage__is__Image,axiom,
    ! [B: $tType,C: $tType,U: C,E4: set(product_prod(C,B))] : aa(set(product_prod(C,B)),set(B),vimage(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),U)),E4) = image(C,B,E4,aa(set(C),set(C),insert2(C,U),bot_bot(set(C)))) ).

% pair_vimage_is_Image
tff(fact_3431_set__bind__option,axiom,
    ! [B: $tType,C: $tType,X2: option(C),F: fun(C,option(B))] : aa(option(B),set(B),set_option(B),aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),X2),F)) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(C),set(set(B)),image2(C,set(B),aa(fun(C,option(B)),fun(C,set(B)),aa(fun(option(B),set(B)),fun(fun(C,option(B)),fun(C,set(B))),comp(option(B),set(B),C),set_option(B)),F)),aa(option(C),set(C),set_option(C),X2))) ).

% set_bind_option
tff(fact_3432_ImageI,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,R: set(product_prod(B,C)),A4: set(B)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R)
     => ( member(B,A3,A4)
       => member(C,B2,image(B,C,R,A4)) ) ) ).

% ImageI
tff(fact_3433_elem__set,axiom,
    ! [B: $tType,X2: B,Xo: option(B)] :
      ( member(B,X2,aa(option(B),set(B),set_option(B),Xo))
    <=> ( Xo = aa(B,option(B),some(B),X2) ) ) ).

% elem_set
tff(fact_3434_set__empty__eq,axiom,
    ! [B: $tType,Xo: option(B)] :
      ( ( aa(option(B),set(B),set_option(B),Xo) = bot_bot(set(B)) )
    <=> ( Xo = none(B) ) ) ).

% set_empty_eq
tff(fact_3435_Image__singleton__iff,axiom,
    ! [B: $tType,C: $tType,B2: B,R: set(product_prod(C,B)),A3: C] :
      ( member(B,B2,image(C,B,R,aa(set(C),set(C),insert2(C,A3),bot_bot(set(C)))))
    <=> member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A3),B2),R) ) ).

% Image_singleton_iff
tff(fact_3436_rev__ImageI,axiom,
    ! [C: $tType,B: $tType,A3: B,A4: set(B),B2: C,R: set(product_prod(B,C))] :
      ( member(B,A3,A4)
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R)
       => member(C,B2,image(B,C,R,A4)) ) ) ).

% rev_ImageI
tff(fact_3437_Image__iff,axiom,
    ! [B: $tType,C: $tType,B2: B,R: set(product_prod(C,B)),A4: set(C)] :
      ( member(B,B2,image(C,B,R,A4))
    <=> ? [X4: C] :
          ( member(C,X4,A4)
          & member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X4),B2),R) ) ) ).

% Image_iff
tff(fact_3438_ImageE,axiom,
    ! [B: $tType,C: $tType,B2: B,R: set(product_prod(C,B)),A4: set(C)] :
      ( member(B,B2,image(C,B,R,A4))
     => ~ ! [X3: C] :
            ( member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X3),B2),R)
           => ~ member(C,X3,A4) ) ) ).

% ImageE
tff(fact_3439_ospec,axiom,
    ! [B: $tType,A4: option(B),P: fun(B,$o),X2: B] :
      ( ! [X3: B] :
          ( member(B,X3,aa(option(B),set(B),set_option(B),A4))
         => aa(B,$o,P,X3) )
     => ( ( A4 = aa(B,option(B),some(B),X2) )
       => aa(B,$o,P,X2) ) ) ).

% ospec
tff(fact_3440_option_Oset__intros,axiom,
    ! [B: $tType,X22: B] : member(B,X22,aa(option(B),set(B),set_option(B),aa(B,option(B),some(B),X22))) ).

% option.set_intros
tff(fact_3441_option_Oset__cases,axiom,
    ! [B: $tType,E2: B,A3: option(B)] :
      ( member(B,E2,aa(option(B),set(B),set_option(B),A3))
     => ( A3 = aa(B,option(B),some(B),E2) ) ) ).

% option.set_cases
tff(fact_3442_map__option__idI,axiom,
    ! [B: $tType,X2: option(B),F: fun(B,B)] :
      ( ! [Y4: B] :
          ( member(B,Y4,aa(option(B),set(B),set_option(B),X2))
         => ( aa(B,B,F,Y4) = Y4 ) )
     => ( aa(option(B),option(B),aa(fun(B,B),fun(option(B),option(B)),map_option(B,B),F),X2) = X2 ) ) ).

% map_option_idI
tff(fact_3443_option_Oinj__map__strong,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Xa: option(B),F: fun(B,C),Fa: fun(B,C)] :
      ( ! [Z3: B,Za: B] :
          ( member(B,Z3,aa(option(B),set(B),set_option(B),X2))
         => ( member(B,Za,aa(option(B),set(B),set_option(B),Xa))
           => ( ( aa(B,C,F,Z3) = aa(B,C,Fa,Za) )
             => ( Z3 = Za ) ) ) )
     => ( ( aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),X2) = aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),Fa),Xa) )
       => ( X2 = Xa ) ) ) ).

% option.inj_map_strong
tff(fact_3444_option_Omap__cong0,axiom,
    ! [C: $tType,B: $tType,X2: option(B),F: fun(B,C),G: fun(B,C)] :
      ( ! [Z3: B] :
          ( member(B,Z3,aa(option(B),set(B),set_option(B),X2))
         => ( aa(B,C,F,Z3) = aa(B,C,G,Z3) ) )
     => ( aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),X2) = aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),G),X2) ) ) ).

% option.map_cong0
tff(fact_3445_option_Omap__cong,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Ya: option(B),F: fun(B,C),G: fun(B,C)] :
      ( ( X2 = Ya )
     => ( ! [Z3: B] :
            ( member(B,Z3,aa(option(B),set(B),set_option(B),Ya))
           => ( aa(B,C,F,Z3) = aa(B,C,G,Z3) ) )
       => ( aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),X2) = aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),G),Ya) ) ) ) ).

% option.map_cong
tff(fact_3446_bind__option__cong,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Y: option(B),F: fun(B,option(C)),G: fun(B,option(C))] :
      ( ( X2 = Y )
     => ( ! [Z3: B] :
            ( member(B,Z3,aa(option(B),set(B),set_option(B),Y))
           => ( aa(B,option(C),F,Z3) = aa(B,option(C),G,Z3) ) )
       => ( aa(fun(B,option(C)),option(C),aa(option(B),fun(fun(B,option(C)),option(C)),bind(B,C),X2),F) = aa(fun(B,option(C)),option(C),aa(option(B),fun(fun(B,option(C)),option(C)),bind(B,C),Y),G) ) ) ) ).

% bind_option_cong
tff(fact_3447_rtrancl__image__advance__rtrancl,axiom,
    ! [B: $tType,Q3: B,R4: set(product_prod(B,B)),Q0: set(B),X2: B] :
      ( member(B,Q3,image(B,B,transitive_rtrancl(B,R4),Q0))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),X2),transitive_rtrancl(B,R4))
       => member(B,X2,image(B,B,transitive_rtrancl(B,R4),Q0)) ) ) ).

% rtrancl_image_advance_rtrancl
tff(fact_3448_rtrancl__image__advance,axiom,
    ! [B: $tType,Q3: B,R4: set(product_prod(B,B)),Q0: set(B),X2: B] :
      ( member(B,Q3,image(B,B,transitive_rtrancl(B,R4),Q0))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Q3),X2),R4)
       => member(B,X2,image(B,B,transitive_rtrancl(B,R4),Q0)) ) ) ).

% rtrancl_image_advance
tff(fact_3449_finite__Image__subset,axiom,
    ! [B: $tType,C: $tType,A4: set(product_prod(C,B)),B5: set(C),C5: set(product_prod(C,B))] :
      ( finite_finite2(B,image(C,B,A4,B5))
     => ( aa(set(product_prod(C,B)),$o,aa(set(product_prod(C,B)),fun(set(product_prod(C,B)),$o),ord_less_eq(set(product_prod(C,B))),C5),A4)
       => finite_finite2(B,image(C,B,C5,B5)) ) ) ).

% finite_Image_subset
tff(fact_3450_rtrancl__image__unfold__right,axiom,
    ! [B: $tType,E4: set(product_prod(B,B)),V5: set(B)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,E4,image(B,B,transitive_rtrancl(B,E4),V5))),image(B,B,transitive_rtrancl(B,E4),V5)) ).

% rtrancl_image_unfold_right
tff(fact_3451_rtrancl__reachable__induct,axiom,
    ! [B: $tType,I4: set(B),INV: set(B),E4: set(product_prod(B,B))] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),I4),INV)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,E4,INV)),INV)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,transitive_rtrancl(B,E4),I4)),INV) ) ) ).

% rtrancl_reachable_induct
tff(fact_3452_trancl__Image__unfold__right,axiom,
    ! [B: $tType,E4: set(product_prod(B,B)),S2: set(B)] : image(B,B,transitive_trancl(B,E4),S2) = image(B,B,E4,image(B,B,transitive_rtrancl(B,E4),S2)) ).

% trancl_Image_unfold_right
tff(fact_3453_trancl__Image__unfold__left,axiom,
    ! [B: $tType,E4: set(product_prod(B,B)),S2: set(B)] : image(B,B,transitive_trancl(B,E4),S2) = image(B,B,transitive_rtrancl(B,E4),image(B,B,E4,S2)) ).

% trancl_Image_unfold_left
tff(fact_3454_option_Osimps_I14_J,axiom,
    ! [B: $tType] : aa(option(B),set(B),set_option(B),none(B)) = bot_bot(set(B)) ).

% option.simps(14)
tff(fact_3455_option_Oset__map,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),V: option(C)] : aa(option(B),set(B),set_option(B),aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),V)) = aa(set(C),set(B),image2(C,B,F),aa(option(C),set(C),set_option(C),V)) ).

% option.set_map
tff(fact_3456_option_Oset__sel,axiom,
    ! [B: $tType,A3: option(B)] :
      ( ( A3 != none(B) )
     => member(B,aa(option(B),B,the2(B),A3),aa(option(B),set(B),set_option(B),A3)) ) ).

% option.set_sel
tff(fact_3457_Image__empty__rtrancl__Image__id,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),V: B] :
      ( ( image(B,B,R4,aa(set(B),set(B),insert2(B,V),bot_bot(set(B)))) = bot_bot(set(B)) )
     => ( image(B,B,transitive_rtrancl(B,R4),aa(set(B),set(B),insert2(B,V),bot_bot(set(B)))) = aa(set(B),set(B),insert2(B,V),bot_bot(set(B))) ) ) ).

% Image_empty_rtrancl_Image_id
tff(fact_3458_Image__empty__trancl__Image__empty,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),V: B] :
      ( ( image(B,B,R4,aa(set(B),set(B),insert2(B,V),bot_bot(set(B)))) = bot_bot(set(B)) )
     => ( image(B,B,transitive_trancl(B,R4),aa(set(B),set(B),insert2(B,V),bot_bot(set(B)))) = bot_bot(set(B)) ) ) ).

% Image_empty_trancl_Image_empty
tff(fact_3459_reachable__mono,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),R6: set(product_prod(B,B)),X7: set(B),X8: set(B)] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),R6)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),X7),X8)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,transitive_rtrancl(B,R4),X7)),image(B,B,transitive_rtrancl(B,R6),X8)) ) ) ).

% reachable_mono
tff(fact_3460_Image__subset__snd__image,axiom,
    ! [B: $tType,C: $tType,A4: set(product_prod(C,B)),B5: set(C)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(C,B,A4,B5)),aa(set(product_prod(C,B)),set(B),image2(product_prod(C,B),B,product_snd(C,B)),A4)) ).

% Image_subset_snd_image
tff(fact_3461_trancl__image__by__rtrancl,axiom,
    ! [B: $tType,E4: set(product_prod(B,B)),Vi: set(B)] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),image(B,B,transitive_trancl(B,E4),Vi)),Vi) = image(B,B,transitive_rtrancl(B,E4),Vi) ).

% trancl_image_by_rtrancl
tff(fact_3462_weak__map__of__SomeI,axiom,
    ! [B: $tType,C: $tType,K: B,X2: C,L: list(product_prod(B,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),X2),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),L))
     => ? [X3: C] : aa(B,option(C),map_of(B,C,L),K) = aa(C,option(C),some(C),X3) ) ).

% weak_map_of_SomeI
tff(fact_3463_map__of__SomeD,axiom,
    ! [B: $tType,C: $tType,Xsa: list(product_prod(C,B)),K: C,Y: B] :
      ( ( aa(C,option(B),map_of(C,B,Xsa),K) = aa(B,option(B),some(B),Y) )
     => member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),K),Y),aa(list(product_prod(C,B)),set(product_prod(C,B)),set2(product_prod(C,B)),Xsa)) ) ).

% map_of_SomeD
tff(fact_3464_Image__singleton,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(C,B)),A3: C] : image(C,B,R,aa(set(C),set(C),insert2(C,A3),bot_bot(set(C)))) = aa(fun(B,$o),set(B),collect(B),aa(C,fun(B,$o),aTP_Lamp_au(set(product_prod(C,B)),fun(C,fun(B,$o)),R),A3)) ).

% Image_singleton
tff(fact_3465_option_Osimps_I15_J,axiom,
    ! [B: $tType,X22: B] : aa(option(B),set(B),set_option(B),aa(B,option(B),some(B),X22)) = aa(set(B),set(B),insert2(B,X22),bot_bot(set(B))) ).

% option.simps(15)
tff(fact_3466_rtrancl__apply__insert,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),X2: B,S2: set(B)] : image(B,B,transitive_rtrancl(B,R4),aa(set(B),set(B),insert2(B,X2),S2)) = aa(set(B),set(B),insert2(B,X2),image(B,B,transitive_rtrancl(B,R4),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),S2),image(B,B,R4,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))))))) ).

% rtrancl_apply_insert
tff(fact_3467_rtrancl__Image__in__Field,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),V5: set(B)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,transitive_rtrancl(B,R4),V5)),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),field2(B,R4)),V5)) ).

% rtrancl_Image_in_Field
tff(fact_3468_E__closed__restr__reach__cases,axiom,
    ! [B: $tType,U: B,V: B,E4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_rtrancl(B,E4))
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,E4,R4)),R4)
       => ( ~ member(B,V,R4)
         => ~ ( ~ member(B,U,R4)
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),transitive_rtrancl(B,rel_restrict(B,E4,R4))) ) ) ) ) ).

% E_closed_restr_reach_cases
tff(fact_3469_rel__restrict__tranclI,axiom,
    ! [B: $tType,X2: B,Y: B,E4: set(product_prod(B,B)),R4: set(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,E4))
     => ( ~ member(B,X2,R4)
       => ( ~ member(B,Y,R4)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,E4,R4)),R4)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,rel_restrict(B,E4,R4))) ) ) ) ) ).

% rel_restrict_tranclI
tff(fact_3470_refl__on__reflcl__Image,axiom,
    ! [B: $tType,B5: set(B),A4: set(product_prod(B,B)),C5: set(B)] :
      ( refl_on(B,B5,A4)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),C5),B5)
       => ( image(B,B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),A4),id2(B)),C5) = image(B,B,A4,C5) ) ) ) ).

% refl_on_reflcl_Image
tff(fact_3471_map__of__eq__None__iff,axiom,
    ! [B: $tType,C: $tType,Xys: list(product_prod(C,B)),X2: C] :
      ( ( aa(C,option(B),map_of(C,B,Xys),X2) = none(B) )
    <=> ~ member(C,X2,aa(set(product_prod(C,B)),set(C),image2(product_prod(C,B),C,product_fst(C,B)),aa(list(product_prod(C,B)),set(product_prod(C,B)),set2(product_prod(C,B)),Xys))) ) ).

% map_of_eq_None_iff
tff(fact_3472_finite__reachable__advance,axiom,
    ! [B: $tType,E4: set(product_prod(B,B)),V0: B,V: B] :
      ( finite_finite2(B,image(B,B,transitive_rtrancl(B,E4),aa(set(B),set(B),insert2(B,V0),bot_bot(set(B)))))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),V0),V),transitive_rtrancl(B,E4))
       => finite_finite2(B,image(B,B,transitive_rtrancl(B,E4),aa(set(B),set(B),insert2(B,V),bot_bot(set(B))))) ) ) ).

% finite_reachable_advance
tff(fact_3473_rtrancl__Image__advance__ss,axiom,
    ! [B: $tType,U: B,V: B,E4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),E4)
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,transitive_rtrancl(B,E4),aa(set(B),set(B),insert2(B,V),bot_bot(set(B))))),image(B,B,transitive_rtrancl(B,E4),aa(set(B),set(B),insert2(B,U),bot_bot(set(B))))) ) ).

% rtrancl_Image_advance_ss
tff(fact_3474_trancl__Image__advance__ss,axiom,
    ! [B: $tType,U: B,V: B,E4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),U),V),E4)
     => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,transitive_trancl(B,E4),aa(set(B),set(B),insert2(B,V),bot_bot(set(B))))),image(B,B,transitive_trancl(B,E4),aa(set(B),set(B),insert2(B,U),bot_bot(set(B))))) ) ).

% trancl_Image_advance_ss
tff(fact_3475_subset__Image1__Image1__iff,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( order_preorder_on(B,field2(B,R),R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B))))),image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))))
          <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),R) ) ) ) ) ).

% subset_Image1_Image1_iff
tff(fact_3476_map__of__distinct__upd,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(product_prod(B,C)),Y: C] :
      ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa)))
     => ( map_add(B,C,fun_upd(B,option(C),aTP_Lamp_hj(B,option(C)),X2,aa(C,option(C),some(C),Y)),map_of(B,C,Xsa)) = fun_upd(B,option(C),map_of(B,C,Xsa),X2,aa(C,option(C),some(C),Y)) ) ) ).

% map_of_distinct_upd
tff(fact_3477_subset__Image__Image__iff,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B),B5: set(B)] :
      ( order_preorder_on(B,field2(B,R),R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),field2(B,R))
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),field2(B,R))
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,R,A4)),image(B,B,R,B5))
          <=> ! [X4: B] :
                ( member(B,X4,A4)
               => ? [Xa2: B] :
                    ( member(B,Xa2,B5)
                    & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),R) ) ) ) ) ) ) ).

% subset_Image_Image_iff
tff(fact_3478_map__of__map__restrict,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),Ks: list(B)] : map_of(B,C,aa(list(B),list(product_prod(B,C)),map(B,product_prod(B,C),aTP_Lamp_ng(fun(B,C),fun(B,product_prod(B,C)),F)),Ks)) = restrict_map(B,C,aa(fun(B,C),fun(B,option(C)),aa(fun(C,option(C)),fun(fun(B,C),fun(B,option(C))),comp(C,option(C),B),some(C)),F),aa(list(B),set(B),set2(B),Ks)) ).

% map_of_map_restrict
tff(fact_3479_map__of__mapk__SomeI,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),T2: list(product_prod(B,D)),K: B,X2: D] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( ( aa(B,option(D),map_of(B,D,T2),K) = aa(D,option(D),some(D),X2) )
       => ( aa(C,option(D),map_of(C,D,aa(list(product_prod(B,D)),list(product_prod(C,D)),map(product_prod(B,D),product_prod(C,D),aa(fun(B,fun(D,product_prod(C,D))),fun(product_prod(B,D),product_prod(C,D)),product_case_prod(B,D,product_prod(C,D)),aTP_Lamp_oc(fun(B,C),fun(B,fun(D,product_prod(C,D))),F))),T2)),aa(B,C,F,K)) = aa(D,option(D),some(D),X2) ) ) ) ).

% map_of_mapk_SomeI
tff(fact_3480_map__comp__map,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),G: fun(B,D)] : aa(fun(list(B),list(D)),fun(list(B),list(C)),aa(fun(list(D),list(C)),fun(fun(list(B),list(D)),fun(list(B),list(C))),comp(list(D),list(C),list(B)),map(D,C,F)),map(B,D,G)) = map(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G)) ).

% map_comp_map
tff(fact_3481_map__map,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(D,C),Xsa: list(D)] : aa(list(C),list(B),map(C,B,F),aa(list(D),list(C),map(D,C,G),Xsa)) = aa(list(D),list(B),map(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G)),Xsa) ).

% map_map
tff(fact_3482_List_Omap_Ocompositionality,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(D,C),List: list(D)] : aa(list(C),list(B),map(C,B,F),aa(list(D),list(C),map(D,C,G),List)) = aa(list(D),list(B),map(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G)),List) ).

% List.map.compositionality
tff(fact_3483_list_Omap__comp,axiom,
    ! [C: $tType,B: $tType,D: $tType,G: fun(C,B),F: fun(D,C),V: list(D)] : aa(list(C),list(B),map(C,B,G),aa(list(D),list(C),map(D,C,F),V)) = aa(list(D),list(B),map(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),V) ).

% list.map_comp
tff(fact_3484_List_Omap_Ocomp,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),G: fun(B,D)] : aa(fun(list(B),list(D)),fun(list(B),list(C)),aa(fun(list(D),list(C)),fun(fun(list(B),list(D)),fun(list(B),list(C))),comp(list(D),list(C),list(B)),map(D,C,F)),map(B,D,G)) = map(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G)) ).

% List.map.comp
tff(fact_3485_map__fst__mk__snd,axiom,
    ! [C: $tType,B: $tType,K: C,L: list(B)] : aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),aa(list(B),list(product_prod(B,C)),map(B,product_prod(B,C),aa(C,fun(B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))),K)),L)) = L ).

% map_fst_mk_snd
tff(fact_3486_map__snd__mk__fst,axiom,
    ! [C: $tType,B: $tType,K: C,L: list(B)] : aa(list(product_prod(C,B)),list(B),map(product_prod(C,B),B,product_snd(C,B)),aa(list(B),list(product_prod(C,B)),map(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),K)),L)) = L ).

% map_snd_mk_fst
tff(fact_3487_set__oo__map__alt,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),X: list(B)] : aa(list(B),set(C),aa(fun(list(B),list(C)),fun(list(B),set(C)),aa(fun(list(C),set(C)),fun(fun(list(B),list(C)),fun(list(B),set(C))),comp(list(C),set(C),list(B)),set2(C)),map(B,C,F)),X) = aa(set(B),set(C),image2(B,C,F),aa(list(B),set(B),set2(B),X)) ).

% set_oo_map_alt
tff(fact_3488_Id__on__set,axiom,
    ! [B: $tType,Xsa: list(B)] : id_on(B,aa(list(B),set(B),set2(B),Xsa)) = aa(list(product_prod(B,B)),set(product_prod(B,B)),set2(product_prod(B,B)),aa(list(B),list(product_prod(B,B)),map(B,product_prod(B,B),aTP_Lamp_je(B,product_prod(B,B))),Xsa)) ).

% Id_on_set
tff(fact_3489_map__of__map__keys,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),M: fun(B,option(C))] :
      ( ( aa(list(B),set(B),set2(B),Xsa) = dom(B,C,M) )
     => ( map_of(B,C,aa(list(B),list(product_prod(B,C)),map(B,product_prod(B,C),aTP_Lamp_ny(fun(B,option(C)),fun(B,product_prod(B,C)),M)),Xsa)) = M ) ) ).

% map_of_map_keys
tff(fact_3490_map__of__map,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),Xsa: list(product_prod(B,D))] : map_of(B,C,aa(list(product_prod(B,D)),list(product_prod(B,C)),map(product_prod(B,D),product_prod(B,C),aa(fun(B,fun(D,product_prod(B,C))),fun(product_prod(B,D),product_prod(B,C)),product_case_prod(B,D,product_prod(B,C)),aTP_Lamp_od(fun(D,C),fun(B,fun(D,product_prod(B,C))),F))),Xsa)) = aa(fun(B,option(D)),fun(B,option(C)),aa(fun(option(D),option(C)),fun(fun(B,option(D)),fun(B,option(C))),comp(option(D),option(C),B),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),F)),map_of(B,D,Xsa)) ).

% map_of_map
tff(fact_3491_inj__on__map__inv__f,axiom,
    ! [C: $tType,B: $tType,L: list(B),A4: set(B),F: fun(B,C)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),L)),A4)
     => ( inj_on(B,C,F,A4)
       => ( aa(list(C),list(B),map(C,B,inv_on(B,C,F,A4)),aa(list(B),list(C),map(B,C,F),L)) = L ) ) ) ).

% inj_on_map_inv_f
tff(fact_3492_Misc_Oran__distinct,axiom,
    ! [C: $tType,B: $tType,Al: list(product_prod(B,C))] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Al))
     => ( ran(B,C,map_of(B,C,Al)) = aa(set(product_prod(B,C)),set(C),image2(product_prod(B,C),C,product_snd(B,C)),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Al)) ) ) ).

% Misc.ran_distinct
tff(fact_3493_map__of__eq__Some__iff,axiom,
    ! [C: $tType,B: $tType,Xys: list(product_prod(B,C)),X2: B,Y: C] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xys))
     => ( ( aa(B,option(C),map_of(B,C,Xys),X2) = aa(C,option(C),some(C),Y) )
      <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xys)) ) ) ).

% map_of_eq_Some_iff
tff(fact_3494_Some__eq__map__of__iff,axiom,
    ! [C: $tType,B: $tType,Xys: list(product_prod(B,C)),Y: C,X2: B] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xys))
     => ( ( aa(C,option(C),some(C),Y) = aa(B,option(C),map_of(B,C,Xys),X2) )
      <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xys)) ) ) ).

% Some_eq_map_of_iff
tff(fact_3495_map__of__is__SomeI,axiom,
    ! [B: $tType,C: $tType,Xys: list(product_prod(B,C)),X2: B,Y: C] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xys))
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xys))
       => ( aa(B,option(C),map_of(B,C,Xys),X2) = aa(C,option(C),some(C),Y) ) ) ) ).

% map_of_is_SomeI
tff(fact_3496_inv__on__f__f,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),X2: B] :
      ( inj_on(B,C,F,A4)
     => ( member(B,X2,A4)
       => ( aa(C,B,inv_on(B,C,F,A4),aa(B,C,F,X2)) = X2 ) ) ) ).

% inv_on_f_f
tff(fact_3497_distinct__mapI,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),L: list(C)] :
      ( distinct(B,aa(list(C),list(B),map(C,B,F),L))
     => distinct(C,L) ) ).

% distinct_mapI
tff(fact_3498_distinct__finite__set,axiom,
    ! [B: $tType,X2: set(B)] : finite_finite2(list(B),aa(fun(list(B),$o),set(list(B)),collect(list(B)),aTP_Lamp_oe(set(B),fun(list(B),$o),X2))) ).

% distinct_finite_set
tff(fact_3499_distinct__map__eq,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),L: list(C),X2: C,Y: C] :
      ( distinct(B,aa(list(C),list(B),map(C,B,F),L))
     => ( ( aa(C,B,F,X2) = aa(C,B,F,Y) )
       => ( member(C,X2,aa(list(C),set(C),set2(C),L))
         => ( member(C,Y,aa(list(C),set(C),set2(C),L))
           => ( X2 = Y ) ) ) ) ) ).

% distinct_map_eq
tff(fact_3500_finite__set__image,axiom,
    ! [B: $tType,A4: set(list(B))] :
      ( finite_finite2(set(B),aa(set(list(B)),set(set(B)),image2(list(B),set(B),set2(B)),A4))
     => ( ! [Xs: list(B)] :
            ( member(list(B),Xs,A4)
           => distinct(B,Xs) )
       => finite_finite2(list(B),A4) ) ) ).

% finite_set_image
tff(fact_3501_inv__on__f__range,axiom,
    ! [B: $tType,C: $tType,Y: B,F: fun(C,B),A4: set(C)] :
      ( member(B,Y,aa(set(C),set(B),image2(C,B,F),A4))
     => member(C,aa(B,C,inv_on(C,B,F,A4),Y),A4) ) ).

% inv_on_f_range
tff(fact_3502_f__inv__on__f,axiom,
    ! [C: $tType,B: $tType,Y: B,F: fun(C,B),A4: set(C)] :
      ( member(B,Y,aa(set(C),set(B),image2(C,B,F),A4))
     => ( aa(C,B,F,aa(B,C,inv_on(C,B,F,A4),Y)) = Y ) ) ).

% f_inv_on_f
tff(fact_3503_distinct__finite__subset,axiom,
    ! [B: $tType,X2: set(B)] :
      ( finite_finite2(B,X2)
     => finite_finite2(list(B),aa(fun(list(B),$o),set(list(B)),collect(list(B)),aTP_Lamp_of(set(B),fun(list(B),$o),X2))) ) ).

% distinct_finite_subset
tff(fact_3504_distinct__map__fstD,axiom,
    ! [B: $tType,C: $tType,Xsa: list(product_prod(B,C)),X2: B,Y: C,Z2: C] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa))
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xsa))
       => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Z2),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xsa))
         => ( Y = Z2 ) ) ) ) ).

% distinct_map_fstD
tff(fact_3505_eq__key__imp__eq__value,axiom,
    ! [B: $tType,C: $tType,Xsa: list(product_prod(B,C)),K: B,V1: C,V22: C] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa))
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V1),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xsa))
       => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K),V22),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xsa))
         => ( V1 = V22 ) ) ) ) ).

% eq_key_imp_eq_value
tff(fact_3506_map__to__set__map__of,axiom,
    ! [C: $tType,B: $tType,L: list(product_prod(B,C))] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),L))
     => ( map_to_set(B,C,map_of(B,C,L)) = aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),L) ) ) ).

% map_to_set_map_of
tff(fact_3507_map__of__map__to__set,axiom,
    ! [C: $tType,B: $tType,L: list(product_prod(B,C)),M: fun(B,option(C))] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),L))
     => ( ( map_of(B,C,L) = M )
      <=> ( aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),L) = map_to_set(B,C,M) ) ) ) ).

% map_of_map_to_set
tff(fact_3508_set__map__of__compr,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(B,C))] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa))
     => ( aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),Xsa) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_og(list(product_prod(B,C)),fun(B,fun(C,$o)),Xsa))) ) ) ).

% set_map_of_compr
tff(fact_3509_card__lists__distinct__length__eq,axiom,
    ! [B: $tType,A4: set(B),K: nat] :
      ( finite_finite2(B,A4)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),K),finite_card(B,A4))
       => ( finite_card(list(B),aa(fun(list(B),$o),set(list(B)),collect(list(B)),aa(nat,fun(list(B),$o),aTP_Lamp_oh(set(B),fun(nat,fun(list(B),$o)),A4),K))) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),aTP_Lamp_bz(nat,nat)),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,A4)),K)),one_one(nat)),finite_card(B,A4))) ) ) ) ).

% card_lists_distinct_length_eq
tff(fact_3510_card__lists__distinct__length__eq_H,axiom,
    ! [B: $tType,K: nat,A4: set(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),finite_card(B,A4))
     => ( finite_card(list(B),aa(fun(list(B),$o),set(list(B)),collect(list(B)),aa(set(B),fun(list(B),$o),aTP_Lamp_oi(nat,fun(set(B),fun(list(B),$o)),K),A4))) = aa(set(nat),nat,aa(fun(nat,nat),fun(set(nat),nat),groups7121269368397514597t_prod(nat,nat),aTP_Lamp_bz(nat,nat)),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),finite_card(B,A4)),K)),one_one(nat)),finite_card(B,A4))) ) ) ).

% card_lists_distinct_length_eq'
tff(fact_3511_distinct__foldl__invar,axiom,
    ! [C: $tType,B: $tType,S2: list(B),I4: fun(set(B),fun(C,$o)),Sigma_0: C,F: fun(C,fun(B,C))] :
      ( distinct(B,S2)
     => ( aa(C,$o,aa(set(B),fun(C,$o),I4,aa(list(B),set(B),set2(B),S2)),Sigma_0)
       => ( ! [X3: B,It: set(B),Sigma: C] :
              ( member(B,X3,It)
             => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),It),aa(list(B),set(B),set2(B),S2))
               => ( aa(C,$o,aa(set(B),fun(C,$o),I4,It),Sigma)
                 => aa(C,$o,aa(set(B),fun(C,$o),I4,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),It),aa(set(B),set(B),insert2(B,X3),bot_bot(set(B))))),aa(B,C,aa(C,fun(B,C),F,Sigma),X3)) ) ) )
         => aa(C,$o,aa(set(B),fun(C,$o),I4,bot_bot(set(B))),aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,F),Sigma_0),S2)) ) ) ) ).

% distinct_foldl_invar
tff(fact_3512_map__of__Some__filter__not__in,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(C,B)),K: C,V: B,P: fun(product_prod(C,B),$o)] :
      ( ( aa(C,option(B),map_of(C,B,Xsa),K) = aa(B,option(B),some(B),V) )
     => ( ~ aa(product_prod(C,B),$o,P,aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),K),V))
       => ( distinct(C,aa(list(product_prod(C,B)),list(C),map(product_prod(C,B),C,product_fst(C,B)),Xsa))
         => ( aa(C,option(B),map_of(C,B,filter(product_prod(C,B),P,Xsa)),K) = none(B) ) ) ) ) ).

% map_of_Some_filter_not_in
tff(fact_3513_map__add__map__of__foldr,axiom,
    ! [C: $tType,B: $tType,M: fun(B,option(C)),Ps: list(product_prod(B,C))] : map_add(B,C,M,map_of(B,C,Ps)) = aa(fun(B,option(C)),fun(B,option(C)),foldr(product_prod(B,C),fun(B,option(C)),aa(fun(B,fun(C,fun(fun(B,option(C)),fun(B,option(C))))),fun(product_prod(B,C),fun(fun(B,option(C)),fun(B,option(C)))),product_case_prod(B,C,fun(fun(B,option(C)),fun(B,option(C)))),aTP_Lamp_oj(B,fun(C,fun(fun(B,option(C)),fun(B,option(C)))))),Ps),M) ).

% map_add_map_of_foldr
tff(fact_3514_foldl__length,axiom,
    ! [B: $tType,L: list(B)] : aa(list(B),nat,aa(nat,fun(list(B),nat),foldl(nat,B,aTP_Lamp_ok(nat,fun(B,nat))),zero_zero(nat)),L) = aa(list(B),nat,size_size(list(B)),L) ).

% foldl_length
tff(fact_3515_foldl__length__aux,axiom,
    ! [B: $tType,A3: nat,L: list(B)] : aa(list(B),nat,aa(nat,fun(list(B),nat),foldl(nat,B,aTP_Lamp_ok(nat,fun(B,nat))),A3),L) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),aa(list(B),nat,size_size(list(B)),L)) ).

% foldl_length_aux
tff(fact_3516_foldl__A1__eq,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),N: B,I: B,Ww: list(B)] :
      ( ! [E3: B] : aa(B,B,aa(B,fun(B,B),F,N),E3) = E3
     => ( ! [E3: B] : aa(B,B,aa(B,fun(B,B),F,E3),N) = E3
       => ( ! [A5: B,B3: B,C3: B] : aa(B,B,aa(B,fun(B,B),F,A5),aa(B,B,aa(B,fun(B,B),F,B3),C3)) = aa(B,B,aa(B,fun(B,B),F,aa(B,B,aa(B,fun(B,B),F,A5),B3)),C3)
         => ( aa(list(B),B,aa(B,fun(list(B),B),foldl(B,B,F),I),Ww) = aa(B,B,aa(B,fun(B,B),F,I),aa(list(B),B,aa(B,fun(list(B),B),foldl(B,B,F),N),Ww)) ) ) ) ) ).

% foldl_A1_eq
tff(fact_3517_sum__length__filter__compl,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B)] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),filter(B,P,Xsa))),aa(list(B),nat,size_size(list(B)),filter(B,aTP_Lamp_ol(fun(B,$o),fun(B,$o),P),Xsa))) = aa(list(B),nat,size_size(list(B)),Xsa) ).

% sum_length_filter_compl
tff(fact_3518_comp__fun__commute_Ofoldr__conv__foldl,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C)),Xsa: list(B),A3: C] :
      ( finite6289374366891150609ommute(B,C,F)
     => ( aa(C,C,foldr(B,C,F,Xsa),A3) = aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,aTP_Lamp_om(fun(B,fun(C,C)),fun(C,fun(B,C)),F)),A3),Xsa) ) ) ).

% comp_fun_commute.foldr_conv_foldl
tff(fact_3519_comp__fun__commute_Ofoldl__f__commute,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C)),A3: B,B2: C,Xsa: list(B)] :
      ( finite6289374366891150609ommute(B,C,F)
     => ( aa(C,C,aa(B,fun(C,C),F,A3),aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,aTP_Lamp_om(fun(B,fun(C,C)),fun(C,fun(B,C)),F)),B2),Xsa)) = aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,aTP_Lamp_om(fun(B,fun(C,C)),fun(C,fun(B,C)),F)),aa(C,C,aa(B,fun(C,C),F,A3),B2)),Xsa) ) ) ).

% comp_fun_commute.foldl_f_commute
tff(fact_3520_map__of__None__filterD,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(C,B)),X2: C,P: fun(product_prod(C,B),$o)] :
      ( ( aa(C,option(B),map_of(C,B,Xsa),X2) = none(B) )
     => ( aa(C,option(B),map_of(C,B,filter(product_prod(C,B),P,Xsa)),X2) = none(B) ) ) ).

% map_of_None_filterD
tff(fact_3521_fst__foldl,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(B,fun(D,B)),G: fun(B,fun(C,fun(D,C))),A3: B,B2: C,Xsa: list(D)] : aa(product_prod(B,C),B,product_fst(B,C),aa(list(D),product_prod(B,C),aa(product_prod(B,C),fun(list(D),product_prod(B,C)),foldl(product_prod(B,C),D,aa(fun(B,fun(C,fun(D,product_prod(B,C)))),fun(product_prod(B,C),fun(D,product_prod(B,C))),product_case_prod(B,C,fun(D,product_prod(B,C))),aa(fun(B,fun(C,fun(D,C))),fun(B,fun(C,fun(D,product_prod(B,C)))),aTP_Lamp_on(fun(B,fun(D,B)),fun(fun(B,fun(C,fun(D,C))),fun(B,fun(C,fun(D,product_prod(B,C))))),F),G))),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)),Xsa)) = aa(list(D),B,aa(B,fun(list(D),B),foldl(B,D,F),A3),Xsa) ).

% fst_foldl
tff(fact_3522_foldl__absorb1,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [X2: B,Zs: list(B)] : aa(B,B,aa(B,fun(B,B),times_times(B),X2),aa(list(B),B,aa(B,fun(list(B),B),foldl(B,B,times_times(B)),one_one(B)),Zs)) = aa(list(B),B,aa(B,fun(list(B),B),foldl(B,B,times_times(B)),X2),Zs) ) ).

% foldl_absorb1
tff(fact_3523_foldl__un__empty__eq,axiom,
    ! [B: $tType,I: set(B),Ww: list(set(B))] : aa(list(set(B)),set(B),aa(set(B),fun(list(set(B)),set(B)),foldl(set(B),set(B),sup_sup(set(B))),I),Ww) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),I),aa(list(set(B)),set(B),aa(set(B),fun(list(set(B)),set(B)),foldl(set(B),set(B),sup_sup(set(B))),bot_bot(set(B))),Ww)) ).

% foldl_un_empty_eq
tff(fact_3524_distinct__map__fst__filterI,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(B,C)),P: fun(product_prod(B,C),$o)] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa))
     => distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),filter(product_prod(B,C),P,Xsa))) ) ).

% distinct_map_fst_filterI
tff(fact_3525_map__of__filter__in,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(C,B)),K: C,Z2: B,P: fun(C,fun(B,$o))] :
      ( ( aa(C,option(B),map_of(C,B,Xsa),K) = aa(B,option(B),some(B),Z2) )
     => ( aa(B,$o,aa(C,fun(B,$o),P,K),Z2)
       => ( aa(C,option(B),map_of(C,B,filter(product_prod(C,B),aa(fun(C,fun(B,$o)),fun(product_prod(C,B),$o),product_case_prod(C,B,$o),P),Xsa)),K) = aa(B,option(B),some(B),Z2) ) ) ) ).

% map_of_filter_in
tff(fact_3526_distinct__length__le,axiom,
    ! [B: $tType,Ys: list(B),Xsa: list(B)] :
      ( distinct(B,Ys)
     => ( ( aa(list(B),set(B),set2(B),Ys) = aa(list(B),set(B),set2(B),Xsa) )
       => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Ys)),aa(list(B),nat,size_size(list(B)),Xsa)) ) ) ).

% distinct_length_le
tff(fact_3527_foldl__set,axiom,
    ! [B: $tType,L: list(set(B))] : aa(list(set(B)),set(B),aa(set(B),fun(list(set(B)),set(B)),foldl(set(B),set(B),sup_sup(set(B))),bot_bot(set(B))),L) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(fun(set(B),$o),set(set(B)),collect(set(B)),aTP_Lamp_oo(list(set(B)),fun(set(B),$o),L))) ).

% foldl_set
tff(fact_3528_map__filter__map__filter,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),P: fun(C,$o),Xsa: list(C)] : aa(list(C),list(B),map(C,B,F),filter(C,P,Xsa)) = map_filter(C,B,aa(fun(C,$o),fun(C,option(B)),aTP_Lamp_op(fun(C,B),fun(fun(C,$o),fun(C,option(B))),F),P),Xsa) ).

% map_filter_map_filter
tff(fact_3529_map__filter__def,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),Xsa: list(C)] : map_filter(C,B,F,Xsa) = aa(list(C),list(B),map(C,B,aa(fun(C,option(B)),fun(C,B),aa(fun(option(B),B),fun(fun(C,option(B)),fun(C,B)),comp(option(B),B,C),the2(B)),F)),filter(C,aTP_Lamp_oq(fun(C,option(B)),fun(C,$o),F),Xsa)) ).

% map_filter_def
tff(fact_3530_execute__of__list,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),array_of_list(B,Xsa)),Ha) = aa(product_prod(array(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(array(B),heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_or(list(B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Xsa)),array_alloc(B,Xsa,Ha))) ) ).

% execute_of_list
tff(fact_3531_mergesort__by__rel__split__length,axiom,
    ! [B: $tType,Xs1: list(B),Xs2: list(B),Xsa: list(B)] :
      ( ( aa(list(B),nat,size_size(list(B)),aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),Xsa))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xs1)),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) )
      & ( aa(list(B),nat,size_size(list(B)),aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),Xsa))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xs2)),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) ) ) ).

% mergesort_by_rel_split_length
tff(fact_3532_card__disjoint__shuffles,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] :
      ( ( aa(set(B),set(B),inf_inf(set(B),aa(list(B),set(B),set2(B),Xsa)),aa(list(B),set(B),set2(B),Ys)) = bot_bot(set(B)) )
     => ( finite_card(list(B),shuffles(B,Xsa,Ys)) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(list(B),nat,size_size(list(B)),Ys))),aa(list(B),nat,size_size(list(B)),Xsa)) ) ) ).

% card_disjoint_shuffles
tff(fact_3533_of__list__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B)] : array_of_list(B,Xsa) = heap_Time_heap(array(B),aTP_Lamp_os(list(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),Xsa)) ) ).

% of_list_def
tff(fact_3534_slice__len,axiom,
    ! [B: $tType,From: nat,To: nat,Xsa: list(B)] :
      ( 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(B),nat,size_size(list(B)),Xsa))
       => ( aa(list(B),nat,size_size(list(B)),slice(B,From,To,Xsa)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),To),From) ) ) ) ).

% slice_len
tff(fact_3535_slice__complete,axiom,
    ! [B: $tType,Xsa: list(B)] : slice(B,zero_zero(nat),aa(list(B),nat,size_size(list(B)),Xsa),Xsa) = Xsa ).

% slice_complete
tff(fact_3536_foldr__length,axiom,
    ! [B: $tType,L: list(B)] : aa(nat,nat,foldr(B,nat,aTP_Lamp_ot(B,fun(nat,nat)),L),zero_zero(nat)) = aa(list(B),nat,size_size(list(B)),L) ).

% foldr_length
tff(fact_3537_length__shuffles,axiom,
    ! [B: $tType,Zs: list(B),Xsa: list(B),Ys: list(B)] :
      ( member(list(B),Zs,shuffles(B,Xsa,Ys))
     => ( aa(list(B),nat,size_size(list(B)),Zs) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(list(B),nat,size_size(list(B)),Ys)) ) ) ).

% length_shuffles
tff(fact_3538_foldr__length__aux,axiom,
    ! [B: $tType,L: list(B),A3: nat] : aa(nat,nat,foldr(B,nat,aTP_Lamp_ot(B,fun(nat,nat)),L),A3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),A3),aa(list(B),nat,size_size(list(B)),L)) ).

% foldr_length_aux
tff(fact_3539_effect__of__listI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),H2: heap_ext(product_unit),Xsa: list(B),Ha: heap_ext(product_unit)] :
          ( ( aa(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit))),product_Pair(array(B),heap_ext(product_unit)),A3),H2) = array_alloc(B,Xsa,Ha) )
         => heap_Time_effect(array(B),array_of_list(B,Xsa),Ha,H2,A3,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),aa(list(B),nat,size_size(list(B)),Xsa))) ) ) ).

% effect_of_listI
tff(fact_3540_execute__make,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,F: fun(nat,B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),array_make(B,N,F)),Ha) = aa(product_prod(array(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(array(B),heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ou(nat,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),N)),array_alloc(B,aa(list(nat),list(B),map(nat,B,F),upt(zero_zero(nat),N)),Ha))) ) ).

% execute_make
tff(fact_3541_execute__new,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B,Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2)),Ha) = aa(product_prod(array(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(array(B),heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ou(nat,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),N)),array_alloc(B,replicate(B,N,X2),Ha))) ) ).

% execute_new
tff(fact_3542_Array__Time_Omake__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,F: fun(nat,B)] : array_make(B,N,F) = heap_Time_heap(array(B),aa(fun(nat,B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ov(nat,fun(fun(nat,B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),N),F)) ) ).

% Array_Time.make_def
tff(fact_3543_new__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B] : aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2) = heap_Time_heap(array(B),aa(B,fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ow(nat,fun(B,fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),N),X2)) ) ).

% new_def
tff(fact_3544_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_3545_map__of__eq__empty__iff,axiom,
    ! [C: $tType,B: $tType,Xys: list(product_prod(B,C))] :
      ( ! [X4: B] : aa(B,option(C),map_of(B,C,Xys),X4) = none(C)
    <=> ( Xys = nil(product_prod(B,C)) ) ) ).

% map_of_eq_empty_iff
tff(fact_3546_slice__Nil,axiom,
    ! [B: $tType,Begin: nat,End: nat] : slice(B,Begin,End,nil(B)) = nil(B) ).

% slice_Nil
tff(fact_3547_slice__eq__bounds__empty,axiom,
    ! [B: $tType,I: nat,Xsa: list(B)] : slice(B,I,I,Xsa) = nil(B) ).

% slice_eq_bounds_empty
tff(fact_3548_empty__eq__map__of__iff,axiom,
    ! [C: $tType,B: $tType,Xys: list(product_prod(B,C))] :
      ( ( aTP_Lamp_hj(B,option(C)) = map_of(B,C,Xys) )
    <=> ( Xys = nil(product_prod(B,C)) ) ) ).

% empty_eq_map_of_iff
tff(fact_3549_length__ge__1__conv,axiom,
    ! [B: $tType,L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,suc,zero_zero(nat))),aa(list(B),nat,size_size(list(B)),L))
    <=> ( L != nil(B) ) ) ).

% length_ge_1_conv
tff(fact_3550_map__fst__mk__fst,axiom,
    ! [C: $tType,B: $tType,K: B,L: list(C)] : aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),aa(list(C),list(product_prod(B,C)),map(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K)),L)) = replicate(B,aa(list(C),nat,size_size(list(C)),L),K) ).

% map_fst_mk_fst
tff(fact_3551_map__snd__mk__snd,axiom,
    ! [C: $tType,B: $tType,K: B,L: list(C)] : aa(list(product_prod(C,B)),list(B),map(product_prod(C,B),B,product_snd(C,B)),aa(list(C),list(product_prod(C,B)),map(C,product_prod(C,B),aa(B,fun(C,product_prod(C,B)),aTP_Lamp_it(B,fun(C,product_prod(C,B))),K)),L)) = replicate(B,aa(list(C),nat,size_size(list(C)),L),K) ).

% map_snd_mk_snd
tff(fact_3552_map__add__upt_H,axiom,
    ! [Ofs: nat,A3: nat,B2: nat] : aa(list(nat),list(nat),map(nat,nat,aTP_Lamp_ox(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_3553_len__greater__imp__nonempty,axiom,
    ! [B: $tType,X2: nat,L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),aa(list(B),nat,size_size(list(B)),L))
     => ( L != nil(B) ) ) ).

% len_greater_imp_nonempty
tff(fact_3554_map__add__upt,axiom,
    ! [N: nat,M: nat] : aa(list(nat),list(nat),map(nat,nat,aTP_Lamp_ox(nat,fun(nat,nat),N)),upt(zero_zero(nat),M)) = upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) ).

% map_add_upt
tff(fact_3555_map__of__Cons__code_I1_J,axiom,
    ! [C: $tType,B: $tType,K: C] : aa(C,option(B),map_of(C,B,nil(product_prod(C,B))),K) = none(B) ).

% map_of_Cons_code(1)
tff(fact_3556_map__of_Osimps_I1_J,axiom,
    ! [B: $tType,C: $tType,X: B] : aa(B,option(C),map_of(B,C,nil(product_prod(B,C))),X) = none(C) ).

% map_of.simps(1)
tff(fact_3557_mergesort__by__rel__split_Osimps_I1_J,axiom,
    ! [B: $tType,Xs1: list(B),Xs2: list(B)] : merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),nil(B)) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2) ).

% mergesort_by_rel_split.simps(1)
tff(fact_3558_upt__filter__extend,axiom,
    ! [U: nat,U4: nat,P: fun(nat,$o)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),U),U4)
     => ( ! [I2: nat] :
            ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),U),I2)
              & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),U4) )
           => ~ aa(nat,$o,P,I2) )
       => ( filter(nat,P,upt(zero_zero(nat),U)) = filter(nat,P,upt(zero_zero(nat),U4)) ) ) ) ).

% upt_filter_extend
tff(fact_3559_effect__newI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),H2: heap_ext(product_unit),N: nat,X2: B,Ha: heap_ext(product_unit)] :
          ( ( aa(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit))),product_Pair(array(B),heap_ext(product_unit)),A3),H2) = array_alloc(B,replicate(B,N,X2),Ha) )
         => heap_Time_effect(array(B),aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2),Ha,H2,A3,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))) ) ) ).

% effect_newI
tff(fact_3560_effect__makeI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),H2: heap_ext(product_unit),F: fun(nat,B),N: nat,Ha: heap_ext(product_unit)] :
          ( ( aa(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit))),product_Pair(array(B),heap_ext(product_unit)),A3),H2) = array_alloc(B,aa(list(nat),list(B),map(nat,B,F),upt(zero_zero(nat),N)),Ha) )
         => heap_Time_effect(array(B),array_make(B,N,F),Ha,H2,A3,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))) ) ) ).

% effect_makeI
tff(fact_3561_mergesort__by__rel_Opinduct,axiom,
    ! [B: $tType,A0: fun(B,fun(B,$o)),A1: list(B),P: fun(fun(B,fun(B,$o)),fun(list(B),$o))] :
      ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),mergesort_by_rel_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),A0),A1))
     => ( ! [R7: fun(B,fun(B,$o)),Xs: list(B)] :
            ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),mergesort_by_rel_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),R7),Xs))
           => ( ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xs)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))
               => aa(list(B),$o,aa(fun(B,fun(B,$o)),fun(list(B),$o),P,R7),aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xs))) )
             => ( ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xs)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))
                 => aa(list(B),$o,aa(fun(B,fun(B,$o)),fun(list(B),$o),P,R7),aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xs))) )
               => aa(list(B),$o,aa(fun(B,fun(B,$o)),fun(list(B),$o),P,R7),Xs) ) ) )
       => aa(list(B),$o,aa(fun(B,fun(B,$o)),fun(list(B),$o),P,A0),A1) ) ) ).

% mergesort_by_rel.pinduct
tff(fact_3562_mergesort__by__rel_Oelims,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Y: list(B)] :
      ( ( aa(list(B),list(B),mergesort_by_rel(B,X2),Xa) = Y )
     => ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Xa,merges9089515139780605204_merge(B,X2,aa(list(B),list(B),mergesort_by_rel(B,X2),aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xa))),aa(list(B),list(B),mergesort_by_rel(B,X2),aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xa))))) ) ) ).

% mergesort_by_rel.elims
tff(fact_3563_mergesort__by__rel_Osimps,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] :
      aa(list(B),list(B),mergesort_by_rel(B,R4),Xsa) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Xsa,merges9089515139780605204_merge(B,R4,aa(list(B),list(B),mergesort_by_rel(B,R4),aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xsa))),aa(list(B),list(B),mergesort_by_rel(B,R4),aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xsa))))) ).

% mergesort_by_rel.simps
tff(fact_3564_enumerate__replicate__eq,axiom,
    ! [B: $tType,N: nat,M: nat,A3: B] : enumerate(B,N,replicate(B,M,A3)) = aa(list(nat),list(product_prod(nat,B)),map(nat,product_prod(nat,B),aTP_Lamp_oy(B,fun(nat,product_prod(nat,B)),A3)),upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M))) ).

% enumerate_replicate_eq
tff(fact_3565_nth__step__trancl,axiom,
    ! [B: $tType,Xsa: list(B),R4: set(product_prod(B,B)),N: nat,M: nat] :
      ( ! [N3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)))
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,nth(B,Xsa),aa(nat,nat,suc,N3))),aa(nat,B,nth(B,Xsa),N3)),R4) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,nth(B,Xsa),N)),aa(nat,B,nth(B,Xsa),M)),transitive_trancl(B,R4)) ) ) ) ).

% nth_step_trancl
tff(fact_3566_mergesort__by__rel__simps_I1_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o))] : aa(list(B),list(B),mergesort_by_rel(B,R4),nil(B)) = nil(B) ).

% mergesort_by_rel_simps(1)
tff(fact_3567_set__mergesort__by__rel,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] : aa(list(B),set(B),set2(B),aa(list(B),list(B),mergesort_by_rel(B,R4),Xsa)) = aa(list(B),set(B),set2(B),Xsa) ).

% set_mergesort_by_rel
tff(fact_3568_mergesort__by__rel__merge__simps_I3_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Ys: list(B)] : merges9089515139780605204_merge(B,R4,nil(B),Ys) = Ys ).

% mergesort_by_rel_merge_simps(3)
tff(fact_3569_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_3570_set__mergesort__by__rel__merge,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B),Ys: list(B)] : aa(list(B),set(B),set2(B),merges9089515139780605204_merge(B,R4,Xsa,Ys)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(list(B),set(B),set2(B),Xsa)),aa(list(B),set(B),set2(B),Ys)) ).

% set_mergesort_by_rel_merge
tff(fact_3571_map__fst__enumerate,axiom,
    ! [B: $tType,N: nat,Xsa: list(B)] : aa(list(product_prod(nat,B)),list(nat),map(product_prod(nat,B),nat,product_fst(nat,B)),enumerate(B,N,Xsa)) = upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))) ).

% map_fst_enumerate
tff(fact_3572_nth__image__indices,axiom,
    ! [B: $tType,L: list(B)] : aa(set(nat),set(B),image2(nat,B,nth(B,L)),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(B),nat,size_size(list(B)),L))) = aa(list(B),set(B),set2(B),L) ).

% nth_image_indices
tff(fact_3573_ran__nth__set__encoding__conv,axiom,
    ! [B: $tType,L: list(B)] : ran(nat,B,aTP_Lamp_oz(list(B),fun(nat,option(B)),L)) = aa(list(B),set(B),set2(B),L) ).

% ran_nth_set_encoding_conv
tff(fact_3574_mergesort__by__rel_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(B,fun(B,$o)),list(B))] :
      ~ ! [R7: fun(B,fun(B,$o)),Xs: list(B)] : X2 != aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),R7),Xs) ).

% mergesort_by_rel.cases
tff(fact_3575_map__eq__nth__eq,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),L: list(C),L4: list(C),I: nat] :
      ( ( aa(list(C),list(B),map(C,B,F),L) = aa(list(C),list(B),map(C,B,F),L4) )
     => ( aa(C,B,F,aa(nat,C,nth(C,L),I)) = aa(C,B,F,aa(nat,C,nth(C,L4),I)) ) ) ).

% map_eq_nth_eq
tff(fact_3576_nth__enumerate__eq,axiom,
    ! [B: $tType,M: nat,Xsa: list(B),N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( aa(nat,product_prod(nat,B),nth(product_prod(nat,B),enumerate(B,N,Xsa)),M) = aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M)),aa(nat,B,nth(B,Xsa),M)) ) ) ).

% nth_enumerate_eq
tff(fact_3577_mergesort__by__rel__merge__simps_I2_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] : merges9089515139780605204_merge(B,R4,Xsa,nil(B)) = Xsa ).

% mergesort_by_rel_merge_simps(2)
tff(fact_3578_obtain__list__from__elements,axiom,
    ! [B: $tType,N: nat,P: fun(B,fun(nat,$o))] :
      ( ! [I2: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),N)
         => ? [Li: B] : aa(nat,$o,aa(B,fun(nat,$o),P,Li),I2) )
     => ~ ! [L5: list(B)] :
            ( ( aa(list(B),nat,size_size(list(B)),L5) = N )
           => ~ ! [I5: nat] :
                  ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I5),N)
                 => aa(nat,$o,aa(B,fun(nat,$o),P,aa(nat,B,nth(B,L5),I5)),I5) ) ) ) ).

% obtain_list_from_elements
tff(fact_3579_in__set__enumerate__eq,axiom,
    ! [B: $tType,P3: product_prod(nat,B),N: nat,Xsa: list(B)] :
      ( member(product_prod(nat,B),P3,aa(list(product_prod(nat,B)),set(product_prod(nat,B)),set2(product_prod(nat,B)),enumerate(B,N,Xsa)))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(product_prod(nat,B),nat,product_fst(nat,B),P3))
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(product_prod(nat,B),nat,product_fst(nat,B),P3)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),N))
        & ( aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(product_prod(nat,B),nat,product_fst(nat,B),P3)),N)) = aa(product_prod(nat,B),B,product_snd(nat,B),P3) ) ) ) ).

% in_set_enumerate_eq
tff(fact_3580_all__set__conv__nth,axiom,
    ! [B: $tType,L: list(B),P: fun(B,$o)] :
      ( ! [X4: B] :
          ( member(B,X4,aa(list(B),set(B),set2(B),L))
         => aa(B,$o,P,X4) )
    <=> ! [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),L))
         => aa(B,$o,P,aa(nat,B,nth(B,L),I3)) ) ) ).

% all_set_conv_nth
tff(fact_3581_set__image__eq__pointwiseI,axiom,
    ! [C: $tType,B: $tType,L: list(B),L4: list(B),F: fun(B,C)] :
      ( ( aa(list(B),nat,size_size(list(B)),L) = aa(list(B),nat,size_size(list(B)),L4) )
     => ( ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(B),nat,size_size(list(B)),L))
           => ( aa(B,C,F,aa(nat,B,nth(B,L),I2)) = aa(B,C,F,aa(nat,B,nth(B,L4),I2)) ) )
       => ( aa(set(B),set(C),image2(B,C,F),aa(list(B),set(B),set2(B),L)) = aa(set(B),set(C),image2(B,C,F),aa(list(B),set(B),set2(B),L4)) ) ) ) ).

% set_image_eq_pointwiseI
tff(fact_3582_in__set__image__conv__nth,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: C,L: list(C)] :
      ( member(B,aa(C,B,F,X2),aa(set(C),set(B),image2(C,B,F),aa(list(C),set(C),set2(C),L)))
    <=> ? [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),L))
          & ( aa(C,B,F,aa(nat,C,nth(C,L),I3)) = aa(C,B,F,X2) ) ) ) ).

% in_set_image_conv_nth
tff(fact_3583_distinct__idx,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),L: list(C),I: nat,J: nat] :
      ( distinct(B,aa(list(C),list(B),map(C,B,F),L))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),L))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(C),nat,size_size(list(C)),L))
         => ( ( aa(C,B,F,aa(nat,C,nth(C,L),I)) = aa(C,B,F,aa(nat,C,nth(C,L),J)) )
           => ( I = J ) ) ) ) ) ).

% distinct_idx
tff(fact_3584_array__of__list__make,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B)] : array_of_list(B,Xsa) = array_make(B,aa(list(B),nat,size_size(list(B)),Xsa),nth(B,Xsa)) ) ).

% array_of_list_make
tff(fact_3585_nth__map__upt,axiom,
    ! [B: $tType,I: nat,N: nat,M: nat,F: fun(nat,B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))
     => ( aa(nat,B,nth(B,aa(list(nat),list(B),map(nat,B,F),upt(M,N))),I) = aa(nat,B,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),I)) ) ) ).

% nth_map_upt
tff(fact_3586_mergesort__by__rel_Opsimps,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] :
      ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),mergesort_by_rel_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),R4),Xsa))
     => ( aa(list(B),list(B),mergesort_by_rel(B,R4),Xsa) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Xsa,merges9089515139780605204_merge(B,R4,aa(list(B),list(B),mergesort_by_rel(B,R4),aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xsa))),aa(list(B),list(B),mergesort_by_rel(B,R4),aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xsa))))) ) ) ).

% mergesort_by_rel.psimps
tff(fact_3587_mergesort__by__rel_Opelims,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Y: list(B)] :
      ( ( aa(list(B),list(B),mergesort_by_rel(B,X2),Xa) = Y )
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),mergesort_by_rel_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ~ ( ( Y = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xa)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Xa,merges9089515139780605204_merge(B,X2,aa(list(B),list(B),mergesort_by_rel(B,X2),aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xa))),aa(list(B),list(B),mergesort_by_rel(B,X2),aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xa))))) )
           => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),mergesort_by_rel_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa)) ) ) ) ).

% mergesort_by_rel.pelims
tff(fact_3588_enumerate__map__upt,axiom,
    ! [B: $tType,N: nat,F: fun(nat,B),M: nat] : enumerate(B,N,aa(list(nat),list(B),map(nat,B,F),upt(N,M))) = aa(list(nat),list(product_prod(nat,B)),map(nat,product_prod(nat,B),aTP_Lamp_pa(fun(nat,B),fun(nat,product_prod(nat,B)),F)),upt(N,M)) ).

% enumerate_map_upt
tff(fact_3589_map__upt__eqI,axiom,
    ! [B: $tType,Xsa: list(B),N: nat,M: nat,F: fun(nat,B)] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M) )
     => ( ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(B),nat,size_size(list(B)),Xsa))
           => ( aa(nat,B,nth(B,Xsa),I2) = aa(nat,B,F,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),I2)) ) )
       => ( aa(list(nat),list(B),map(nat,B,F),upt(M,N)) = Xsa ) ) ) ).

% map_upt_eqI
tff(fact_3590_slice__nth,axiom,
    ! [B: $tType,From: nat,To: nat,Xsa: list(B),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(B),nat,size_size(list(B)),Xsa))
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),To),From))
         => ( aa(nat,B,nth(B,slice(B,From,To,Xsa)),I) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),From),I)) ) ) ) ) ).

% slice_nth
tff(fact_3591_product__nth,axiom,
    ! [B: $tType,C: $tType,N: nat,Xsa: list(B),Ys: list(C)] :
      ( 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(B),nat,size_size(list(B)),Xsa)),aa(list(C),nat,size_size(list(C)),Ys)))
     => ( aa(nat,product_prod(B,C),nth(product_prod(B,C),product(B,C,Xsa,Ys)),N) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),N),aa(list(C),nat,size_size(list(C)),Ys)))),aa(nat,C,nth(C,Ys),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),N),aa(list(C),nat,size_size(list(C)),Ys)))) ) ) ).

% product_nth
tff(fact_3592_mergesort__def,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ( mergesort(B) = mergesort_by_rel(B,ord_less_eq(B)) ) ) ).

% mergesort_def
tff(fact_3593_sorted__in__between,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [I: nat,J: nat,L: list(B),X2: B] :
          ( 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(B),nat,size_size(list(B)),L))
             => ( sorted_wrt(B,ord_less_eq(B),L)
               => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,nth(B,L),I)),X2)
                 => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(nat,B,nth(B,L),J))
                   => ~ ! [K3: nat] :
                          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),K3)
                         => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K3),J)
                           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,nth(B,L),K3)),X2)
                             => ~ aa(B,$o,aa(B,fun(B,$o),ord_less(B),X2),aa(nat,B,nth(B,L),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K3),one_one(nat)))) ) ) ) ) ) ) ) ) ) ) ).

% sorted_in_between
tff(fact_3594_Un__set__drop__extend,axiom,
    ! [B: $tType,J: nat,L: list(set(B))] :
      ( 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(B)),nat,size_size(list(set(B))),L))
       => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(nat,set(B),nth(set(B),L),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),aa(nat,nat,suc,zero_zero(nat))))),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(list(set(B)),set(set(B)),set2(set(B)),drop(set(B),J,L)))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(list(set(B)),set(set(B)),set2(set(B)),drop(set(B),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),aa(nat,nat,suc,zero_zero(nat))),L))) ) ) ) ).

% Un_set_drop_extend
tff(fact_3595_mergesort__by__rel__simps_I3_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),X1: B,X22: B,Xsa: list(B)] : aa(list(B),list(B),mergesort_by_rel(B,R4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),Xsa))) = aa(product_prod(list(B),list(B)),list(B),aa(fun(list(B),fun(list(B),list(B))),fun(product_prod(list(B),list(B)),list(B)),product_case_prod(list(B),list(B),list(B)),aTP_Lamp_pb(fun(B,fun(B,$o)),fun(list(B),fun(list(B),list(B))),R4)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),nil(B))),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),nil(B))),Xsa)) ).

% mergesort_by_rel_simps(3)
tff(fact_3596_drop__drop,axiom,
    ! [B: $tType,N: nat,M: nat,Xsa: list(B)] : drop(B,N,drop(B,M,Xsa)) = drop(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M),Xsa) ).

% drop_drop
tff(fact_3597_sorted__wrt__mergesort__by__rel__merge,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B),Ys: list(B)] :
      ( ! [X3: B,Y4: B] :
          ( aa(B,$o,aa(B,fun(B,$o),R4,X3),Y4)
          | aa(B,$o,aa(B,fun(B,$o),R4,Y4),X3) )
     => ( ! [X3: B,Y4: B,Z3: B] :
            ( aa(B,$o,aa(B,fun(B,$o),R4,X3),Y4)
           => ( aa(B,$o,aa(B,fun(B,$o),R4,Y4),Z3)
             => aa(B,$o,aa(B,fun(B,$o),R4,X3),Z3) ) )
       => ( sorted_wrt(B,R4,merges9089515139780605204_merge(B,R4,Xsa,Ys))
        <=> ( sorted_wrt(B,R4,Xsa)
            & sorted_wrt(B,R4,Ys) ) ) ) ) ).

% sorted_wrt_mergesort_by_rel_merge
tff(fact_3598_mergesort__by__rel__simps_I2_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),X2: B] : aa(list(B),list(B),mergesort_by_rel(B,R4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B)) ).

% mergesort_by_rel_simps(2)
tff(fact_3599_enumerate__simps_I2_J,axiom,
    ! [B: $tType,N: nat,X2: B,Xsa: list(B)] : enumerate(B,N,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(list(product_prod(nat,B)),list(product_prod(nat,B)),aa(product_prod(nat,B),fun(list(product_prod(nat,B)),list(product_prod(nat,B))),cons(product_prod(nat,B)),aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),N),X2)),enumerate(B,aa(nat,nat,suc,N),Xsa)) ).

% enumerate_simps(2)
tff(fact_3600_sorted__wrt__map__linord,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [L: list(product_prod(B,C))] :
          ( sorted_wrt(product_prod(B,C),aTP_Lamp_pc(product_prod(B,C),fun(product_prod(B,C),$o)),L)
        <=> sorted_wrt(B,ord_less_eq(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),L)) ) ) ).

% sorted_wrt_map_linord
tff(fact_3601_nth__Cons__numeral,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),V: num] : aa(nat,B,nth(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(num,nat,numeral_numeral(nat),V)) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(num,nat,numeral_numeral(nat),V)),one_one(nat))) ).

% nth_Cons_numeral
tff(fact_3602_drop__Cons__numeral,axiom,
    ! [B: $tType,V: num,X2: B,Xsa: list(B)] : drop(B,aa(num,nat,numeral_numeral(nat),V),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = drop(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(num,nat,numeral_numeral(nat),V)),one_one(nat)),Xsa) ).

% drop_Cons_numeral
tff(fact_3603_nth__drop,axiom,
    ! [B: $tType,N: nat,Xsa: list(B),I: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( aa(nat,B,nth(B,drop(B,N,Xsa)),I) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),I)) ) ) ).

% nth_drop
tff(fact_3604_nth__Cons__pos,axiom,
    ! [B: $tType,N: nat,X2: B,Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => ( aa(nat,B,nth(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),N) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ) ) ).

% nth_Cons_pos
tff(fact_3605_Misc_Ofoldr__Cons,axiom,
    ! [B: $tType,Xsa: list(B)] : aa(list(B),list(B),foldr(B,list(B),cons(B),Xsa),nil(B)) = Xsa ).

% Misc.foldr_Cons
tff(fact_3606_map__consI_I1_J,axiom,
    ! [B: $tType,C: $tType,W: list(B),F: fun(C,B),Ww: list(C),A3: C] :
      ( ( W = aa(list(C),list(B),map(C,B,F),Ww) )
     => ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(C,B,F,A3)),W) = aa(list(C),list(B),map(C,B,F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),Ww)) ) ) ).

% map_consI(1)
tff(fact_3607_map__eq__consE,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),Ls: list(C),Fa: B,Fl: list(B)] :
      ( ( aa(list(C),list(B),map(C,B,F),Ls) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Fa),Fl) )
     => ~ ! [A5: C,L5: list(C)] :
            ( ( Ls = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),L5) )
           => ( ( aa(C,B,F,A5) = Fa )
             => ( aa(list(C),list(B),map(C,B,F),L5) != Fl ) ) ) ) ).

% map_eq_consE
tff(fact_3608_neq__NilE,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( L != nil(B) )
     => ~ ! [X3: B,Xs: list(B)] : L != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) ) ).

% neq_NilE
tff(fact_3609_list__2pre__induct,axiom,
    ! [B: $tType,C: $tType,P: fun(list(B),fun(list(C),$o)),W1: list(B),W2: list(C)] :
      ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,nil(B)),nil(C))
     => ( ! [E3: B,W12: list(B),W22: list(C)] :
            ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,W12),W22)
           => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E3),W12)),W22) )
       => ( ! [E3: C,W13: list(B),W23: list(C)] :
              ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,W13),W23)
             => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,W13),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),E3),W23)) )
         => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,W1),W2) ) ) ) ).

% list_2pre_induct
tff(fact_3610_list__induct__first2,axiom,
    ! [B: $tType,P: fun(list(B),$o),Xsa: list(B)] :
      ( aa(list(B),$o,P,nil(B))
     => ( ! [X3: B] : aa(list(B),$o,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))
       => ( ! [X12: B,X23: B,Xs: list(B)] :
              ( aa(list(B),$o,P,Xs)
             => aa(list(B),$o,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs))) )
         => aa(list(B),$o,P,Xsa) ) ) ) ).

% list_induct_first2
tff(fact_3611_mergesort__by__rel__merge__induct,axiom,
    ! [B: $tType,C: $tType,P: fun(list(B),fun(list(C),$o)),R4: fun(B,fun(C,$o)),Xsa: list(B),Ys: list(C)] :
      ( ! [Xs: list(B)] : aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xs),nil(C))
     => ( ! [Ys2: list(C)] : aa(list(C),$o,aa(list(B),fun(list(C),$o),P,nil(B)),Ys2)
       => ( ! [X3: B,Xs: list(B),Y4: C,Ys2: list(C)] :
              ( aa(C,$o,aa(B,fun(C,$o),R4,X3),Y4)
             => ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xs),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),Ys2))
               => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),Ys2)) ) )
         => ( ! [X3: B,Xs: list(B),Y4: C,Ys2: list(C)] :
                ( ~ aa(C,$o,aa(B,fun(C,$o),R4,X3),Y4)
               => ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Ys2)
                 => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),Ys2)) ) )
           => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xsa),Ys) ) ) ) ) ).

% mergesort_by_rel_merge_induct
tff(fact_3612_sorted__wrt__mergesort__by__rel,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] :
      ( ! [X3: B,Y4: B] :
          ( aa(B,$o,aa(B,fun(B,$o),R4,X3),Y4)
          | aa(B,$o,aa(B,fun(B,$o),R4,Y4),X3) )
     => ( ! [X3: B,Y4: B,Z3: B] :
            ( aa(B,$o,aa(B,fun(B,$o),R4,X3),Y4)
           => ( aa(B,$o,aa(B,fun(B,$o),R4,Y4),Z3)
             => aa(B,$o,aa(B,fun(B,$o),R4,X3),Z3) ) )
       => sorted_wrt(B,R4,aa(list(B),list(B),mergesort_by_rel(B,R4),Xsa)) ) ) ).

% sorted_wrt_mergesort_by_rel
tff(fact_3613_list__tail__coinc,axiom,
    ! [B: $tType,N12: B,R1: list(B),N23: B,R22: list(B)] :
      ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),N12),R1) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),N23),R22) )
     => ( ( N12 = N23 )
        & ( R1 = R22 ) ) ) ).

% list_tail_coinc
tff(fact_3614_drop__eq__ConsD,axiom,
    ! [B: $tType,N: nat,Xsa: list(B),X2: B,Xs3: list(B)] :
      ( ( drop(B,N,Xsa) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xs3) )
     => ( drop(B,aa(nat,nat,suc,N),Xsa) = Xs3 ) ) ).

% drop_eq_ConsD
tff(fact_3615_drop__Cons_H,axiom,
    ! [B: $tType,N: nat,X2: B,Xsa: list(B)] :
      drop(B,N,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = $ite(N = zero_zero(nat),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),drop(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),Xsa)) ).

% drop_Cons'
tff(fact_3616_mergesort__by__rel__merge__simps_I1_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),X2: B,Xsa: list(B),Y: B,Ys: list(B)] :
      merges9089515139780605204_merge(B,R4,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)) = $ite(aa(B,$o,aa(B,fun(B,$o),R4,X2),Y),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),merges9089515139780605204_merge(B,R4,Xsa,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys))),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),merges9089515139780605204_merge(B,R4,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Ys))) ).

% mergesort_by_rel_merge_simps(1)
tff(fact_3617_sorted__filter_H,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B),P: fun(B,$o)] :
          ( sorted_wrt(B,ord_less_eq(B),L)
         => sorted_wrt(B,ord_less_eq(B),filter(B,P,L)) ) ) ).

% sorted_filter'
tff(fact_3618_sorted__mergesort__by__rel,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B)] : sorted_wrt(B,ord_less_eq(B),aa(list(B),list(B),mergesort_by_rel(B,ord_less_eq(B)),Xsa)) ) ).

% sorted_mergesort_by_rel
tff(fact_3619_map__filter__simps_I1_J,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),X2: C,Xsa: list(C)] : map_filter(C,B,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xsa)) = aa(option(B),list(B),aa(fun(B,list(B)),fun(option(B),list(B)),aa(list(B),fun(fun(B,list(B)),fun(option(B),list(B))),case_option(list(B),B),map_filter(C,B,F,Xsa)),aa(list(C),fun(B,list(B)),aTP_Lamp_pd(fun(C,option(B)),fun(list(C),fun(B,list(B))),F),Xsa)),aa(C,option(B),F,X2)) ).

% map_filter_simps(1)
tff(fact_3620_zipf_Ocases,axiom,
    ! [D: $tType,B: $tType,C: $tType,X2: product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C)))] :
      ( ! [F3: fun(B,fun(C,D))] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C))),aa(fun(B,fun(C,D)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,D)),product_prod(list(B),list(C))),F3),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),nil(C)))
     => ( ! [F3: fun(B,fun(C,D)),A5: B,As: list(B),B3: C,Bs: list(C)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C))),aa(fun(B,fun(C,D)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,D)),product_prod(list(B),list(C))),F3),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs)))
       => ( ! [A5: fun(B,fun(C,D)),V4: B,Va: list(B)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C))),aa(fun(B,fun(C,D)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,D)),product_prod(list(B),list(C))),A5),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)),nil(C)))
         => ~ ! [A5: fun(B,fun(C,D)),V4: C,Va: list(C)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C))),aa(fun(B,fun(C,D)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,D)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,D)),product_prod(list(B),list(C))),A5),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va))) ) ) ) ).

% zipf.cases
tff(fact_3621_merge_Ocases,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: product_prod(list(B),list(B))] :
          ( ! [L22: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),L22)
         => ( ! [V4: B,Va: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)),nil(B))
           => ~ ! [X12: B,L12: list(B),X23: B,L22: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),L12)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),L22)) ) ) ) ).

% merge.cases
tff(fact_3622_list__all__zip_Ocases,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))] :
      ( ! [P4: fun(B,fun(C,$o))] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),P4),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),nil(C)))
     => ( ! [P4: fun(B,fun(C,$o)),A5: B,As: list(B),B3: C,Bs: list(C)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),P4),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs)))
       => ( ! [P4: fun(B,fun(C,$o)),V4: B,Va: list(B)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),P4),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)),nil(C)))
         => ~ ! [P4: fun(B,fun(C,$o)),V4: C,Va: list(C)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),P4),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va))) ) ) ) ).

% list_all_zip.cases
tff(fact_3623_partition__rev_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B)))] :
      ( ! [P4: fun(B,$o),Yes: list(B),No: list(B)] : X2 != aa(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),aa(fun(B,$o),fun(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B)))),product_Pair(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),P4),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No)),nil(B)))
     => ~ ! [P4: fun(B,$o),Yes: list(B),No: list(B),X3: B,Xs: list(B)] : X2 != aa(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),aa(fun(B,$o),fun(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B)))),product_Pair(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),P4),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs))) ) ).

% partition_rev.cases
tff(fact_3624_quicksort__by__rel_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))] :
      ( ! [R7: fun(B,fun(B,$o)),Sl: list(B)] : X2 != aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Sl),nil(B)))
     => ~ ! [R7: fun(B,fun(B,$o)),Sl: list(B),X3: B,Xs: list(B)] : X2 != aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Sl),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs))) ) ).

% quicksort_by_rel.cases
tff(fact_3625_mergesort__by__rel__merge_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))] :
      ( ! [R7: fun(B,fun(B,$o)),X3: B,Xs: list(B),Y4: B,Ys2: list(B)] : X2 != aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2)))
     => ( ! [R7: fun(B,fun(B,$o)),Xs: list(B)] : X2 != aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs),nil(B)))
       => ~ ! [R7: fun(B,fun(B,$o)),V4: B,Va: list(B)] : X2 != aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va))) ) ) ).

% mergesort_by_rel_merge.cases
tff(fact_3626_mergesort__by__rel__split_Ocases,axiom,
    ! [B: $tType,X2: product_prod(product_prod(list(B),list(B)),list(B))] :
      ( ! [Xs12: list(B),Xs22: list(B)] : X2 != aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22)),nil(B))
     => ( ! [Xs12: list(B),Xs22: list(B),X3: B] : X2 != aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))
       => ~ ! [Xs12: list(B),Xs22: list(B),X12: B,X23: B,Xs: list(B)] : X2 != aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs))) ) ) ).

% mergesort_by_rel_split.cases
tff(fact_3627_shuffles_Ocases,axiom,
    ! [B: $tType,X2: product_prod(list(B),list(B))] :
      ( ! [Ys2: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys2)
     => ( ! [Xs: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs),nil(B))
       => ~ ! [X3: B,Xs: list(B),Y4: B,Ys2: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2)) ) ) ).

% shuffles.cases
tff(fact_3628_map__tailrec__rev_Ocases,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(fun(B,C),product_prod(list(B),list(C)))] :
      ( ! [F3: fun(B,C),Bs: list(C)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,C),product_prod(list(B),list(C))),aa(fun(B,C),fun(product_prod(list(B),list(C)),product_prod(fun(B,C),product_prod(list(B),list(C)))),product_Pair(fun(B,C),product_prod(list(B),list(C))),F3),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),Bs))
     => ~ ! [F3: fun(B,C),A5: B,As: list(B),Bs: list(C)] : X2 != aa(product_prod(list(B),list(C)),product_prod(fun(B,C),product_prod(list(B),list(C))),aa(fun(B,C),fun(product_prod(list(B),list(C)),product_prod(fun(B,C),product_prod(list(B),list(C)))),product_Pair(fun(B,C),product_prod(list(B),list(C))),F3),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),Bs)) ) ).

% map_tailrec_rev.cases
tff(fact_3629_foldr_Ofoldr__Cons,axiom,
    ! [B: $tType,C: $tType,F: fun(C,fun(B,B)),X2: C,Xsa: list(C)] : foldr(C,B,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xsa)) = aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),aa(C,fun(B,B),F,X2)),foldr(C,B,F,Xsa)) ).

% foldr.foldr_Cons
tff(fact_3630_arg__min__list_Ocases,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [X2: product_prod(fun(B,C),list(B))] :
          ( ! [F3: fun(B,C),X3: B] : X2 != aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),F3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))
         => ( ! [F3: fun(B,C),X3: B,Y4: B,Zs2: list(B)] : X2 != aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),F3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Zs2)))
           => ~ ! [A5: fun(B,C)] : X2 != aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),A5),nil(B)) ) ) ) ).

% arg_min_list.cases
tff(fact_3631_successively_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(B,fun(B,$o)),list(B))] :
      ( ! [P4: fun(B,fun(B,$o))] : X2 != aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),P4),nil(B))
     => ( ! [P4: fun(B,fun(B,$o)),X3: B] : X2 != aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),P4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))
       => ~ ! [P4: fun(B,fun(B,$o)),X3: B,Y4: B,Xs: list(B)] : X2 != aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),P4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs))) ) ) ).

% successively.cases
tff(fact_3632_sorted__wrt_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(B,fun(B,$o)),list(B))] :
      ( ! [P4: fun(B,fun(B,$o))] : X2 != aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),P4),nil(B))
     => ~ ! [P4: fun(B,fun(B,$o)),X3: B,Ys2: list(B)] : X2 != aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),P4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2)) ) ).

% sorted_wrt.cases
tff(fact_3633_mergesort__by__rel__merge_Oelims,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Xb: list(B),Y: list(B)] :
      ( ( merges9089515139780605204_merge(B,X2,Xa,Xb) = Y )
     => ( ! [X3: B,Xs: list(B)] :
            ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
           => ! [Y4: B,Ys2: list(B)] :
                ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2) )
               => ( Y != $ite(aa(B,$o,aa(B,fun(B,$o),X2,X3),Y4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),merges9089515139780605204_merge(B,X2,Xs,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2))),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),merges9089515139780605204_merge(B,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs),Ys2))) ) ) )
       => ( ( ( Xb = nil(B) )
           => ( Y != Xa ) )
         => ~ ( ( Xa = nil(B) )
             => ! [V4: B,Va: list(B)] :
                  ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                 => ( Y != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) ) ) ) ) ) ) ).

% mergesort_by_rel_merge.elims
tff(fact_3634_mergesort__by__rel__merge_Osimps_I3_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),V: B,Va2: list(B)] : merges9089515139780605204_merge(B,R4,nil(B),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V),Va2)) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V),Va2) ).

% mergesort_by_rel_merge.simps(3)
tff(fact_3635_mergesort__by__rel__split_Osimps_I3_J,axiom,
    ! [B: $tType,Xs1: list(B),Xs2: list(B),X1: B,X22: B,Xsa: list(B)] : merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),Xsa))) = merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),Xs1)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),Xs2)),Xsa) ).

% mergesort_by_rel_split.simps(3)
tff(fact_3636_filter__conv__foldr,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B)] : filter(B,P,Xsa) = aa(list(B),list(B),foldr(B,list(B),aTP_Lamp_pe(fun(B,$o),fun(B,fun(list(B),list(B))),P),Xsa),nil(B)) ).

% filter_conv_foldr
tff(fact_3637_sorted__wrt01,axiom,
    ! [B: $tType,Xsa: list(B),P: fun(B,fun(B,$o))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat))
     => sorted_wrt(B,P,Xsa) ) ).

% sorted_wrt01
tff(fact_3638_length__compl__induct,axiom,
    ! [B: $tType,P: fun(list(B),$o),L: list(B)] :
      ( aa(list(B),$o,P,nil(B))
     => ( ! [E3: B,L5: list(B)] :
            ( ! [Ll: list(B)] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Ll)),aa(list(B),nat,size_size(list(B)),L5))
               => aa(list(B),$o,P,Ll) )
           => aa(list(B),$o,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E3),L5)) )
       => aa(list(B),$o,P,L) ) ) ).

% length_compl_induct
tff(fact_3639_list__decomp__1,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( aa(list(B),nat,size_size(list(B)),L) = one_one(nat) )
     => ? [A5: B] : L = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),nil(B)) ) ).

% list_decomp_1
tff(fact_3640_map__of__Cons__code_I2_J,axiom,
    ! [B: $tType,C: $tType,L: C,V: B,Ps: list(product_prod(C,B)),K: C] :
      aa(C,option(B),map_of(C,B,aa(list(product_prod(C,B)),list(product_prod(C,B)),aa(product_prod(C,B),fun(list(product_prod(C,B)),list(product_prod(C,B))),cons(product_prod(C,B)),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),L),V)),Ps)),K) = $ite(L = K,aa(B,option(B),some(B),V),aa(C,option(B),map_of(C,B,Ps),K)) ).

% map_of_Cons_code(2)
tff(fact_3641_mergesort__by__rel__split_Osimps_I2_J,axiom,
    ! [B: $tType,Xs1: list(B),Xs2: list(B),X2: B] : merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xs1)),Xs2) ).

% mergesort_by_rel_split.simps(2)
tff(fact_3642_mergesort__by__rel__split_Oelims,axiom,
    ! [B: $tType,X2: product_prod(list(B),list(B)),Xa: list(B),Y: product_prod(list(B),list(B))] :
      ( ( merges295452479951948502_split(B,X2,Xa) = Y )
     => ( ! [Xs12: list(B),Xs22: list(B)] :
            ( ( X2 = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
           => ( ( Xa = nil(B) )
             => ( Y != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) ) ) )
       => ( ! [Xs12: list(B),Xs22: list(B)] :
              ( ( X2 = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
             => ! [X3: B] :
                  ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
                 => ( Y != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs12)),Xs22) ) ) )
         => ~ ! [Xs12: list(B),Xs22: list(B)] :
                ( ( X2 = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
               => ! [X12: B,X23: B,Xs: list(B)] :
                    ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs)) )
                   => ( Y != merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),Xs12)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs22)),Xs) ) ) ) ) ) ) ).

% mergesort_by_rel_split.elims
tff(fact_3643_sorted01,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat))
         => sorted_wrt(B,ord_less_eq(B),Xsa) ) ) ).

% sorted01
tff(fact_3644_list_Osize_I4_J,axiom,
    ! [B: $tType,X21: B,X222: list(B)] : aa(list(B),nat,size_size(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X21),X222)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),X222)),aa(nat,nat,suc,zero_zero(nat))) ).

% list.size(4)
tff(fact_3645_nth__Cons_H,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),N: nat] :
      aa(nat,B,nth(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),N) = $ite(N = zero_zero(nat),X2,aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))) ).

% nth_Cons'
tff(fact_3646_upt__eq__Cons__conv,axiom,
    ! [I: nat,J: nat,X2: nat,Xsa: list(nat)] :
      ( ( upt(I,J) = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),X2),Xsa) )
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J)
        & ( I = X2 )
        & ( upt(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),one_one(nat)),J) = Xsa ) ) ) ).

% upt_eq_Cons_conv
tff(fact_3647_in__set__drop__conv__nth,axiom,
    ! [B: $tType,X2: B,N: nat,L: list(B)] :
      ( member(B,X2,aa(list(B),set(B),set2(B),drop(B,N,L)))
    <=> ? [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),I3)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),L))
          & ( X2 = aa(nat,B,nth(B,L),I3) ) ) ) ).

% in_set_drop_conv_nth
tff(fact_3648_set__drop__conv,axiom,
    ! [B: $tType,N: nat,L: list(B)] : aa(list(B),set(B),set2(B),drop(B,N,L)) = aa(fun(B,$o),set(B),collect(B),aa(list(B),fun(B,$o),aTP_Lamp_pf(nat,fun(list(B),fun(B,$o)),N),L)) ).

% set_drop_conv
tff(fact_3649_list__decomp__2,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( aa(list(B),nat,size_size(list(B)),L) = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) )
     => ? [A5: B,B3: B] : L = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),B3),nil(B))) ) ).

% list_decomp_2
tff(fact_3650_nth__non__equal__first__eq,axiom,
    ! [B: $tType,X2: B,Y: B,Xsa: list(B),N: nat] :
      ( ( X2 != Y )
     => ( ( aa(nat,B,nth(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),N) = Y )
      <=> ( ( aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),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_3651_Cons__replicate__eq,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),N: nat,Y: B] :
      ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) = replicate(B,N,Y) )
    <=> ( ( X2 = Y )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
        & ( Xsa = replicate(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),X2) ) ) ) ).

% Cons_replicate_eq
tff(fact_3652_distinct__sorted__mono,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B),I: nat,J: nat] :
          ( sorted_wrt(B,ord_less_eq(B),L)
         => ( distinct(B,L)
           => ( 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(B),nat,size_size(list(B)),L))
               => aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,nth(B,L),I)),aa(nat,B,nth(B,L),J)) ) ) ) ) ) ).

% distinct_sorted_mono
tff(fact_3653_distinct__sorted__strict__mono__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B),I: nat,J: nat] :
          ( distinct(B,L)
         => ( sorted_wrt(B,ord_less_eq(B),L)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(B),nat,size_size(list(B)),L))
               => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(nat,B,nth(B,L),I)),aa(nat,B,nth(B,L),J))
                <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),J) ) ) ) ) ) ) ).

% distinct_sorted_strict_mono_iff
tff(fact_3654_distinct__sorted__mono__iff,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B),I: nat,J: nat] :
          ( distinct(B,L)
         => ( sorted_wrt(B,ord_less_eq(B),L)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
             => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(B),nat,size_size(list(B)),L))
               => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(nat,B,nth(B,L),I)),aa(nat,B,nth(B,L),J))
                <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J) ) ) ) ) ) ) ).

% distinct_sorted_mono_iff
tff(fact_3655_map__of_Osimps_I2_J,axiom,
    ! [C: $tType,B: $tType,P3: product_prod(B,C),Ps: list(product_prod(B,C))] : map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),P3),Ps)) = fun_upd(B,option(C),map_of(B,C,Ps),aa(product_prod(B,C),B,product_fst(B,C),P3),aa(C,option(C),some(C),aa(product_prod(B,C),C,product_snd(B,C),P3))) ).

% map_of.simps(2)
tff(fact_3656_slice__Cons,axiom,
    ! [B: $tType,Begin: nat,End: nat,X2: B,Xsa: list(B)] :
      slice(B,Begin,End,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = $ite(
        ( ( Begin = zero_zero(nat) )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),End) ),
        aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),slice(B,Begin,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),End),one_one(nat)),Xsa)),
        slice(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Begin),one_one(nat)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),End),one_one(nat)),Xsa) ) ).

% slice_Cons
tff(fact_3657_mergesort__by__rel__split_Opelims,axiom,
    ! [B: $tType,X2: product_prod(list(B),list(B)),Xa: list(B),Y: product_prod(list(B),list(B))] :
      ( ( merges295452479951948502_split(B,X2,Xa) = Y )
     => ( aa(product_prod(product_prod(list(B),list(B)),list(B)),$o,accp(product_prod(product_prod(list(B),list(B)),list(B)),merges7066485432131860899it_rel(B)),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),X2),Xa))
       => ( ! [Xs12: list(B),Xs22: list(B)] :
              ( ( X2 = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
             => ( ( Xa = nil(B) )
               => ( ( Y = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
                 => ~ aa(product_prod(product_prod(list(B),list(B)),list(B)),$o,accp(product_prod(product_prod(list(B),list(B)),list(B)),merges7066485432131860899it_rel(B)),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22)),nil(B))) ) ) )
         => ( ! [Xs12: list(B),Xs22: list(B)] :
                ( ( X2 = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
               => ! [X3: B] :
                    ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
                   => ( ( Y = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs12)),Xs22) )
                     => ~ aa(product_prod(product_prod(list(B),list(B)),list(B)),$o,accp(product_prod(product_prod(list(B),list(B)),list(B)),merges7066485432131860899it_rel(B)),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))) ) ) )
           => ~ ! [Xs12: list(B),Xs22: list(B)] :
                  ( ( X2 = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22) )
                 => ! [X12: B,X23: B,Xs: list(B)] :
                      ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs)) )
                     => ( ( Y = merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),Xs12)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs22)),Xs) )
                       => ~ aa(product_prod(product_prod(list(B),list(B)),list(B)),$o,accp(product_prod(product_prod(list(B),list(B)),list(B)),merges7066485432131860899it_rel(B)),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs12),Xs22)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),Xs)))) ) ) ) ) ) ) ) ).

% mergesort_by_rel_split.pelims
tff(fact_3658_list__decode_Opelims,axiom,
    ! [X2: nat,Y: list(nat)] :
      ( ( nat_list_decode(X2) = Y )
     => ( aa(nat,$o,accp(nat,nat_list_decode_rel),X2)
       => ( ( ( X2 = zero_zero(nat) )
           => ( ( Y = nil(nat) )
             => ~ aa(nat,$o,accp(nat,nat_list_decode_rel),zero_zero(nat)) ) )
         => ~ ! [N3: nat] :
                ( ( X2 = aa(nat,nat,suc,N3) )
               => ( ( Y = aa(product_prod(nat,nat),list(nat),aa(fun(nat,fun(nat,list(nat))),fun(product_prod(nat,nat),list(nat)),product_case_prod(nat,nat,list(nat)),aTP_Lamp_pg(nat,fun(nat,list(nat)))),nat_prod_decode(N3)) )
                 => ~ aa(nat,$o,accp(nat,nat_list_decode_rel),aa(nat,nat,suc,N3)) ) ) ) ) ) ).

% list_decode.pelims
tff(fact_3659_mergesort__by__rel__merge_Opelims,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Xb: list(B),Y: list(B)] :
      ( ( merges9089515139780605204_merge(B,X2,Xa,Xb) = Y )
     => ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),merges2244889521215249637ge_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xa),Xb)))
       => ( ! [X3: B,Xs: list(B)] :
              ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
             => ! [Y4: B,Ys2: list(B)] :
                  ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2) )
                 => ( ( Y = $ite(aa(B,$o,aa(B,fun(B,$o),X2,X3),Y4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),merges9089515139780605204_merge(B,X2,Xs,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2))),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),merges9089515139780605204_merge(B,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs),Ys2))) )
                   => ~ aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),merges2244889521215249637ge_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2)))) ) ) )
         => ( ( ( Xb = nil(B) )
             => ( ( Y = Xa )
               => ~ aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),merges2244889521215249637ge_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xa),nil(B)))) ) )
           => ~ ( ( Xa = nil(B) )
               => ! [V4: B,Va: list(B)] :
                    ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                   => ( ( Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                     => ~ aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),merges2244889521215249637ge_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)))) ) ) ) ) ) ) ) ).

% mergesort_by_rel_merge.pelims
tff(fact_3660_subset__eq__mset__impl_Ocases,axiom,
    ! [B: $tType,X2: product_prod(list(B),list(B))] :
      ( ! [Ys2: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys2)
     => ~ ! [X3: B,Xs: list(B),Ys2: list(B)] : X2 != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Ys2) ) ).

% subset_eq_mset_impl.cases
tff(fact_3661_drop__upt,axiom,
    ! [M: nat,I: nat,J: nat] : drop(nat,M,upt(I,J)) = upt(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),M),J) ).

% drop_upt
tff(fact_3662_natural__zero__minus__one,axiom,
    aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),zero_zero(code_natural)),one_one(code_natural)) = zero_zero(code_natural) ).

% natural_zero_minus_one
tff(fact_3663_list__decode_Opsimps_I1_J,axiom,
    ( aa(nat,$o,accp(nat,nat_list_decode_rel),zero_zero(nat))
   => ( nat_list_decode(zero_zero(nat)) = nil(nat) ) ) ).

% list_decode.psimps(1)
tff(fact_3664_list__decode_Opsimps_I2_J,axiom,
    ! [N: nat] :
      ( aa(nat,$o,accp(nat,nat_list_decode_rel),aa(nat,nat,suc,N))
     => ( nat_list_decode(aa(nat,nat,suc,N)) = aa(product_prod(nat,nat),list(nat),aa(fun(nat,fun(nat,list(nat))),fun(product_prod(nat,nat),list(nat)),product_case_prod(nat,nat,list(nat)),aTP_Lamp_pg(nat,fun(nat,list(nat)))),nat_prod_decode(N)) ) ) ).

% list_decode.psimps(2)
tff(fact_3665_list__encode_Oelims,axiom,
    ! [X2: list(nat),Y: nat] :
      ( ( nat_list_encode(X2) = Y )
     => ( ( ( X2 = nil(nat) )
         => ( Y != zero_zero(nat) ) )
       => ~ ! [X3: nat,Xs: list(nat)] :
              ( ( X2 = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),X3),Xs) )
             => ( Y != aa(nat,nat,suc,aa(product_prod(nat,nat),nat,nat_prod_encode,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X3),nat_list_encode(Xs)))) ) ) ) ) ).

% list_encode.elims
tff(fact_3666_mergesort__remdups__correct,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B)] :
          ( distinct(B,aa(list(B),list(B),mergesort_remdups(B),L))
          & sorted_wrt(B,ord_less_eq(B),aa(list(B),list(B),mergesort_remdups(B),L))
          & ( aa(list(B),set(B),set2(B),aa(list(B),list(B),mergesort_remdups(B),L)) = aa(list(B),set(B),set2(B),L) ) ) ) ).

% mergesort_remdups_correct
tff(fact_3667_filter__upt__last,axiom,
    ! [B: $tType,P: fun(B,$o),L: list(B),Js: list(nat),J: nat,I: nat] :
      ( ( filter(nat,aa(list(B),fun(nat,$o),aTP_Lamp_ph(fun(B,$o),fun(list(B),fun(nat,$o)),P),L),upt(zero_zero(nat),aa(list(B),nat,size_size(list(B)),L))) = 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(B),nat,size_size(list(B)),L))
         => ~ aa(B,$o,P,aa(nat,B,nth(B,L),I)) ) ) ) ).

% filter_upt_last
tff(fact_3668_empty__append__eq__id,axiom,
    ! [B: $tType,X: list(B)] : aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),nil(B)),X) = X ).

% empty_append_eq_id
tff(fact_3669_op__conc__empty__img__id,axiom,
    ! [B: $tType,L6: set(list(B))] : aa(set(list(B)),set(list(B)),image2(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),nil(B))),L6) = L6 ).

% op_conc_empty_img_id
tff(fact_3670_list__e__eq__lel_I2_J,axiom,
    ! [B: $tType,L1: list(B),E5: B,L2: list(B),E2: B] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E5),L2)) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),nil(B)) )
    <=> ( ( L1 = nil(B) )
        & ( E5 = E2 )
        & ( L2 = nil(B) ) ) ) ).

% list_e_eq_lel(2)
tff(fact_3671_list__e__eq__lel_I1_J,axiom,
    ! [B: $tType,E2: B,L1: list(B),E5: B,L2: list(B)] :
      ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),nil(B)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E5),L2)) )
    <=> ( ( L1 = nil(B) )
        & ( E5 = E2 )
        & ( L2 = nil(B) ) ) ) ).

% list_e_eq_lel(1)
tff(fact_3672_list__se__match_I4_J,axiom,
    ! [B: $tType,L2: list(B),A3: B,L1: list(B)] :
      ( ( L2 != nil(B) )
     => ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),L2) )
      <=> ( ( L1 = nil(B) )
          & ( L2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) ) ) ) ) ).

% list_se_match(4)
tff(fact_3673_list__se__match_I3_J,axiom,
    ! [B: $tType,L1: list(B),A3: B,L2: list(B)] :
      ( ( L1 != nil(B) )
     => ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),L2) )
      <=> ( ( L1 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) )
          & ( L2 = nil(B) ) ) ) ) ).

% list_se_match(3)
tff(fact_3674_list__se__match_I2_J,axiom,
    ! [B: $tType,L2: list(B),L1: list(B),A3: B] :
      ( ( L2 != nil(B) )
     => ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),L2) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) )
      <=> ( ( L1 = nil(B) )
          & ( L2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) ) ) ) ) ).

% list_se_match(2)
tff(fact_3675_list__se__match_I1_J,axiom,
    ! [B: $tType,L1: list(B),L2: list(B),A3: B] :
      ( ( L1 != nil(B) )
     => ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),L2) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) )
      <=> ( ( L1 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),nil(B)) )
          & ( L2 = nil(B) ) ) ) ) ).

% list_se_match(1)
tff(fact_3676_list__ee__eq__leel_I2_J,axiom,
    ! [B: $tType,L1: list(B),E12: B,E23: B,L2: list(B),E1: B,E22: B] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E23),L2))) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E22),nil(B))) )
    <=> ( ( L1 = nil(B) )
        & ( E1 = E12 )
        & ( E22 = E23 )
        & ( L2 = nil(B) ) ) ) ).

% list_ee_eq_leel(2)
tff(fact_3677_list__ee__eq__leel_I1_J,axiom,
    ! [B: $tType,E1: B,E22: B,L1: list(B),E12: B,E23: B,L2: list(B)] :
      ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E22),nil(B))) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E23),L2))) )
    <=> ( ( L1 = nil(B) )
        & ( E1 = E12 )
        & ( E22 = E23 )
        & ( L2 = nil(B) ) ) ) ).

% list_ee_eq_leel(1)
tff(fact_3678_length__append,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] : aa(list(B),nat,size_size(list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(list(B),nat,size_size(list(B)),Ys)) ).

% length_append
tff(fact_3679_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_3680_nth__append__first,axiom,
    ! [B: $tType,I: nat,L: list(B),L4: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
     => ( aa(nat,B,nth(B,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L),L4)),I) = aa(nat,B,nth(B,L),I) ) ) ).

% nth_append_first
tff(fact_3681_nth__append__length__plus,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),N: nat] : aa(nat,B,nth(B,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),N)) = aa(nat,B,nth(B,Ys),N) ).

% nth_append_length_plus
tff(fact_3682_list__match__lel__lel,axiom,
    ! [B: $tType,C1: list(B),Qs: B,C22: list(B),C12: list(B),Qs2: B,C23: list(B)] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),C1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Qs),C22)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),C12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Qs2),C23)) )
     => ( ! [C21: list(B)] :
            ( ( C1 = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),C12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Qs2),C21)) )
           => ( C23 != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),C21),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Qs),C22)) ) )
       => ( ( ( C12 = C1 )
           => ( ( Qs2 = Qs )
             => ( C23 != C22 ) ) )
         => ~ ! [C212: list(B)] :
                ( ( C12 = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),C1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Qs),C212)) )
               => ( C22 != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),C212),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Qs2),C23)) ) ) ) ) ) ).

% list_match_lel_lel
tff(fact_3683_foldl__conc__empty__eq,axiom,
    ! [B: $tType,I: list(B),Ww: list(list(B))] : aa(list(list(B)),list(B),aa(list(B),fun(list(list(B)),list(B)),foldl(list(B),list(B),append(B)),I),Ww) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),I),aa(list(list(B)),list(B),aa(list(B),fun(list(list(B)),list(B)),foldl(list(B),list(B),append(B)),nil(B)),Ww)) ).

% foldl_conc_empty_eq
tff(fact_3684_Misc_Omap__eq__append__conv,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),Ls: list(C),Fl: list(B),Fl2: list(B)] :
      ( ( aa(list(C),list(B),map(C,B,F),Ls) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Fl),Fl2) )
    <=> ? [L3: list(C),L7: list(C)] :
          ( ( Ls = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L3),L7) )
          & ( aa(list(C),list(B),map(C,B,F),L3) = Fl )
          & ( aa(list(C),list(B),map(C,B,F),L7) = Fl2 ) ) ) ).

% Misc.map_eq_append_conv
tff(fact_3685_Misc_Oappend__eq__map__conv,axiom,
    ! [C: $tType,B: $tType,Fl: list(B),Fl2: list(B),F: fun(C,B),Ls: list(C)] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Fl),Fl2) = aa(list(C),list(B),map(C,B,F),Ls) )
    <=> ? [L3: list(C),L7: list(C)] :
          ( ( Ls = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L3),L7) )
          & ( aa(list(C),list(B),map(C,B,F),L3) = Fl )
          & ( aa(list(C),list(B),map(C,B,F),L7) = Fl2 ) ) ) ).

% Misc.append_eq_map_conv
tff(fact_3686_map__eq__appendE,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),Ls: list(C),Fl: list(B),Fl2: list(B)] :
      ( ( aa(list(C),list(B),map(C,B,F),Ls) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Fl),Fl2) )
     => ~ ! [L5: list(C),L8: list(C)] :
            ( ( Ls = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L5),L8) )
           => ( ( aa(list(C),list(B),map(C,B,F),L5) = Fl )
             => ( aa(list(C),list(B),map(C,B,F),L8) != Fl2 ) ) ) ) ).

% map_eq_appendE
tff(fact_3687_append__eq__mapE,axiom,
    ! [C: $tType,B: $tType,Fl: list(B),Fl2: list(B),F: fun(C,B),Ls: list(C)] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Fl),Fl2) = aa(list(C),list(B),map(C,B,F),Ls) )
     => ~ ! [L5: list(C),L8: list(C)] :
            ( ( Ls = aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L5),L8) )
           => ( ( aa(list(C),list(B),map(C,B,F),L5) = Fl )
             => ( aa(list(C),list(B),map(C,B,F),L8) != Fl2 ) ) ) ) ).

% append_eq_mapE
tff(fact_3688_enumerate__append__eq,axiom,
    ! [B: $tType,N: nat,Xsa: list(B),Ys: list(B)] : enumerate(B,N,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)) = aa(list(product_prod(nat,B)),list(product_prod(nat,B)),aa(list(product_prod(nat,B)),fun(list(product_prod(nat,B)),list(product_prod(nat,B))),append(product_prod(nat,B)),enumerate(B,N,Xsa)),enumerate(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(B),nat,size_size(list(B)),Xsa)),Ys)) ).

% enumerate_append_eq
tff(fact_3689_neq__Nil__revE,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( L != nil(B) )
     => ~ ! [Ll2: list(B),E3: B] : L != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ll2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E3),nil(B))) ) ).

% neq_Nil_revE
tff(fact_3690_rev__induct2_H,axiom,
    ! [B: $tType,C: $tType,P: fun(list(B),fun(list(C),$o)),Xsa: list(B),Ys: list(C)] :
      ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,nil(B)),nil(C))
     => ( ! [X3: B,Xs: list(B)] : aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xs),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))),nil(C))
       => ( ! [Y4: C,Ys2: list(C)] : aa(list(C),$o,aa(list(B),fun(list(C),$o),P,nil(B)),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),Y4),nil(C))))
         => ( ! [X3: B,Xs: list(B),Y4: C,Ys2: list(C)] :
                ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xs),Ys2)
               => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xs),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))),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),Y4),nil(C)))) )
           => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xsa),Ys) ) ) ) ) ).

% rev_induct2'
tff(fact_3691_neq__Nil__rev__conv,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( L != nil(B) )
    <=> ? [Xs4: list(B),X4: B] : L = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xs4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X4),nil(B))) ) ).

% neq_Nil_rev_conv
tff(fact_3692_rev__nonempty__induct2_H,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),P: fun(list(B),fun(list(C),$o))] :
      ( ( Xsa != nil(B) )
     => ( ( Ys != nil(C) )
       => ( ! [X3: B,Y4: C] : aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),nil(C)))
         => ( ! [X3: B,Xs: list(B),Y4: C] :
                ( ( Xs != nil(B) )
               => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xs),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),nil(C))) )
           => ( ! [X3: B,Y4: C,Ys2: list(C)] :
                  ( ( Ys2 != nil(C) )
                 => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B))),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),Y4),nil(C)))) )
             => ( ! [X3: B,Xs: list(B),Y4: C,Ys2: list(C)] :
                    ( aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xs),Ys2)
                   => ( ( Xs != nil(B) )
                     => ( ( Ys2 != nil(C) )
                       => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xs),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))),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),Y4),nil(C)))) ) ) )
               => aa(list(C),$o,aa(list(B),fun(list(C),$o),P,Xsa),Ys) ) ) ) ) ) ) ).

% rev_nonempty_induct2'
tff(fact_3693_list__Cons__eq__append__cases,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Ys: list(B),Zs: list(B)] :
      ( ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Zs) )
     => ( ( ( Ys = nil(B) )
         => ( Zs != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) ) )
       => ~ ! [Ys3: list(B)] :
              ( ( Ys = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Ys3) )
             => ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys3),Zs) != Xsa ) ) ) ) ).

% list_Cons_eq_append_cases
tff(fact_3694_list__append__eq__Cons__cases,axiom,
    ! [B: $tType,Ys: list(B),Zs: list(B),X2: B,Xsa: list(B)] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Zs) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) )
     => ( ( ( Ys = nil(B) )
         => ( Zs != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) ) )
       => ~ ! [Ys3: list(B)] :
              ( ( Ys = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Ys3) )
             => ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys3),Zs) != Xsa ) ) ) ) ).

% list_append_eq_Cons_cases
tff(fact_3695_in__set__list__format,axiom,
    ! [B: $tType,E2: B,L: list(B)] :
      ( member(B,E2,aa(list(B),set(B),set2(B),L))
     => ~ ! [L12: list(B),L22: list(B)] : L != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),L22)) ) ).

% in_set_list_format
tff(fact_3696_xy__in__set__cases,axiom,
    ! [B: $tType,X2: B,L: list(B),Y: B] :
      ( member(B,X2,aa(list(B),set(B),set2(B),L))
     => ( member(B,Y,aa(list(B),set(B),set2(B),L))
       => ( ( ( X2 = Y )
           => ! [L12: list(B),L22: list(B)] : L != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),L22)) )
         => ( ( ( X2 != Y )
             => ! [L12: list(B),L22: list(B),L32: list(B)] : L != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L22),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),L32)))) )
           => ~ ( ( X2 != Y )
               => ! [L12: list(B),L22: list(B),L32: list(B)] : L != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L12),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L22),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),L32)))) ) ) ) ) ) ).

% xy_in_set_cases
tff(fact_3697_map__consI_I2_J,axiom,
    ! [C: $tType,B: $tType,W: list(B),L: list(B),F: fun(C,B),Ww: list(C),A3: C] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),W),L) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),aa(list(C),list(B),map(C,B,F),Ww)),L) )
     => ( aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(C,B,F,A3)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),W),L)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),aa(list(C),list(B),map(C,B,F),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),Ww))),L) ) ) ).

% map_consI(2)
tff(fact_3698_list__rest__coinc,axiom,
    ! [B: $tType,S22: list(B),S1: list(B),R1: list(B),R22: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),S22)),aa(list(B),nat,size_size(list(B)),S1))
     => ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),S1),R1) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),S22),R22) )
       => ? [R1p: list(B)] : R22 = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),R1p),R1) ) ) ).

% list_rest_coinc
tff(fact_3699_set__union__code,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(list(B),set(B),set2(B),Xsa)),aa(list(B),set(B),set2(B),Ys)) = aa(list(B),set(B),set2(B),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)) ).

% set_union_code
tff(fact_3700_distinct__match,axiom,
    ! [B: $tType,Al: list(B),E2: B,Bl: list(B),Al2: list(B),Bl2: list(B)] :
      ( distinct(B,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),Bl)))
     => ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),Bl)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),Bl2)) )
      <=> ( ( Al = Al2 )
          & ( Bl = Bl2 ) ) ) ) ).

% distinct_match
tff(fact_3701_upt__eq__append__conv,axiom,
    ! [I: nat,J: nat,Xsa: 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),Xsa),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) = Xsa )
            & ( upt(K4,J) = Ys ) ) ) ) ).

% upt_eq_append_conv
tff(fact_3702_replicate__add,axiom,
    ! [B: $tType,N: nat,M: nat,X2: B] : replicate(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M),X2) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),replicate(B,N,X2)),replicate(B,M,X2)) ).

% replicate_add
tff(fact_3703_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_3704_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_3705_foldl__rule,axiom,
    ! [B: $tType,C: $tType,I4: fun(B,fun(list(C),fun(list(C),$o))),Sigma_0: B,L0: list(C),F: fun(B,fun(C,B))] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,Sigma_0),nil(C)),L0)
     => ( ! [L12: list(C),L22: list(C),X3: C,Sigma: B] :
            ( ( L0 = 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),X3),L22)) )
           => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,Sigma),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X3),L22))
             => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,aa(C,B,aa(B,fun(C,B),F,Sigma),X3)),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),X3),nil(C)))),L22) ) )
       => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,aa(list(C),B,aa(B,fun(list(C),B),foldl(B,C,F),Sigma_0),L0)),L0),nil(C)) ) ) ).

% foldl_rule
tff(fact_3706_foldl__rule__P,axiom,
    ! [B: $tType,C: $tType,I4: fun(B,fun(list(C),fun(list(C),$o))),Sigma_0: B,L0: list(C),F: fun(B,fun(C,B)),P: fun(B,$o)] :
      ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,Sigma_0),nil(C)),L0)
     => ( ! [L12: list(C),L22: list(C),X3: C,Sigma: B] :
            ( ( L0 = 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),X3),L22)) )
           => ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,Sigma),L12),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X3),L22))
             => aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,aa(C,B,aa(B,fun(C,B),F,Sigma),X3)),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),X3),nil(C)))),L22) ) )
       => ( ! [Sigma: B] :
              ( aa(list(C),$o,aa(list(C),fun(list(C),$o),aa(B,fun(list(C),fun(list(C),$o)),I4,Sigma),L0),nil(C))
             => aa(B,$o,P,Sigma) )
         => aa(B,$o,P,aa(list(C),B,aa(B,fun(list(C),B),foldl(B,C,F),Sigma_0),L0)) ) ) ) ).

% foldl_rule_P
tff(fact_3707_foldl__rule__aux,axiom,
    ! [B: $tType,C: $tType,I4: fun(B,fun(list(C),$o)),Sigma_0: B,L0: list(C),F: fun(B,fun(C,B))] :
      ( aa(list(C),$o,aa(B,fun(list(C),$o),I4,Sigma_0),L0)
     => ( ! [L12: list(C),L22: list(C),X3: C,Sigma: B] :
            ( ( L0 = 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),X3),L22)) )
           => ( aa(list(C),$o,aa(B,fun(list(C),$o),I4,Sigma),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X3),L22))
             => aa(list(C),$o,aa(B,fun(list(C),$o),I4,aa(C,B,aa(B,fun(C,B),F,Sigma),X3)),L22) ) )
       => aa(list(C),$o,aa(B,fun(list(C),$o),I4,aa(list(C),B,aa(B,fun(list(C),B),foldl(B,C,F),Sigma_0),L0)),nil(C)) ) ) ).

% foldl_rule_aux
tff(fact_3708_foldl__rule__aux__P,axiom,
    ! [B: $tType,C: $tType,I4: fun(B,fun(list(C),$o)),Sigma_0: B,L0: list(C),F: fun(B,fun(C,B)),P: fun(B,$o)] :
      ( aa(list(C),$o,aa(B,fun(list(C),$o),I4,Sigma_0),L0)
     => ( ! [L12: list(C),L22: list(C),X3: C,Sigma: B] :
            ( ( L0 = 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),X3),L22)) )
           => ( aa(list(C),$o,aa(B,fun(list(C),$o),I4,Sigma),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X3),L22))
             => aa(list(C),$o,aa(B,fun(list(C),$o),I4,aa(C,B,aa(B,fun(C,B),F,Sigma),X3)),L22) ) )
       => ( ! [Sigma: B] :
              ( aa(list(C),$o,aa(B,fun(list(C),$o),I4,Sigma),nil(C))
             => aa(B,$o,P,Sigma) )
         => aa(B,$o,P,aa(list(C),B,aa(B,fun(list(C),B),foldl(B,C,F),Sigma_0),L0)) ) ) ) ).

% foldl_rule_aux_P
tff(fact_3709_map__by__foldl,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),L: list(C)] : aa(list(C),list(B),aa(list(B),fun(list(C),list(B)),foldl(list(B),C,aTP_Lamp_pi(fun(C,B),fun(list(B),fun(C,list(B))),F)),nil(B)),L) = aa(list(C),list(B),map(C,B,F),L) ).

% map_by_foldl
tff(fact_3710_length__Suc__rev__conv,axiom,
    ! [B: $tType,Xsa: list(B),N: nat] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(nat,nat,suc,N) )
    <=> ? [Ys4: list(B),Y3: B] :
          ( ( Xsa = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y3),nil(B))) )
          & ( aa(list(B),nat,size_size(list(B)),Ys4) = N ) ) ) ).

% length_Suc_rev_conv
tff(fact_3711_length__compl__rev__induct,axiom,
    ! [B: $tType,P: fun(list(B),$o),L: list(B)] :
      ( aa(list(B),$o,P,nil(B))
     => ( ! [L5: list(B),E3: B] :
            ( ! [Ll: list(B)] :
                ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Ll)),aa(list(B),nat,size_size(list(B)),L5))
               => aa(list(B),$o,P,Ll) )
           => aa(list(B),$o,P,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L5),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E3),nil(B)))) )
       => aa(list(B),$o,P,L) ) ) ).

% length_compl_rev_induct
tff(fact_3712_not__distinct__split__distinct,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ~ distinct(B,Xsa)
     => ~ ! [Y4: B,Ys2: list(B)] :
            ( distinct(B,Ys2)
           => ( member(B,Y4,aa(list(B),set(B),set2(B),Ys2))
             => ! [Zs2: list(B)] : Xsa != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys2),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),nil(B))),Zs2)) ) ) ) ).

% not_distinct_split_distinct
tff(fact_3713_filter__eq__snocD,axiom,
    ! [B: $tType,P: fun(B,$o),L: list(B),L4: list(B),X2: B] :
      ( ( filter(B,P,L) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L4),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) )
     => ( member(B,X2,aa(list(B),set(B),set2(B),L))
        & aa(B,$o,P,X2) ) ) ).

% filter_eq_snocD
tff(fact_3714_replicate__Suc__conv__snoc,axiom,
    ! [B: $tType,N: nat,X2: B] : replicate(B,aa(nat,nat,suc,N),X2) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),replicate(B,N,X2)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) ).

% replicate_Suc_conv_snoc
tff(fact_3715_slice__prepend,axiom,
    ! [B: $tType,I: nat,K: nat,Xsa: list(B),Ys: list(B)] :
      ( 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(B),nat,size_size(list(B)),Xsa))
       => $let(
            p: nat,
            p:= aa(list(B),nat,size_size(list(B)),Ys),
            slice(B,I,K,Xsa) = slice(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),p),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),K),p),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Xsa)) ) ) ) ).

% slice_prepend
tff(fact_3716_sorted__append__bigger,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B),Y: B] :
          ( sorted_wrt(B,ord_less_eq(B),Xsa)
         => ( ! [X3: B] :
                ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
               => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X3),Y) )
           => sorted_wrt(B,ord_less_eq(B),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),nil(B)))) ) ) ) ).

% sorted_append_bigger
tff(fact_3717_upt__eq__lel__conv,axiom,
    ! [L: nat,Ha: nat,Is1: list(nat),I: nat,Is2: list(nat)] :
      ( ( upt(L,Ha) = 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(L,I) )
        & ( Is2 = upt(aa(nat,nat,suc,I),Ha) )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),L),I)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),Ha) ) ) ).

% upt_eq_lel_conv
tff(fact_3718_list__encode_Osimps_I2_J,axiom,
    ! [X2: nat,Xsa: list(nat)] : nat_list_encode(aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),X2),Xsa)) = aa(nat,nat,suc,aa(product_prod(nat,nat),nat,nat_prod_encode,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X2),nat_list_encode(Xsa)))) ).

% list_encode.simps(2)
tff(fact_3719_list__encode_Opelims,axiom,
    ! [X2: list(nat),Y: nat] :
      ( ( nat_list_encode(X2) = Y )
     => ( aa(list(nat),$o,accp(list(nat),nat_list_encode_rel),X2)
       => ( ( ( X2 = nil(nat) )
           => ( ( Y = zero_zero(nat) )
             => ~ aa(list(nat),$o,accp(list(nat),nat_list_encode_rel),nil(nat)) ) )
         => ~ ! [X3: nat,Xs: list(nat)] :
                ( ( X2 = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),X3),Xs) )
               => ( ( Y = aa(nat,nat,suc,aa(product_prod(nat,nat),nat,nat_prod_encode,aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X3),nat_list_encode(Xs)))) )
                 => ~ aa(list(nat),$o,accp(list(nat),nat_list_encode_rel),aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),X3),Xs)) ) ) ) ) ) ).

% list_encode.pelims
tff(fact_3720_map__upds__append1,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C),M: fun(B,option(C)),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(list(C),nat,size_size(list(C)),Ys))
     => ( map_upds(B,C,M,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))),Ys) = fun_upd(B,option(C),map_upds(B,C,M,Xsa,Ys),X2,aa(C,option(C),some(C),aa(nat,C,nth(C,Ys),aa(list(B),nat,size_size(list(B)),Xsa)))) ) ) ).

% map_upds_append1
tff(fact_3721_lexn__conv,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),N: nat] : lexn(B,R,N) = aa(fun(product_prod(list(B),list(B)),$o),set(product_prod(list(B),list(B))),collect(product_prod(list(B),list(B))),aa(fun(list(B),fun(list(B),$o)),fun(product_prod(list(B),list(B)),$o),product_case_prod(list(B),list(B),$o),aa(nat,fun(list(B),fun(list(B),$o)),aTP_Lamp_pj(set(product_prod(B,B)),fun(nat,fun(list(B),fun(list(B),$o))),R),N))) ).

% lexn_conv
tff(fact_3722_drop__last__conv,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( L != nil(B) )
     => ( drop(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),L)),aa(nat,nat,suc,zero_zero(nat))),L) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),last(B,L)),nil(B)) ) ) ).

% drop_last_conv
tff(fact_3723_Misc_Olast__in__set,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( L != nil(B) )
     => member(B,last(B,L),aa(list(B),set(B),set2(B),L)) ) ).

% Misc.last_in_set
tff(fact_3724_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)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),one_one(nat)) ) ) ).

% last_upt
tff(fact_3725_map__upds__Cons,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),A3: B,As2: list(B),B2: C,Bs2: list(C)] : map_upds(B,C,M,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),As2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B2),Bs2)) = map_upds(B,C,fun_upd(B,option(C),M,A3,aa(C,option(C),some(C),B2)),As2,Bs2) ).

% map_upds_Cons
tff(fact_3726_map__upds__twist,axiom,
    ! [B: $tType,C: $tType,A3: B,As2: list(B),M: fun(B,option(C)),B2: C,Bs2: list(C)] :
      ( ~ member(B,A3,aa(list(B),set(B),set2(B),As2))
     => ( map_upds(B,C,fun_upd(B,option(C),M,A3,aa(C,option(C),some(C),B2)),As2,Bs2) = fun_upd(B,option(C),map_upds(B,C,M,As2,Bs2),A3,aa(C,option(C),some(C),B2)) ) ) ).

% map_upds_twist
tff(fact_3727_last__filter,axiom,
    ! [B: $tType,Xsa: list(B),P: fun(B,$o)] :
      ( ( Xsa != nil(B) )
     => ( aa(B,$o,P,last(B,Xsa))
       => ( last(B,filter(B,P,Xsa)) = last(B,Xsa) ) ) ) ).

% last_filter
tff(fact_3728_lexn__length,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B)),N: nat] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lexn(B,R,N))
     => ( ( aa(list(B),nat,size_size(list(B)),Xsa) = N )
        & ( aa(list(B),nat,size_size(list(B)),Ys) = N ) ) ) ).

% lexn_length
tff(fact_3729_product_Osimps_I2_J,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(B),Ys: list(C)] : product(B,C,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Ys) = aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),aa(list(C),list(product_prod(B,C)),map(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2)),Ys)),product(B,C,Xsa,Ys)) ).

% product.simps(2)
tff(fact_3730_map__of__Some__split,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(C,B)),K: C,V: B] :
      ( ( aa(C,option(B),map_of(C,B,Xsa),K) = aa(B,option(B),some(B),V) )
     => ? [Ys2: list(product_prod(C,B)),Zs2: list(product_prod(C,B))] :
          ( ( Xsa = aa(list(product_prod(C,B)),list(product_prod(C,B)),aa(list(product_prod(C,B)),fun(list(product_prod(C,B)),list(product_prod(C,B))),append(product_prod(C,B)),Ys2),aa(list(product_prod(C,B)),list(product_prod(C,B)),aa(product_prod(C,B),fun(list(product_prod(C,B)),list(product_prod(C,B))),cons(product_prod(C,B)),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),K),V)),Zs2)) )
          & ( aa(C,option(B),map_of(C,B,Ys2),K) = none(B) ) ) ) ).

% map_of_Some_split
tff(fact_3731_last__conv__nth,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( Xsa != nil(B) )
     => ( last(B,Xsa) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat))) ) ) ).

% last_conv_nth
tff(fact_3732_map__of__distinct__lookup,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(product_prod(B,C)),Ys: list(product_prod(B,C)),Y: C] :
      ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa)))
     => ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Ys)))
       => ( aa(B,option(C),map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),Ys))),X2) = aa(C,option(C),some(C),Y) ) ) ) ).

% map_of_distinct_lookup
tff(fact_3733_map__of__distinct__upd3,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(product_prod(B,C)),Ys: list(product_prod(B,C)),Y: C,Y6: C] :
      ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa)))
     => ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Ys)))
       => ( map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),Ys))) = fun_upd(B,option(C),map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y6)),Ys))),X2,aa(C,option(C),some(C),Y)) ) ) ) ).

% map_of_distinct_upd3
tff(fact_3734_map__of__distinct__upd2,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(product_prod(B,C)),Ys: list(product_prod(B,C)),Y: C] :
      ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa)))
     => ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Ys)))
       => ( map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),Ys))) = fun_upd(B,option(C),map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),Ys)),X2,aa(C,option(C),some(C),Y)) ) ) ) ).

% map_of_distinct_upd2
tff(fact_3735_map__of__distinct__upd4,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(product_prod(B,C)),Ys: list(product_prod(B,C)),Y: C] :
      ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa)))
     => ( ~ member(B,X2,aa(list(B),set(B),set2(B),aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Ys)))
       => ( map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),Ys)) = fun_upd(B,option(C),map_of(B,C,aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(list(product_prod(B,C)),fun(list(product_prod(B,C)),list(product_prod(B,C))),append(product_prod(B,C)),Xsa),aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),Ys))),X2,none(C)) ) ) ) ).

% map_of_distinct_upd4
tff(fact_3736_lex__conv,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : lex(B,R) = aa(fun(product_prod(list(B),list(B)),$o),set(product_prod(list(B),list(B))),collect(product_prod(list(B),list(B))),aa(fun(list(B),fun(list(B),$o)),fun(product_prod(list(B),list(B)),$o),product_case_prod(list(B),list(B),$o),aTP_Lamp_pk(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),R))) ).

% lex_conv
tff(fact_3737_shuffles_Opelims,axiom,
    ! [B: $tType,X2: list(B),Xa: list(B),Y: set(list(B))] :
      ( ( shuffles(B,X2,Xa) = Y )
     => ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Xa))
       => ( ( ( X2 = nil(B) )
           => ( ( Y = aa(set(list(B)),set(list(B)),insert2(list(B),Xa),bot_bot(set(list(B)))) )
             => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Xa)) ) )
         => ( ( ( Xa = nil(B) )
             => ( ( Y = aa(set(list(B)),set(list(B)),insert2(list(B),X2),bot_bot(set(list(B)))) )
               => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),nil(B))) ) )
           => ~ ! [X3: B,Xs: list(B)] :
                  ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
                 => ! [Y4: B,Ys2: list(B)] :
                      ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2) )
                     => ( ( Y = aa(set(list(B)),set(list(B)),aa(set(list(B)),fun(set(list(B)),set(list(B))),sup_sup(set(list(B))),aa(set(list(B)),set(list(B)),image2(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3)),shuffles(B,Xs,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2)))),aa(set(list(B)),set(list(B)),image2(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4)),shuffles(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs),Ys2))) )
                       => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2))) ) ) ) ) ) ) ) ).

% shuffles.pelims
tff(fact_3738_set__relcomp,axiom,
    ! [C: $tType,D: $tType,B: $tType,Xys: list(product_prod(B,D)),Yzs: list(product_prod(D,C))] : relcomp(B,D,C,aa(list(product_prod(B,D)),set(product_prod(B,D)),set2(product_prod(B,D)),Xys),aa(list(product_prod(D,C)),set(product_prod(D,C)),set2(product_prod(D,C)),Yzs)) = aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),concat(product_prod(B,C),aa(list(product_prod(B,D)),list(list(product_prod(B,C))),map(product_prod(B,D),list(product_prod(B,C)),aTP_Lamp_pm(list(product_prod(D,C)),fun(product_prod(B,D),list(product_prod(B,C))),Yzs)),Xys))) ).

% set_relcomp
tff(fact_3739_natural_Osimps_I4_J,axiom,
    ! [B: $tType,F1: B,F22: fun(code_natural,B)] : aa(code_natural,B,code_case_natural(B,F1,F22),zero_zero(code_natural)) = F1 ).

% natural.simps(4)
tff(fact_3740_Cons__in__lex,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Y: B,Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)),lex(B,R))
    <=> ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
          & ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(B),nat,size_size(list(B)),Ys) ) )
        | ( ( X2 = Y )
          & member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lex(B,R)) ) ) ) ).

% Cons_in_lex
tff(fact_3741_concat__filter__neq__Nil,axiom,
    ! [B: $tType,Xsa: list(list(B))] : concat(B,filter(list(B),aTP_Lamp_pn(list(B),$o),Xsa)) = concat(B,Xsa) ).

% concat_filter_neq_Nil
tff(fact_3742_Nil__notin__lex,axiom,
    ! [B: $tType,Ys: list(B),R: set(product_prod(B,B))] : ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys),lex(B,R)) ).

% Nil_notin_lex
tff(fact_3743_Nil2__notin__lex,axiom,
    ! [B: $tType,Xsa: list(B),R: set(product_prod(B,B))] : ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),nil(B)),lex(B,R)) ).

% Nil2_notin_lex
tff(fact_3744_lex__append__leftI,axiom,
    ! [B: $tType,Ys: list(B),Zs: list(B),R: set(product_prod(B,B)),Xsa: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),lex(B,R))
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Zs)),lex(B,R)) ) ).

% lex_append_leftI
tff(fact_3745_foldl__foldl__conv__concat,axiom,
    ! [B: $tType,C: $tType,F: fun(B,fun(C,B)),A3: B,Xsa: list(list(C))] : aa(list(list(C)),B,aa(B,fun(list(list(C)),B),foldl(B,list(C),foldl(B,C,F)),A3),Xsa) = aa(list(C),B,aa(B,fun(list(C),B),foldl(B,C,F),A3),concat(C,Xsa)) ).

% foldl_foldl_conv_concat
tff(fact_3746_product__concat__map,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C)] : product(B,C,Xsa,Ys) = concat(product_prod(B,C),aa(list(B),list(list(product_prod(B,C))),map(B,list(product_prod(B,C)),aTP_Lamp_po(list(C),fun(B,list(product_prod(B,C))),Ys)),Xsa)) ).

% product_concat_map
tff(fact_3747_lex__append__left__iff,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),Xsa: list(B),Ys: list(B),Zs: list(B)] :
      ( ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),R)
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Zs)),lex(B,R))
      <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),lex(B,R)) ) ) ).

% lex_append_left_iff
tff(fact_3748_lex__append__leftD,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),Xsa: list(B),Ys: list(B),Zs: list(B)] :
      ( ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),R)
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Zs)),lex(B,R))
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),lex(B,R)) ) ) ).

% lex_append_leftD
tff(fact_3749_lex__append__rightI,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B)),Vs: list(B),Us: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lex(B,R))
     => ( ( aa(list(B),nat,size_size(list(B)),Vs) = aa(list(B),nat,size_size(list(B)),Us) )
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Us)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Vs)),lex(B,R)) ) ) ).

% lex_append_rightI
tff(fact_3750_map__of__concat,axiom,
    ! [C: $tType,B: $tType,Xss: list(list(product_prod(B,C)))] : map_of(B,C,concat(product_prod(B,C),Xss)) = aa(fun(B,option(C)),fun(B,option(C)),foldr(list(product_prod(B,C)),fun(B,option(C)),aTP_Lamp_pp(list(product_prod(B,C)),fun(fun(B,option(C)),fun(B,option(C)))),Xss),aTP_Lamp_hj(B,option(C))) ).

% map_of_concat
tff(fact_3751_comm__append__is__replicate,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] :
      ( ( Xsa != nil(B) )
     => ( ( Ys != nil(B) )
       => ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Xsa) )
         => ? [N3: nat,Zs2: list(B)] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),N3)
              & ( concat(B,replicate(list(B),N3,Zs2)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys) ) ) ) ) ) ).

% comm_append_is_replicate
tff(fact_3752_shuffles_Opinduct,axiom,
    ! [B: $tType,A0: list(B),A1: list(B),P: fun(list(B),fun(list(B),$o))] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),A0),A1))
     => ( ! [Ys2: list(B)] :
            ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys2))
           => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,nil(B)),Ys2) )
       => ( ! [Xs: list(B)] :
              ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs),nil(B)))
             => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,Xs),nil(B)) )
         => ( ! [X3: B,Xs: list(B),Y4: B,Ys2: list(B)] :
                ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2)))
               => ( aa(list(B),$o,aa(list(B),fun(list(B),$o),P,Xs),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2))
                 => ( aa(list(B),$o,aa(list(B),fun(list(B),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Ys2)
                   => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Ys2)) ) ) )
           => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,A0),A1) ) ) ) ) ).

% shuffles.pinduct
tff(fact_3753_shuffles_Opsimps_I1_J,axiom,
    ! [B: $tType,Ys: list(B)] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys))
     => ( shuffles(B,nil(B),Ys) = aa(set(list(B)),set(list(B)),insert2(list(B),Ys),bot_bot(set(list(B)))) ) ) ).

% shuffles.psimps(1)
tff(fact_3754_shuffles_Opsimps_I2_J,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),nil(B)))
     => ( shuffles(B,Xsa,nil(B)) = aa(set(list(B)),set(list(B)),insert2(list(B),Xsa),bot_bot(set(list(B)))) ) ) ).

% shuffles.psimps(2)
tff(fact_3755_distinct__concat_H,axiom,
    ! [B: $tType,Xsa: list(list(B))] :
      ( distinct(list(B),filter(list(B),aTP_Lamp_pn(list(B),$o),Xsa))
     => ( ! [Ys2: list(B)] :
            ( member(list(B),Ys2,aa(list(list(B)),set(list(B)),set2(list(B)),Xsa))
           => distinct(B,Ys2) )
       => ( ! [Ys2: list(B),Zs2: list(B)] :
              ( member(list(B),Ys2,aa(list(list(B)),set(list(B)),set2(list(B)),Xsa))
             => ( member(list(B),Zs2,aa(list(list(B)),set(list(B)),set2(list(B)),Xsa))
               => ( ( Ys2 != Zs2 )
                 => ( aa(set(B),set(B),inf_inf(set(B),aa(list(B),set(B),set2(B),Ys2)),aa(list(B),set(B),set2(B),Zs2)) = bot_bot(set(B)) ) ) ) )
         => distinct(B,concat(B,Xsa)) ) ) ) ).

% distinct_concat'
tff(fact_3756_shuffles_Opsimps_I3_J,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Y: B,Ys: list(B)] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),shuffles_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)))
     => ( shuffles(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)) = aa(set(list(B)),set(list(B)),aa(set(list(B)),fun(set(list(B)),set(list(B))),sup_sup(set(list(B))),aa(set(list(B)),set(list(B)),image2(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2)),shuffles(B,Xsa,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)))),aa(set(list(B)),set(list(B)),image2(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y)),shuffles(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Ys))) ) ) ).

% shuffles.psimps(3)
tff(fact_3757_product__code,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C)] : product_product(B,C,aa(list(B),set(B),set2(B),Xsa),aa(list(C),set(C),set2(C),Ys)) = aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),concat(product_prod(B,C),aa(list(B),list(list(product_prod(B,C))),map(B,list(product_prod(B,C)),aTP_Lamp_po(list(C),fun(B,list(product_prod(B,C))),Ys)),Xsa))) ).

% product_code
tff(fact_3758_lenlex__conv,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : lenlex(B,R) = aa(fun(product_prod(list(B),list(B)),$o),set(product_prod(list(B),list(B))),collect(product_prod(list(B),list(B))),aa(fun(list(B),fun(list(B),$o)),fun(product_prod(list(B),list(B)),$o),product_case_prod(list(B),list(B),$o),aTP_Lamp_pq(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),R))) ).

% lenlex_conv
tff(fact_3759_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),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),aa(nat,nat,suc,I)))
     => ( aa(nat,nat,nth(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_3760_splice_Opinduct,axiom,
    ! [B: $tType,A0: list(B),A1: list(B),P: fun(list(B),fun(list(B),$o))] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),A0),A1))
     => ( ! [Ys2: list(B)] :
            ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys2))
           => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,nil(B)),Ys2) )
       => ( ! [X3: B,Xs: list(B),Ys2: list(B)] :
              ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Ys2))
             => ( aa(list(B),$o,aa(list(B),fun(list(B),$o),P,Ys2),Xs)
               => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Ys2) ) )
         => aa(list(B),$o,aa(list(B),fun(list(B),$o),P,A0),A1) ) ) ) ).

% splice.pinduct
tff(fact_3761_Nil__lenlex__iff1,axiom,
    ! [B: $tType,Ns: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ns),lenlex(B,R))
    <=> ( Ns != nil(B) ) ) ).

% Nil_lenlex_iff1
tff(fact_3762_lenlex__irreflexive,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),Xsa: list(B)] :
      ( ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),R)
     => ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Xsa),lenlex(B,R)) ) ).

% lenlex_irreflexive
tff(fact_3763_Nil__lenlex__iff2,axiom,
    ! [B: $tType,Ns: list(B),R: set(product_prod(B,B))] : ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ns),nil(B)),lenlex(B,R)) ).

% Nil_lenlex_iff2
tff(fact_3764_lenlex__length,axiom,
    ! [B: $tType,Ms: list(B),Ns: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ms),Ns),lenlex(B,R))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Ms)),aa(list(B),nat,size_size(list(B)),Ns)) ) ).

% lenlex_length
tff(fact_3765_lenlex__append1,axiom,
    ! [B: $tType,Us: list(B),Xsa: list(B),R4: set(product_prod(B,B)),Vs: list(B),Ys: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Us),Xsa),lenlex(B,R4))
     => ( ( aa(list(B),nat,size_size(list(B)),Vs) = aa(list(B),nat,size_size(list(B)),Ys) )
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us),Vs)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),lenlex(B,R4)) ) ) ).

% lenlex_append1
tff(fact_3766_member__product,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(B,C),A4: set(B),B5: set(C)] :
      ( member(product_prod(B,C),X2,product_product(B,C,A4,B5))
    <=> member(product_prod(B,C),X2,product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5))) ) ).

% member_product
tff(fact_3767_Product__Type_Oproduct__def,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] : product_product(B,C,A4,B5) = product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)) ).

% Product_Type.product_def
tff(fact_3768_lenlex__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : lenlex(B,R) = inv_image(product_prod(nat,list(B)),list(B),lex_prod(nat,list(B),less_than,lex(B,R)),aTP_Lamp_pr(list(B),product_prod(nat,list(B)))) ).

% lenlex_def
tff(fact_3769_Cons__lenlex__iff,axiom,
    ! [B: $tType,M: B,Ms: list(B),N: B,Ns: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),M),Ms)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),N),Ns)),lenlex(B,R))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Ms)),aa(list(B),nat,size_size(list(B)),Ns))
        | ( ( aa(list(B),nat,size_size(list(B)),Ms) = aa(list(B),nat,size_size(list(B)),Ns) )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),M),N),R) )
        | ( ( M = N )
          & member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ms),Ns),lenlex(B,R)) ) ) ) ).

% Cons_lenlex_iff
tff(fact_3770_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),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I))
     => ( aa(nat,nat,nth(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_3771_splice_Opelims,axiom,
    ! [B: $tType,X2: list(B),Xa: list(B),Y: list(B)] :
      ( ( splice(B,X2,Xa) = Y )
     => ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Xa))
       => ( ( ( X2 = nil(B) )
           => ( ( Y = Xa )
             => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Xa)) ) )
         => ~ ! [X3: B,Xs: list(B)] :
                ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
               => ( ( Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),splice(B,Xa,Xs)) )
                 => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Xa)) ) ) ) ) ) ).

% splice.pelims
tff(fact_3772_sorted__find__Min,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B),P: fun(B,$o)] :
          ( sorted_wrt(B,ord_less_eq(B),Xsa)
         => ( ? [X: B] :
                ( member(B,X,aa(list(B),set(B),set2(B),Xsa))
                & aa(B,$o,P,X) )
           => ( find(B,P,Xsa) = aa(B,option(B),some(B),lattic643756798350308766er_Min(B,aa(fun(B,$o),set(B),collect(B),aa(fun(B,$o),fun(B,$o),aTP_Lamp_ps(list(B),fun(fun(B,$o),fun(B,$o)),Xsa),P)))) ) ) ) ) ).

% sorted_find_Min
tff(fact_3773_part__def,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [F: fun(B,C),Pivot: C,Xsa: list(B)] : linorder_part(B,C,F,Pivot,Xsa) = aa(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))),aa(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))),product_Pair(list(B),product_prod(list(B),list(B))),filter(B,aa(C,fun(B,$o),aTP_Lamp_pt(fun(B,C),fun(C,fun(B,$o)),F),Pivot),Xsa)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),filter(B,aa(C,fun(B,$o),aTP_Lamp_pu(fun(B,C),fun(C,fun(B,$o)),F),Pivot),Xsa)),filter(B,aa(C,fun(B,$o),aTP_Lamp_pv(fun(B,C),fun(C,fun(B,$o)),F),Pivot),Xsa))) ) ).

% part_def
tff(fact_3774_merge__list__correct,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Ls: list(list(B)),As2: list(list(B))] :
          ( ! [L5: list(B)] :
              ( member(list(B),L5,aa(list(list(B)),set(list(B)),set2(list(B)),Ls))
             => ( distinct(B,L5)
                & sorted_wrt(B,ord_less_eq(B),L5) ) )
         => ( ! [L5: list(B)] :
                ( member(list(B),L5,aa(list(list(B)),set(list(B)),set2(list(B)),As2))
               => ( distinct(B,L5)
                  & sorted_wrt(B,ord_less_eq(B),L5) ) )
           => ( distinct(B,merge_list(B,As2,Ls))
              & sorted_wrt(B,ord_less_eq(B),merge_list(B,As2,Ls))
              & ( aa(list(B),set(B),set2(B),merge_list(B,As2,Ls)) = aa(list(B),set(B),set2(B),concat(B,aa(list(list(B)),list(list(B)),aa(list(list(B)),fun(list(list(B)),list(list(B))),append(list(B)),As2),Ls))) ) ) ) ) ) ).

% merge_list_correct
tff(fact_3775_length__splice,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] : aa(list(B),nat,size_size(list(B)),splice(B,Xsa,Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),aa(list(B),nat,size_size(list(B)),Ys)) ).

% length_splice
tff(fact_3776_splice__replicate,axiom,
    ! [B: $tType,M: nat,X2: B,N: nat] : splice(B,replicate(B,M,X2),replicate(B,N,X2)) = replicate(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),X2) ).

% splice_replicate
tff(fact_3777_merge__list_Osimps_I4_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [La: list(B),Acc22: list(list(B)),L: list(B)] : merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),nil(list(B)))) = merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22))) ) ).

% merge_list.simps(4)
tff(fact_3778_merge__list_Osimps_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [La: list(B),Acc22: list(list(B))] : merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22),nil(list(B))) = merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22)) ) ).

% merge_list.simps(3)
tff(fact_3779_merge__list_Osimps_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B)] : merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),nil(list(B)))) = L ) ).

% merge_list.simps(2)
tff(fact_3780_merge__list_Osimps_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ( merge_list(B,nil(list(B)),nil(list(B))) = nil(B) ) ) ).

% merge_list.simps(1)
tff(fact_3781_find__SomeD_I1_J,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),X2: B] :
      ( ( find(B,P,Xsa) = aa(B,option(B),some(B),X2) )
     => aa(B,$o,P,X2) ) ).

% find_SomeD(1)
tff(fact_3782_find_Osimps_I2_J,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Xsa: list(B)] :
      find(B,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = $ite(aa(B,$o,P,X2),aa(B,option(B),some(B),X2),find(B,P,Xsa)) ).

% find.simps(2)
tff(fact_3783_find_Osimps_I1_J,axiom,
    ! [B: $tType,Uu: fun(B,$o)] : find(B,Uu,nil(B)) = none(B) ).

% find.simps(1)
tff(fact_3784_find__SomeD_I2_J,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),X2: B] :
      ( ( find(B,P,Xsa) = aa(B,option(B),some(B),X2) )
     => member(B,X2,aa(list(B),set(B),set2(B),Xsa)) ) ).

% find_SomeD(2)
tff(fact_3785_find__None__iff2,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B)] :
      ( ( none(B) = find(B,P,Xsa) )
    <=> ~ ? [X4: B] :
            ( member(B,X4,aa(list(B),set(B),set2(B),Xsa))
            & aa(B,$o,P,X4) ) ) ).

% find_None_iff2
tff(fact_3786_find__None__iff,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B)] :
      ( ( find(B,P,Xsa) = none(B) )
    <=> ~ ? [X4: B] :
            ( member(B,X4,aa(list(B),set(B),set2(B),Xsa))
            & aa(B,$o,P,X4) ) ) ).

% find_None_iff
tff(fact_3787_part__code_I1_J,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [F: fun(B,C),Pivot: C] : linorder_part(B,C,F,Pivot,nil(B)) = aa(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))),aa(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))),product_Pair(list(B),product_prod(list(B),list(B))),nil(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B))) ) ).

% part_code(1)
tff(fact_3788_find__Some__iff,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),X2: B] :
      ( ( find(B,P,Xsa) = aa(B,option(B),some(B),X2) )
    <=> ? [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),Xsa))
          & aa(B,$o,P,aa(nat,B,nth(B,Xsa),I3))
          & ( X2 = aa(nat,B,nth(B,Xsa),I3) )
          & ! [J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),I3)
             => ~ aa(B,$o,P,aa(nat,B,nth(B,Xsa),J2)) ) ) ) ).

% find_Some_iff
tff(fact_3789_find__Some__iff2,axiom,
    ! [B: $tType,X2: B,P: fun(B,$o),Xsa: list(B)] :
      ( ( aa(B,option(B),some(B),X2) = find(B,P,Xsa) )
    <=> ? [I3: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),Xsa))
          & aa(B,$o,P,aa(nat,B,nth(B,Xsa),I3))
          & ( X2 = aa(nat,B,nth(B,Xsa),I3) )
          & ! [J2: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),I3)
             => ~ aa(B,$o,P,aa(nat,B,nth(B,Xsa),J2)) ) ) ) ).

% find_Some_iff2
tff(fact_3790_mergesort__remdups__def,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B)] : aa(list(B),list(B),mergesort_remdups(B),Xsa) = merge_list(B,nil(list(B)),aa(list(B),list(list(B)),map(B,list(B),aTP_Lamp_pw(B,list(B))),Xsa)) ) ).

% mergesort_remdups_def
tff(fact_3791_splice_Opsimps_I2_J,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Ys: list(B)] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),Ys))
     => ( splice(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Ys) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),splice(B,Ys,Xsa)) ) ) ).

% splice.psimps(2)
tff(fact_3792_splice_Opsimps_I1_J,axiom,
    ! [B: $tType,Ys: list(B)] :
      ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),splice_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Ys))
     => ( splice(B,nil(B),Ys) = Ys ) ) ).

% splice.psimps(1)
tff(fact_3793_part__code_I2_J,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [F: fun(B,C),Pivot: C,X2: B,Xsa: list(B)] : linorder_part(B,C,F,Pivot,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(product_prod(list(B),product_prod(list(B),list(B))),product_prod(list(B),product_prod(list(B),list(B))),aa(fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))))),fun(product_prod(list(B),product_prod(list(B),list(B))),product_prod(list(B),product_prod(list(B),list(B)))),product_case_prod(list(B),product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))),aa(B,fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))))),aa(C,fun(B,fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))))),aTP_Lamp_py(fun(B,C),fun(C,fun(B,fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))))))),F),Pivot),X2)),linorder_part(B,C,F,Pivot,Xsa)) ) ).

% part_code(2)
tff(fact_3794_extract__SomeE,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),Ys: list(B),Y: B,Zs: list(B)] :
      ( ( extract(B,P,Xsa) = aa(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B)))),some(product_prod(list(B),product_prod(B,list(B)))),aa(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B))),aa(list(B),fun(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B)))),product_Pair(list(B),product_prod(B,list(B))),Ys),aa(list(B),product_prod(B,list(B)),aa(B,fun(list(B),product_prod(B,list(B))),product_Pair(B,list(B)),Y),Zs))) )
     => ( ( Xsa = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Zs)) )
        & aa(B,$o,P,Y)
        & ~ ? [X: B] :
              ( member(B,X,aa(list(B),set(B),set2(B),Ys))
              & aa(B,$o,P,X) ) ) ) ).

% extract_SomeE
tff(fact_3795_extract__Some__iff,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),Ys: list(B),Y: B,Zs: list(B)] :
      ( ( extract(B,P,Xsa) = aa(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B)))),some(product_prod(list(B),product_prod(B,list(B)))),aa(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B))),aa(list(B),fun(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B)))),product_Pair(list(B),product_prod(B,list(B))),Ys),aa(list(B),product_prod(B,list(B)),aa(B,fun(list(B),product_prod(B,list(B))),product_Pair(B,list(B)),Y),Zs))) )
    <=> ( ( Xsa = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Zs)) )
        & aa(B,$o,P,Y)
        & ~ ? [X4: B] :
              ( member(B,X4,aa(list(B),set(B),set2(B),Ys))
              & aa(B,$o,P,X4) ) ) ) ).

% extract_Some_iff
tff(fact_3796_extract__Cons__code,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Xsa: list(B)] :
      extract(B,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = $ite(aa(B,$o,P,X2),aa(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B)))),some(product_prod(list(B),product_prod(B,list(B)))),aa(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B))),aa(list(B),fun(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B)))),product_Pair(list(B),product_prod(B,list(B))),nil(B)),aa(list(B),product_prod(B,list(B)),aa(B,fun(list(B),product_prod(B,list(B))),product_Pair(B,list(B)),X2),Xsa))),aa(option(product_prod(list(B),product_prod(B,list(B)))),option(product_prod(list(B),product_prod(B,list(B)))),aa(fun(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B))))),fun(option(product_prod(list(B),product_prod(B,list(B)))),option(product_prod(list(B),product_prod(B,list(B))))),aa(option(product_prod(list(B),product_prod(B,list(B)))),fun(fun(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B))))),fun(option(product_prod(list(B),product_prod(B,list(B)))),option(product_prod(list(B),product_prod(B,list(B)))))),case_option(option(product_prod(list(B),product_prod(B,list(B)))),product_prod(list(B),product_prod(B,list(B)))),none(product_prod(list(B),product_prod(B,list(B))))),aa(fun(list(B),fun(product_prod(B,list(B)),option(product_prod(list(B),product_prod(B,list(B)))))),fun(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B))))),product_case_prod(list(B),product_prod(B,list(B)),option(product_prod(list(B),product_prod(B,list(B))))),aTP_Lamp_qa(B,fun(list(B),fun(product_prod(B,list(B)),option(product_prod(list(B),product_prod(B,list(B)))))),X2))),extract(B,P,Xsa))) ).

% extract_Cons_code
tff(fact_3797_merge__list_Ocases,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: product_prod(list(list(B)),list(list(B)))] :
          ( ( X2 != aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),nil(list(B))) )
         => ( ! [L5: list(B)] : X2 != aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))))
           => ( ! [La2: list(B),Acc23: list(list(B))] : X2 != aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),nil(list(B)))
             => ( ! [La2: list(B),Acc23: list(list(B)),L5: list(B)] : X2 != aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))))
               => ~ ! [Acc23: list(list(B)),L12: list(B),L22: list(B),Ls2: list(list(B))] : X2 != aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),Acc23),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L12),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L22),Ls2))) ) ) ) ) ) ).

% merge_list.cases
tff(fact_3798_subset__eq__mset__impl_Oelims,axiom,
    ! [B: $tType,X2: list(B),Xa: list(B),Y: option($o)] :
      ( ( subset_eq_mset_impl(B,X2,Xa) = Y )
     => ( ( ( X2 = nil(B) )
         => ( Y != aa($o,option($o),some($o),Xa != nil(B)) ) )
       => ~ ! [X3: B,Xs: list(B)] :
              ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
             => ( Y != aa(option(product_prod(list(B),product_prod(B,list(B)))),option($o),aa(fun(product_prod(list(B),product_prod(B,list(B))),option($o)),fun(option(product_prod(list(B),product_prod(B,list(B)))),option($o)),aa(option($o),fun(fun(product_prod(list(B),product_prod(B,list(B))),option($o)),fun(option(product_prod(list(B),product_prod(B,list(B)))),option($o))),case_option(option($o),product_prod(list(B),product_prod(B,list(B)))),none($o)),aa(fun(list(B),fun(product_prod(B,list(B)),option($o))),fun(product_prod(list(B),product_prod(B,list(B))),option($o)),product_case_prod(list(B),product_prod(B,list(B)),option($o)),aTP_Lamp_qc(list(B),fun(list(B),fun(product_prod(B,list(B)),option($o))),Xs))),extract(B,aa(B,fun(B,$o),fequal(B),X3),Xa)) ) ) ) ) ).

% subset_eq_mset_impl.elims
tff(fact_3799_lexord__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : lexord(B,R) = aa(fun(product_prod(list(B),list(B)),$o),set(product_prod(list(B),list(B))),collect(product_prod(list(B),list(B))),aa(fun(list(B),fun(list(B),$o)),fun(product_prod(list(B),list(B)),$o),product_case_prod(list(B),list(B),$o),aTP_Lamp_qd(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),R))) ).

% lexord_def
tff(fact_3800_list__collect__set__alt,axiom,
    ! [B: $tType,C: $tType,F: fun(C,set(B)),L: list(C)] : list_collect_set(C,B,F,L) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(fun(set(B),$o),set(set(B)),collect(set(B)),aa(list(C),fun(set(B),$o),aTP_Lamp_qe(fun(C,set(B)),fun(list(C),fun(set(B),$o)),F),L))) ).

% list_collect_set_alt
tff(fact_3801_subset__eq__mset__impl_Opelims,axiom,
    ! [B: $tType,X2: list(B),Xa: list(B),Y: option($o)] :
      ( ( subset_eq_mset_impl(B,X2,Xa) = Y )
     => ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),subset751672762298770561pl_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Xa))
       => ( ( ( X2 = nil(B) )
           => ( ( Y = aa($o,option($o),some($o),Xa != nil(B)) )
             => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),subset751672762298770561pl_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Xa)) ) )
         => ~ ! [X3: B,Xs: list(B)] :
                ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
               => ( ( Y = aa(option(product_prod(list(B),product_prod(B,list(B)))),option($o),aa(fun(product_prod(list(B),product_prod(B,list(B))),option($o)),fun(option(product_prod(list(B),product_prod(B,list(B)))),option($o)),aa(option($o),fun(fun(product_prod(list(B),product_prod(B,list(B))),option($o)),fun(option(product_prod(list(B),product_prod(B,list(B)))),option($o))),case_option(option($o),product_prod(list(B),product_prod(B,list(B)))),none($o)),aa(fun(list(B),fun(product_prod(B,list(B)),option($o))),fun(product_prod(list(B),product_prod(B,list(B))),option($o)),product_case_prod(list(B),product_prod(B,list(B)),option($o)),aTP_Lamp_qc(list(B),fun(list(B),fun(product_prod(B,list(B)),option($o))),Xs))),extract(B,aa(B,fun(B,$o),fequal(B),X3),Xa)) )
                 => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),subset751672762298770561pl_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Xa)) ) ) ) ) ) ).

% subset_eq_mset_impl.pelims
tff(fact_3802_list__collect__set__simps_I2_J,axiom,
    ! [B: $tType,C: $tType,F: fun(C,set(B)),A3: C] : list_collect_set(C,B,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),nil(C))) = aa(C,set(B),F,A3) ).

% list_collect_set_simps(2)
tff(fact_3803_list__collect__set__simps_I1_J,axiom,
    ! [C: $tType,B: $tType,F: fun(C,set(B))] : list_collect_set(C,B,F,nil(C)) = bot_bot(set(B)) ).

% list_collect_set_simps(1)
tff(fact_3804_list__collect__set__simps_I3_J,axiom,
    ! [B: $tType,C: $tType,F: fun(C,set(B)),A3: C,L: list(C)] : list_collect_set(C,B,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A3),L)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(C,set(B),F,A3)),list_collect_set(C,B,F,L)) ).

% list_collect_set_simps(3)
tff(fact_3805_list__collect__set__simps_I4_J,axiom,
    ! [B: $tType,C: $tType,F: fun(C,set(B)),L: list(C),L4: list(C)] : list_collect_set(C,B,F,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),L),L4)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),list_collect_set(C,B,F,L)),list_collect_set(C,B,F,L4)) ).

% list_collect_set_simps(4)
tff(fact_3806_lexord__cons__cons,axiom,
    ! [B: $tType,A3: B,X2: list(B),B2: B,Y: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),X2)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),B2),Y)),lexord(B,R))
    <=> ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
        | ( ( A3 = B2 )
          & member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lexord(B,R)) ) ) ) ).

% lexord_cons_cons
tff(fact_3807_lexord__Nil__left,axiom,
    ! [B: $tType,Y: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Y),lexord(B,R))
    <=> ? [A7: B,X4: list(B)] : Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A7),X4) ) ).

% lexord_Nil_left
tff(fact_3808_list__collect__set__map__simps_I2_J,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(C,set(B)),X2: fun(D,C),A3: D] : list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),nil(D)))) = aa(C,set(B),F,aa(D,C,X2,A3)) ).

% list_collect_set_map_simps(2)
tff(fact_3809_list__collect__set__map__simps_I1_J,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(C,set(B)),X2: fun(D,C)] : list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),nil(D))) = bot_bot(set(B)) ).

% list_collect_set_map_simps(1)
tff(fact_3810_list__collect__set__map__simps_I3_J,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(C,set(B)),X2: fun(D,C),A3: D,L: list(D)] : list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),A3),L))) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(C,set(B),F,aa(D,C,X2,A3))),list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),L))) ).

% list_collect_set_map_simps(3)
tff(fact_3811_list__collect__set__map__simps_I4_J,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(C,set(B)),X2: fun(D,C),L: list(D),L4: list(D)] : list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),aa(list(D),list(D),aa(list(D),fun(list(D),list(D)),append(D),L),L4))) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),L))),list_collect_set(C,B,F,aa(list(D),list(C),map(D,C,X2),L4))) ).

% list_collect_set_map_simps(4)
tff(fact_3812_lexord__irreflexive,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),Xsa: list(B)] :
      ( ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),R)
     => ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Xsa),lexord(B,R)) ) ).

% lexord_irreflexive
tff(fact_3813_lexord__linear,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: list(B),Y: list(B)] :
      ( ! [A5: B,B3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),B3),R)
          | ( A5 = B3 )
          | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A5),R) )
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lexord(B,R))
        | ( X2 = Y )
        | member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Y),X2),lexord(B,R)) ) ) ).

% lexord_linear
tff(fact_3814_lexord__Nil__right,axiom,
    ! [B: $tType,X2: list(B),R: set(product_prod(B,B))] : ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),nil(B)),lexord(B,R)) ).

% lexord_Nil_right
tff(fact_3815_lexord__append__leftI,axiom,
    ! [B: $tType,U: list(B),V: list(B),R: set(product_prod(B,B)),X2: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),U),V),lexord(B,R))
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),X2),U)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),X2),V)),lexord(B,R)) ) ).

% lexord_append_leftI
tff(fact_3816_lexord__partial__trans,axiom,
    ! [B: $tType,Xsa: list(B),R: set(product_prod(B,B)),Ys: list(B),Zs: list(B)] :
      ( ! [X3: B,Y4: B,Z3: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R)
           => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
             => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Z3),R) ) ) )
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lexord(B,R))
       => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),lexord(B,R))
         => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Zs),lexord(B,R)) ) ) ) ).

% lexord_partial_trans
tff(fact_3817_lexord__append__leftD,axiom,
    ! [B: $tType,X2: list(B),U: list(B),V: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),X2),U)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),X2),V)),lexord(B,R))
     => ( ! [A5: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),A5),R)
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),U),V),lexord(B,R)) ) ) ).

% lexord_append_leftD
tff(fact_3818_lexord__append__rightI,axiom,
    ! [B: $tType,Y: list(B),X2: list(B),R: set(product_prod(B,B))] :
      ( ? [B6: B,Z5: list(B)] : Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),B6),Z5)
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),X2),Y)),lexord(B,R)) ) ).

% lexord_append_rightI
tff(fact_3819_lexord__sufE,axiom,
    ! [B: $tType,Xsa: list(B),Zs: list(B),Ys: list(B),Qs: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Zs)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Qs)),lexord(B,R))
     => ( ( Xsa != Ys )
       => ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(B),nat,size_size(list(B)),Ys) )
         => ( ( aa(list(B),nat,size_size(list(B)),Zs) = aa(list(B),nat,size_size(list(B)),Qs) )
           => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lexord(B,R)) ) ) ) ) ).

% lexord_sufE
tff(fact_3820_list__collect__set__as__map,axiom,
    ! [B: $tType,C: $tType,F: fun(C,set(B)),L: list(C)] : list_collect_set(C,B,F,L) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(list(set(B)),set(set(B)),set2(set(B)),aa(list(C),list(set(B)),map(C,set(B),F),L))) ).

% list_collect_set_as_map
tff(fact_3821_lexord__lex,axiom,
    ! [B: $tType,X2: list(B),Y: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lex(B,R))
    <=> ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lexord(B,R))
        & ( aa(list(B),nat,size_size(list(B)),X2) = aa(list(B),nat,size_size(list(B)),Y) ) ) ) ).

% lexord_lex
tff(fact_3822_lexord__append__left__rightI,axiom,
    ! [B: $tType,A3: B,B2: B,R: set(product_prod(B,B)),U: list(B),X2: list(B),Y: list(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),U),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),X2))),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),U),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),B2),Y))),lexord(B,R)) ) ).

% lexord_append_left_rightI
tff(fact_3823_lexord__same__pref__iff,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),Zs: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Zs)),lexord(B,R))
    <=> ( ? [X4: B] :
            ( member(B,X4,aa(list(B),set(B),set2(B),Xsa))
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),X4),R) )
        | member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),lexord(B,R)) ) ) ).

% lexord_same_pref_iff
tff(fact_3824_lexord__sufI,axiom,
    ! [B: $tType,U: list(B),W: list(B),R: set(product_prod(B,B)),V: list(B),Z2: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),U),W),lexord(B,R))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),W)),aa(list(B),nat,size_size(list(B)),U))
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),U),V)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),W),Z2)),lexord(B,R)) ) ) ).

% lexord_sufI
tff(fact_3825_list__collect__set__def,axiom,
    ! [B: $tType,C: $tType,F: fun(C,set(B)),L: list(C)] : list_collect_set(C,B,F,L) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(fun(set(B),$o),set(set(B)),collect(set(B)),aa(list(C),fun(set(B),$o),aTP_Lamp_qf(fun(C,set(B)),fun(list(C),fun(set(B),$o)),F),L))) ).

% list_collect_set_def
tff(fact_3826_subset__eq__mset__impl_Osimps_I2_J,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Ys: list(B)] : subset_eq_mset_impl(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Ys) = aa(option(product_prod(list(B),product_prod(B,list(B)))),option($o),aa(fun(product_prod(list(B),product_prod(B,list(B))),option($o)),fun(option(product_prod(list(B),product_prod(B,list(B)))),option($o)),aa(option($o),fun(fun(product_prod(list(B),product_prod(B,list(B))),option($o)),fun(option(product_prod(list(B),product_prod(B,list(B)))),option($o))),case_option(option($o),product_prod(list(B),product_prod(B,list(B)))),none($o)),aa(fun(list(B),fun(product_prod(B,list(B)),option($o))),fun(product_prod(list(B),product_prod(B,list(B))),option($o)),product_case_prod(list(B),product_prod(B,list(B)),option($o)),aTP_Lamp_qc(list(B),fun(list(B),fun(product_prod(B,list(B)),option($o))),Xsa))),extract(B,aa(B,fun(B,$o),fequal(B),X2),Ys)) ).

% subset_eq_mset_impl.simps(2)
tff(fact_3827_List_Olexordp__def,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),Xsa: list(B),Ys: list(B)] :
      ( lexordp(B,R,Xsa,Ys)
    <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lexord(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% List.lexordp_def
tff(fact_3828_upto_Opelims,axiom,
    ! [X2: int,Xa: int,Y: list(int)] :
      ( ( upto(X2,Xa) = Y )
     => ( aa(product_prod(int,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),X2),Xa))
       => ~ ( ( Y = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X2),Xa),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),X2),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),one_one(int)),Xa)),nil(int)) )
           => ~ aa(product_prod(int,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),X2),Xa)) ) ) ) ).

% upto.pelims
tff(fact_3829_upto_Opsimps,axiom,
    ! [I: int,J: int] :
      ( aa(product_prod(int,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),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_3830_listrel1__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : listrel1(B,R) = aa(fun(product_prod(list(B),list(B)),$o),set(product_prod(list(B),list(B))),collect(product_prod(list(B),list(B))),aa(fun(list(B),fun(list(B),$o)),fun(product_prod(list(B),list(B)),$o),product_case_prod(list(B),list(B),$o),aTP_Lamp_qg(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),R))) ).

% listrel1_def
tff(fact_3831_Cons__listrel1__Cons,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Y: B,Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)),listrel1(B,R))
    <=> ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
          & ( Xsa = Ys ) )
        | ( ( X2 = Y )
          & member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R)) ) ) ) ).

% Cons_listrel1_Cons
tff(fact_3832_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_3833_length__upto,axiom,
    ! [I: int,J: int] : aa(list(int),nat,size_size(list(int)),upto(I,J)) = aa(int,nat,nat2,aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),minus_minus(int),J),I)),one_one(int))) ).

% length_upto
tff(fact_3834_upto__rec__numeral_I1_J,axiom,
    ! [M: num,N: num] :
      upto(aa(num,int,numeral_numeral(int),M),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),M)),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),M)),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(num,int,numeral_numeral(int),M)),one_one(int)),aa(num,int,numeral_numeral(int),N))),nil(int)) ).

% upto_rec_numeral(1)
tff(fact_3835_upto__rec__numeral_I2_J,axiom,
    ! [M: num,N: num] :
      upto(aa(num,int,numeral_numeral(int),M),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),M)),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),M)),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(num,int,numeral_numeral(int),M)),one_one(int)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N)))),nil(int)) ).

% upto_rec_numeral(2)
tff(fact_3836_upto__rec__numeral_I3_J,axiom,
    ! [M: num,N: num] :
      upto(aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M)),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),M))),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),M))),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M))),one_one(int)),aa(num,int,numeral_numeral(int),N))),nil(int)) ).

% upto_rec_numeral(3)
tff(fact_3837_upto__rec__numeral_I4_J,axiom,
    ! [M: num,N: num] :
      upto(aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M)),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),M))),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),M))),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),M))),one_one(int)),aa(int,int,uminus_uminus(int),aa(num,int,numeral_numeral(int),N)))),nil(int)) ).

% upto_rec_numeral(4)
tff(fact_3838_listrel1I2,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B)),X2: B] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Ys)),listrel1(B,R)) ) ).

% listrel1I2
tff(fact_3839_rtrancl__listrel1__ConsI1,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B)),X2: B] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),transitive_rtrancl(list(B),listrel1(B,R)))
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Ys)),transitive_rtrancl(list(B),listrel1(B,R))) ) ).

% rtrancl_listrel1_ConsI1
tff(fact_3840_not__listrel1__Nil,axiom,
    ! [B: $tType,Xsa: list(B),R: set(product_prod(B,B))] : ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),nil(B)),listrel1(B,R)) ).

% not_listrel1_Nil
tff(fact_3841_not__Nil__listrel1,axiom,
    ! [B: $tType,Xsa: list(B),R: set(product_prod(B,B))] : ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Xsa),listrel1(B,R)) ).

% not_Nil_listrel1
tff(fact_3842_rtrancl__listrel1__eq__len,axiom,
    ! [B: $tType,X2: list(B),Y: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),transitive_rtrancl(list(B),listrel1(B,R)))
     => ( aa(list(B),nat,size_size(list(B)),X2) = aa(list(B),nat,size_size(list(B)),Y) ) ) ).

% rtrancl_listrel1_eq_len
tff(fact_3843_listrel1__eq__len,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
     => ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(B),nat,size_size(list(B)),Ys) ) ) ).

% listrel1_eq_len
tff(fact_3844_append__listrel1I,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B)),Us: list(B),Vs: list(B)] :
      ( ( ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
          & ( Us = Vs ) )
        | ( ( Xsa = Ys )
          & member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Us),Vs),listrel1(B,R)) ) )
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Us)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),Vs)),listrel1(B,R)) ) ).

% append_listrel1I
tff(fact_3845_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_3846_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_3847_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_3848_upto_Oelims,axiom,
    ! [X2: int,Xa: int,Y: list(int)] :
      ( ( upto(X2,Xa) = Y )
     => ( Y = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),X2),Xa),aa(list(int),list(int),aa(int,fun(list(int),list(int)),cons(int),X2),upto(aa(int,int,aa(int,fun(int,int),plus_plus(int),X2),one_one(int)),Xa)),nil(int)) ) ) ).

% upto.elims
tff(fact_3849_Cons__listrel1E2,axiom,
    ! [B: $tType,Xsa: list(B),Y: B,Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)),listrel1(B,R))
     => ( ! [X3: B] :
            ( ( Xsa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys) )
           => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y),R) )
       => ~ ! [Zs2: list(B)] :
              ( ( Xsa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Zs2) )
             => ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Zs2),Ys),listrel1(B,R)) ) ) ) ).

% Cons_listrel1E2
tff(fact_3850_Cons__listrel1E1,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),Ys),listrel1(B,R))
     => ( ! [Y4: B] :
            ( ( Ys = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xsa) )
           => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),R) )
       => ~ ! [Zs2: list(B)] :
              ( ( Ys = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Zs2) )
             => ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Zs2),listrel1(B,R)) ) ) ) ).

% Cons_listrel1E1
tff(fact_3851_listrel1I1,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),Xsa: list(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Xsa)),listrel1(B,R)) ) ).

% listrel1I1
tff(fact_3852_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_3853_listrel1I,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),Xsa: list(B),Us: list(B),Vs: list(B),Ys: list(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
     => ( ( Xsa = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Vs)) )
       => ( ( Ys = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Vs)) )
         => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R)) ) ) ) ).

% listrel1I
tff(fact_3854_listrel1E,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
     => ~ ! [X3: B,Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R)
           => ! [Us2: list(B),Vs2: list(B)] :
                ( ( Xsa = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Vs2)) )
               => ( Ys != aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Vs2)) ) ) ) ) ).

% listrel1E
tff(fact_3855_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,aa(int,int,aa(int,fun(int,int),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_3856_rtrancl__listrel1__ConsI2,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B)),Xsa: list(B),Ys: list(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R))
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),transitive_rtrancl(list(B),listrel1(B,R)))
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)),transitive_rtrancl(list(B),listrel1(B,R))) ) ) ).

% rtrancl_listrel1_ConsI2
tff(fact_3857_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)),aa(int,int,aa(int,fun(int,int),minus_minus(int),J),one_one(int)))) ).

% greaterThanLessThan_upto
tff(fact_3858_snoc__listrel1__snoc__iff,axiom,
    ! [B: $tType,Xsa: list(B),X2: B,Ys: list(B),Y: B,R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B)))),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Ys),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),nil(B)))),listrel1(B,R))
    <=> ( ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
          & ( X2 = Y ) )
        | ( ( Xsa = Ys )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R) ) ) ) ).

% snoc_listrel1_snoc_iff
tff(fact_3859_listrel1p__def,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),Xsa: list(B),Ys: list(B)] :
      ( listrel1p(B,R,Xsa,Ys)
    <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% listrel1p_def
tff(fact_3860_sorted__wrt__map__rev__linord,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [L: list(product_prod(B,C))] :
          ( sorted_wrt(product_prod(B,C),aTP_Lamp_qh(product_prod(B,C),fun(product_prod(B,C),$o)),L)
        <=> sorted_wrt(B,ord_less_eq(B),rev(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),L))) ) ) ).

% sorted_wrt_map_rev_linord
tff(fact_3861_set__zip,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C)] : aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys)) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(list(C),fun(product_prod(B,C),$o),aTP_Lamp_qi(list(B),fun(list(C),fun(product_prod(B,C),$o)),Xsa),Ys)) ).

% set_zip
tff(fact_3862_arg__min__list_Opelims,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [X2: fun(B,C),Xa: list(B),Y: B] :
          ( ( arg_min_list(B,C,X2,Xa) = Y )
         => ( aa(product_prod(fun(B,C),list(B)),$o,accp(product_prod(fun(B,C),list(B)),arg_min_list_rel(B,C)),aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),X2),Xa))
           => ( ! [X3: B] :
                  ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
                 => ( ( Y = X3 )
                   => ~ aa(product_prod(fun(B,C),list(B)),$o,accp(product_prod(fun(B,C),list(B)),arg_min_list_rel(B,C)),aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))) ) )
             => ( ! [X3: B,Y4: B,Zs2: list(B)] :
                    ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Zs2)) )
                   => ( ( Y = $let(
                            m: B,
                            m:= arg_min_list(B,C,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Zs2)),
                            $ite(aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,X2,X3)),aa(B,C,X2,m)),X3,m) ) )
                     => ~ aa(product_prod(fun(B,C),list(B)),$o,accp(product_prod(fun(B,C),list(B)),arg_min_list_rel(B,C)),aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Zs2)))) ) )
               => ~ ( ( Xa = nil(B) )
                   => ( ( Y = undefined(B) )
                     => ~ aa(product_prod(fun(B,C),list(B)),$o,accp(product_prod(fun(B,C),list(B)),arg_min_list_rel(B,C)),aa(list(B),product_prod(fun(B,C),list(B)),aa(fun(B,C),fun(list(B),product_prod(fun(B,C),list(B))),product_Pair(fun(B,C),list(B)),X2),nil(B))) ) ) ) ) ) ) ) ).

% arg_min_list.pelims
tff(fact_3863_zip__eq__zip__same__len,axiom,
    ! [B: $tType,C: $tType,A3: list(B),B2: list(C),A6: list(B),B4: list(C)] :
      ( ( aa(list(B),nat,size_size(list(B)),A3) = aa(list(C),nat,size_size(list(C)),B2) )
     => ( ( aa(list(B),nat,size_size(list(B)),A6) = aa(list(C),nat,size_size(list(C)),B4) )
       => ( ( zip(B,C,A3,B2) = zip(B,C,A6,B4) )
        <=> ( ( A3 = A6 )
            & ( B2 = B4 ) ) ) ) ) ).

% zip_eq_zip_same_len
tff(fact_3864_sorted__wrt__rev__linord,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B)] :
          ( sorted_wrt(B,aTP_Lamp_qj(B,fun(B,$o)),L)
        <=> sorted_wrt(B,ord_less_eq(B),rev(B,L)) ) ) ).

% sorted_wrt_rev_linord
tff(fact_3865_zip__Cons__Cons,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(B),Y: C,Ys: list(C)] : zip(B,C,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) = aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),zip(B,C,Xsa,Ys)) ).

% zip_Cons_Cons
tff(fact_3866_map__of__rev__distinct,axiom,
    ! [C: $tType,B: $tType,M: list(product_prod(B,C))] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),M))
     => ( map_of(B,C,rev(product_prod(B,C),M)) = map_of(B,C,M) ) ) ).

% map_of_rev_distinct
tff(fact_3867_zip__replicate,axiom,
    ! [B: $tType,C: $tType,I: nat,X2: B,J: nat,Y: C] : zip(B,C,replicate(B,I,X2),replicate(C,J,Y)) = replicate(product_prod(B,C),aa(nat,nat,ord_min(nat,I),J),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)) ).

% zip_replicate
tff(fact_3868_map__of__zip__is__None,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C),X2: B] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( ( aa(B,option(C),map_of(B,C,zip(B,C,Xsa,Ys)),X2) = none(C) )
      <=> ~ member(B,X2,aa(list(B),set(B),set2(B),Xsa)) ) ) ).

% map_of_zip_is_None
tff(fact_3869_nth__zip,axiom,
    ! [B: $tType,C: $tType,I: nat,Xsa: list(B),Ys: list(C)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Ys))
       => ( aa(nat,product_prod(B,C),nth(product_prod(B,C),zip(B,C,Xsa,Ys)),I) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(nat,B,nth(B,Xsa),I)),aa(nat,C,nth(C,Ys),I)) ) ) ) ).

% nth_zip
tff(fact_3870_zip__assoc,axiom,
    ! [C: $tType,B: $tType,D: $tType,Xsa: list(B),Ys: list(C),Zs: list(D)] : zip(B,product_prod(C,D),Xsa,zip(C,D,Ys,Zs)) = aa(list(product_prod(product_prod(B,C),D)),list(product_prod(B,product_prod(C,D))),map(product_prod(product_prod(B,C),D),product_prod(B,product_prod(C,D)),aa(fun(product_prod(B,C),fun(D,product_prod(B,product_prod(C,D)))),fun(product_prod(product_prod(B,C),D),product_prod(B,product_prod(C,D))),product_case_prod(product_prod(B,C),D,product_prod(B,product_prod(C,D))),aa(fun(B,fun(C,fun(D,product_prod(B,product_prod(C,D))))),fun(product_prod(B,C),fun(D,product_prod(B,product_prod(C,D)))),product_case_prod(B,C,fun(D,product_prod(B,product_prod(C,D)))),aTP_Lamp_qk(B,fun(C,fun(D,product_prod(B,product_prod(C,D)))))))),zip(product_prod(B,C),D,zip(B,C,Xsa,Ys),Zs)) ).

% zip_assoc
tff(fact_3871_pair__list__split,axiom,
    ! [B: $tType,C: $tType,L: list(product_prod(B,C))] :
      ~ ! [L12: list(B),L22: list(C)] :
          ( ( L = zip(B,C,L12,L22) )
         => ( ( aa(list(B),nat,size_size(list(B)),L12) = aa(list(C),nat,size_size(list(C)),L22) )
           => ( aa(list(product_prod(B,C)),nat,size_size(list(product_prod(B,C))),L) != aa(list(C),nat,size_size(list(C)),L22) ) ) ) ).

% pair_list_split
tff(fact_3872_zip__inj,axiom,
    ! [B: $tType,C: $tType,A3: list(B),B2: list(C),A6: list(B),B4: list(C)] :
      ( ( aa(list(B),nat,size_size(list(B)),A3) = aa(list(C),nat,size_size(list(C)),B2) )
     => ( ( aa(list(B),nat,size_size(list(B)),A6) = aa(list(C),nat,size_size(list(C)),B4) )
       => ( ( zip(B,C,A3,B2) = zip(B,C,A6,B4) )
         => ( ( A3 = A6 )
            & ( B2 = B4 ) ) ) ) ) ).

% zip_inj
tff(fact_3873_zip__left__commute,axiom,
    ! [C: $tType,B: $tType,D: $tType,Xsa: list(B),Ys: list(C),Zs: list(D)] : zip(B,product_prod(C,D),Xsa,zip(C,D,Ys,Zs)) = aa(list(product_prod(C,product_prod(B,D))),list(product_prod(B,product_prod(C,D))),map(product_prod(C,product_prod(B,D)),product_prod(B,product_prod(C,D)),aa(fun(C,fun(product_prod(B,D),product_prod(B,product_prod(C,D)))),fun(product_prod(C,product_prod(B,D)),product_prod(B,product_prod(C,D))),product_case_prod(C,product_prod(B,D),product_prod(B,product_prod(C,D))),aTP_Lamp_qm(C,fun(product_prod(B,D),product_prod(B,product_prod(C,D)))))),zip(C,product_prod(B,D),Ys,zip(B,D,Xsa,Zs))) ).

% zip_left_commute
tff(fact_3874_zip__same__conv__map,axiom,
    ! [B: $tType,Xsa: list(B)] : zip(B,B,Xsa,Xsa) = aa(list(B),list(product_prod(B,B)),map(B,product_prod(B,B),aTP_Lamp_je(B,product_prod(B,B))),Xsa) ).

% zip_same_conv_map
tff(fact_3875_set__zip__rightD,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: C,Xsa: list(B),Ys: list(C)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys)))
     => member(C,Y,aa(list(C),set(C),set2(C),Ys)) ) ).

% set_zip_rightD
tff(fact_3876_set__zip__leftD,axiom,
    ! [C: $tType,B: $tType,X2: B,Y: C,Xsa: list(B),Ys: list(C)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys)))
     => member(B,X2,aa(list(B),set(B),set2(B),Xsa)) ) ).

% set_zip_leftD
tff(fact_3877_in__set__zipE,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: C,Xsa: list(B),Ys: list(C)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys)))
     => ~ ( member(B,X2,aa(list(B),set(B),set2(B),Xsa))
         => ~ member(C,Y,aa(list(C),set(C),set2(C),Ys)) ) ) ).

% in_set_zipE
tff(fact_3878_zip__same,axiom,
    ! [B: $tType,A3: B,B2: B,Xsa: list(B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),aa(list(product_prod(B,B)),set(product_prod(B,B)),set2(product_prod(B,B)),zip(B,B,Xsa,Xsa)))
    <=> ( member(B,A3,aa(list(B),set(B),set2(B),Xsa))
        & ( A3 = B2 ) ) ) ).

% zip_same
tff(fact_3879_zip__eq__ConsE,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),Xy: product_prod(B,C),Xys: list(product_prod(B,C))] :
      ( ( zip(B,C,Xsa,Ys) = aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),Xy),Xys) )
     => ~ ! [X3: B,Xs5: list(B)] :
            ( ( Xsa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs5) )
           => ! [Y4: C,Ys3: list(C)] :
                ( ( Ys = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),Ys3) )
               => ( ( Xy = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4) )
                 => ( Xys != zip(B,C,Xs5,Ys3) ) ) ) ) ) ).

% zip_eq_ConsE
tff(fact_3880_set__zip__cart,axiom,
    ! [B: $tType,C: $tType,X2: product_prod(B,C),L: list(B),L4: list(C)] :
      ( member(product_prod(B,C),X2,aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,L,L4)))
     => member(product_prod(B,C),X2,product_Sigma(B,C,aa(list(B),set(B),set2(B),L),aTP_Lamp_qn(list(C),fun(B,set(C)),L4))) ) ).

% set_zip_cart
tff(fact_3881_zip__commute,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C)] : zip(B,C,Xsa,Ys) = aa(list(product_prod(C,B)),list(product_prod(B,C)),map(product_prod(C,B),product_prod(B,C),aa(fun(C,fun(B,product_prod(B,C))),fun(product_prod(C,B),product_prod(B,C)),product_case_prod(C,B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))))),zip(C,B,Ys,Xsa)) ).

% zip_commute
tff(fact_3882_last__zip,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C)] :
      ( ( Xsa != nil(B) )
     => ( ( Ys != nil(C) )
       => ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
         => ( last(product_prod(B,C),zip(B,C,Xsa,Ys)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),last(B,Xsa)),last(C,Ys)) ) ) ) ) ).

% last_zip
tff(fact_3883_in__set__impl__in__set__zip1,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),X2: B] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( member(B,X2,aa(list(B),set(B),set2(B),Xsa))
       => ~ ! [Y4: C] : ~ member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y4),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys))) ) ) ).

% in_set_impl_in_set_zip1
tff(fact_3884_in__set__impl__in__set__zip2,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),Y: C] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( member(C,Y,aa(list(C),set(C),set2(C),Ys))
       => ~ ! [X3: B] : ~ member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y),aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys))) ) ) ).

% in_set_impl_in_set_zip2
tff(fact_3885_map__of__zip__is__Some,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),X2: B] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( member(B,X2,aa(list(B),set(B),set2(B),Xsa))
      <=> ? [Y3: C] : aa(B,option(C),map_of(B,C,zip(B,C,Xsa,Ys)),X2) = aa(C,option(C),some(C),Y3) ) ) ).

% map_of_zip_is_Some
tff(fact_3886_map__upds__fold__map__upd,axiom,
    ! [B: $tType,C: $tType,M: fun(B,option(C)),Ks: list(B),Vs: list(C)] : map_upds(B,C,M,Ks,Vs) = aa(list(product_prod(B,C)),fun(B,option(C)),aa(fun(B,option(C)),fun(list(product_prod(B,C)),fun(B,option(C))),foldl(fun(B,option(C)),product_prod(B,C),aTP_Lamp_qp(fun(B,option(C)),fun(product_prod(B,C),fun(B,option(C))))),M),zip(B,C,Ks,Vs)) ).

% map_upds_fold_map_upd
tff(fact_3887_enumerate__eq__zip,axiom,
    ! [B: $tType,N: nat,Xsa: list(B)] : enumerate(B,N,Xsa) = zip(nat,B,upt(N,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))),Xsa) ).

% enumerate_eq_zip
tff(fact_3888_map__zip__map,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,F: fun(product_prod(C,D),B),G: fun(E,C),Xsa: list(E),Ys: list(D)] : aa(list(product_prod(C,D)),list(B),map(product_prod(C,D),B,F),zip(C,D,aa(list(E),list(C),map(E,C,G),Xsa),Ys)) = aa(list(product_prod(E,D)),list(B),map(product_prod(E,D),B,aa(fun(E,fun(D,B)),fun(product_prod(E,D),B),product_case_prod(E,D,B),aa(fun(E,C),fun(E,fun(D,B)),aTP_Lamp_qq(fun(product_prod(C,D),B),fun(fun(E,C),fun(E,fun(D,B))),F),G))),zip(E,D,Xsa,Ys)) ).

% map_zip_map
tff(fact_3889_map__zip__map2,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,F: fun(product_prod(C,D),B),Xsa: list(C),G: fun(E,D),Ys: list(E)] : aa(list(product_prod(C,D)),list(B),map(product_prod(C,D),B,F),zip(C,D,Xsa,aa(list(E),list(D),map(E,D,G),Ys))) = aa(list(product_prod(C,E)),list(B),map(product_prod(C,E),B,aa(fun(C,fun(E,B)),fun(product_prod(C,E),B),product_case_prod(C,E,B),aa(fun(E,D),fun(C,fun(E,B)),aTP_Lamp_qr(fun(product_prod(C,D),B),fun(fun(E,D),fun(C,fun(E,B))),F),G))),zip(C,E,Xsa,Ys)) ).

% map_zip_map2
tff(fact_3890_foldl__snd__zip,axiom,
    ! [C: $tType,D: $tType,B: $tType,Ys: list(B),Xsa: list(C),F: fun(D,fun(B,D)),B2: D] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Ys)),aa(list(C),nat,size_size(list(C)),Xsa))
     => ( aa(list(product_prod(C,B)),D,aa(D,fun(list(product_prod(C,B)),D),foldl(D,product_prod(C,B),aTP_Lamp_qt(fun(D,fun(B,D)),fun(D,fun(product_prod(C,B),D)),F)),B2),zip(C,B,Xsa,Ys)) = aa(list(B),D,aa(D,fun(list(B),D),foldl(D,B,F),B2),Ys) ) ) ).

% foldl_snd_zip
tff(fact_3891_map__zip2,axiom,
    ! [B: $tType,C: $tType,K: B,L: list(C)] : aa(list(C),list(product_prod(B,C)),map(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),K)),L) = zip(B,C,replicate(B,aa(list(C),nat,size_size(list(C)),L),K),L) ).

% map_zip2
tff(fact_3892_map__zip1,axiom,
    ! [B: $tType,C: $tType,K: C,L: list(B)] : aa(list(B),list(product_prod(B,C)),map(B,product_prod(B,C),aa(C,fun(B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))),K)),L) = zip(B,C,L,replicate(C,aa(list(B),nat,size_size(list(B)),L),K)) ).

% map_zip1
tff(fact_3893_map__prod__fun__zip,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,F: fun(D,B),G: fun(E,C),Xsa: list(D),Ys: list(E)] : aa(list(product_prod(D,E)),list(product_prod(B,C)),map(product_prod(D,E),product_prod(B,C),aa(fun(D,fun(E,product_prod(B,C))),fun(product_prod(D,E),product_prod(B,C)),product_case_prod(D,E,product_prod(B,C)),aa(fun(E,C),fun(D,fun(E,product_prod(B,C))),aTP_Lamp_kc(fun(D,B),fun(fun(E,C),fun(D,fun(E,product_prod(B,C)))),F),G))),zip(D,E,Xsa,Ys)) = zip(B,C,aa(list(D),list(B),map(D,B,F),Xsa),aa(list(E),list(C),map(E,C,G),Ys)) ).

% map_prod_fun_zip
tff(fact_3894_zip__map2,axiom,
    ! [C: $tType,B: $tType,D: $tType,Xsa: list(B),F: fun(D,C),Ys: list(D)] : zip(B,C,Xsa,aa(list(D),list(C),map(D,C,F),Ys)) = aa(list(product_prod(B,D)),list(product_prod(B,C)),map(product_prod(B,D),product_prod(B,C),aa(fun(B,fun(D,product_prod(B,C))),fun(product_prod(B,D),product_prod(B,C)),product_case_prod(B,D,product_prod(B,C)),aTP_Lamp_od(fun(D,C),fun(B,fun(D,product_prod(B,C))),F))),zip(B,D,Xsa,Ys)) ).

% zip_map2
tff(fact_3895_zip__map1,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(D,B),Xsa: list(D),Ys: list(C)] : zip(B,C,aa(list(D),list(B),map(D,B,F),Xsa),Ys) = aa(list(product_prod(D,C)),list(product_prod(B,C)),map(product_prod(D,C),product_prod(B,C),aa(fun(D,fun(C,product_prod(B,C))),fun(product_prod(D,C),product_prod(B,C)),product_case_prod(D,C,product_prod(B,C)),aTP_Lamp_qu(fun(D,B),fun(D,fun(C,product_prod(B,C))),F))),zip(D,C,Xsa,Ys)) ).

% zip_map1
tff(fact_3896_map__of__zip__map,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),F: fun(B,C),X: B] :
      aa(B,option(C),map_of(B,C,zip(B,C,Xsa,aa(list(B),list(C),map(B,C,F),Xsa))),X) = $ite(member(B,X,aa(list(B),set(B),set2(B),Xsa)),aa(C,option(C),some(C),aa(B,C,F,X)),none(C)) ).

% map_of_zip_map
tff(fact_3897_map__of__zip__upd,axiom,
    ! [C: $tType,B: $tType,Ys: list(B),Xsa: list(C),Zs: list(B),X2: C,Y: B,Z2: B] :
      ( ( aa(list(B),nat,size_size(list(B)),Ys) = aa(list(C),nat,size_size(list(C)),Xsa) )
     => ( ( aa(list(B),nat,size_size(list(B)),Zs) = aa(list(C),nat,size_size(list(C)),Xsa) )
       => ( ~ member(C,X2,aa(list(C),set(C),set2(C),Xsa))
         => ( ( fun_upd(C,option(B),map_of(C,B,zip(C,B,Xsa,Ys)),X2,aa(B,option(B),some(B),Y)) = fun_upd(C,option(B),map_of(C,B,zip(C,B,Xsa,Zs)),X2,aa(B,option(B),some(B),Z2)) )
           => ( map_of(C,B,zip(C,B,Xsa,Ys)) = map_of(C,B,zip(C,B,Xsa,Zs)) ) ) ) ) ) ).

% map_of_zip_upd
tff(fact_3898_map__of__zip__nth,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),I: nat] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( distinct(B,Xsa)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(C),nat,size_size(list(C)),Ys))
         => ( aa(B,option(C),map_of(B,C,zip(B,C,Xsa,Ys)),aa(nat,B,nth(B,Xsa),I)) = aa(C,option(C),some(C),aa(nat,C,nth(C,Ys),I)) ) ) ) ) ).

% map_of_zip_nth
tff(fact_3899_foldr__snd__zip,axiom,
    ! [C: $tType,B: $tType,D: $tType,Ys: list(B),Xsa: list(C),F: fun(B,fun(D,D)),B2: D] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Ys)),aa(list(C),nat,size_size(list(C)),Xsa))
     => ( aa(D,D,foldr(product_prod(C,B),D,aa(fun(C,fun(B,fun(D,D))),fun(product_prod(C,B),fun(D,D)),product_case_prod(C,B,fun(D,D)),aTP_Lamp_qv(fun(B,fun(D,D)),fun(C,fun(B,fun(D,D))),F)),zip(C,B,Xsa,Ys)),B2) = aa(D,D,foldr(B,D,F,Ys),B2) ) ) ).

% foldr_snd_zip
tff(fact_3900_nths__shift__lemma,axiom,
    ! [B: $tType,A4: set(nat),Xsa: list(B),I: nat] : aa(list(product_prod(B,nat)),list(B),map(product_prod(B,nat),B,product_fst(B,nat)),filter(product_prod(B,nat),aTP_Lamp_qw(set(nat),fun(product_prod(B,nat),$o),A4),zip(B,nat,Xsa,upt(I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),aa(list(B),nat,size_size(list(B)),Xsa)))))) = aa(list(product_prod(B,nat)),list(B),map(product_prod(B,nat),B,product_fst(B,nat)),filter(product_prod(B,nat),aa(nat,fun(product_prod(B,nat),$o),aTP_Lamp_qx(set(nat),fun(nat,fun(product_prod(B,nat),$o)),A4),I),zip(B,nat,Xsa,upt(zero_zero(nat),aa(list(B),nat,size_size(list(B)),Xsa))))) ).

% nths_shift_lemma
tff(fact_3901_remove__rev__alt__def,axiom,
    ! [B: $tType,X2: B,Xsa: list(B)] : aa(list(B),list(B),remove_rev(B,X2),Xsa) = filter(B,aTP_Lamp_qy(B,fun(B,$o),X2),rev(B,Xsa)) ).

% remove_rev_alt_def
tff(fact_3902_zip__Cons1,axiom,
    ! [B: $tType,C: $tType,X2: B,Xsa: list(B),Ys: list(C)] : zip(B,C,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Ys) = aa(list(C),list(product_prod(B,C)),case_list(list(product_prod(B,C)),C,nil(product_prod(B,C)),aa(list(B),fun(C,fun(list(C),list(product_prod(B,C)))),aTP_Lamp_qz(B,fun(list(B),fun(C,fun(list(C),list(product_prod(B,C))))),X2),Xsa)),Ys) ).

% zip_Cons1
tff(fact_3903_zip__Cons,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Y: C,Ys: list(C)] : zip(B,C,Xsa,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)) = aa(list(B),list(product_prod(B,C)),case_list(list(product_prod(B,C)),B,nil(product_prod(B,C)),aa(list(C),fun(B,fun(list(B),list(product_prod(B,C)))),aTP_Lamp_ra(C,fun(list(C),fun(B,fun(list(B),list(product_prod(B,C))))),Y),Ys)),Xsa) ).

% zip_Cons
tff(fact_3904_filter__rev__alt,axiom,
    ! [B: $tType,P: fun(B,$o),L: list(B)] : aa(list(B),list(B),aa(fun(B,$o),fun(list(B),list(B)),filter_rev(B),P),L) = filter(B,P,rev(B,L)) ).

% filter_rev_alt
tff(fact_3905_remove__rev__def,axiom,
    ! [B: $tType,X2: B] : remove_rev(B,X2) = aa(fun(B,$o),fun(list(B),list(B)),filter_rev(B),aa(fun(B,$o),fun(B,$o),aa(fun($o,$o),fun(fun(B,$o),fun(B,$o)),comp($o,$o,B),fNot),aa(B,fun(B,$o),fequal(B),X2))) ).

% remove_rev_def
tff(fact_3906_min__list_Opelims,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [X2: list(B),Y: B] :
          ( ( min_list(B,X2) = Y )
         => ( aa(list(B),$o,accp(list(B),min_list_rel(B)),X2)
           => ( ! [X3: B,Xs: list(B)] :
                  ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
                 => ( ( Y = aa(list(B),B,case_list(B,B,X3,aa(list(B),fun(B,fun(list(B),B)),aTP_Lamp_rb(B,fun(list(B),fun(B,fun(list(B),B))),X3),Xs)),Xs) )
                   => ~ aa(list(B),$o,accp(list(B),min_list_rel(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)) ) )
             => ~ ( ( X2 = nil(B) )
                 => ( ( Y = undefined(B) )
                   => ~ aa(list(B),$o,accp(list(B),min_list_rel(B)),nil(B)) ) ) ) ) ) ) ).

% min_list.pelims
tff(fact_3907_merge__list_Opsimps_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B)] :
          ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),nil(list(B)))))
         => ( merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),nil(list(B)))) = L ) ) ) ).

% merge_list.psimps(2)
tff(fact_3908_merge__list_Opsimps_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [La: list(B),Acc22: list(list(B))] :
          ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22)),nil(list(B))))
         => ( merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22),nil(list(B))) = merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22)) ) ) ) ).

% merge_list.psimps(3)
tff(fact_3909_merge__list_Opsimps_I4_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [La: list(B),Acc22: list(list(B)),L: list(B)] :
          ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),nil(list(B)))))
         => ( merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),nil(list(B)))) = merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La),Acc22))) ) ) ) ).

% merge_list.psimps(4)
tff(fact_3910_merge__list_Opsimps_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),nil(list(B))))
       => ( merge_list(B,nil(list(B)),nil(list(B))) = nil(B) ) ) ) ).

% merge_list.psimps(1)
tff(fact_3911_merge__list_Opelims,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: list(list(B)),Xa: list(list(B)),Y: list(B)] :
          ( ( merge_list(B,X2,Xa) = Y )
         => ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),X2),Xa))
           => ( ( ( X2 = nil(list(B)) )
               => ( ( Xa = nil(list(B)) )
                 => ( ( Y = nil(B) )
                   => ~ aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),nil(list(B)))) ) ) )
             => ( ( ( X2 = nil(list(B)) )
                 => ! [L5: list(B)] :
                      ( ( Xa = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))) )
                     => ( ( Y = L5 )
                       => ~ aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))))) ) ) )
               => ( ! [La2: list(B),Acc23: list(list(B))] :
                      ( ( X2 = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23) )
                     => ( ( Xa = nil(list(B)) )
                       => ( ( Y = merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)) )
                         => ~ aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),nil(list(B)))) ) ) )
                 => ( ! [La2: list(B),Acc23: list(list(B))] :
                        ( ( X2 = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23) )
                       => ! [L5: list(B)] :
                            ( ( Xa = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))) )
                           => ( ( Y = merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23))) )
                             => ~ aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))))) ) ) )
                   => ~ ! [L12: list(B),L22: list(B),Ls2: list(list(B))] :
                          ( ( Xa = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L12),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L22),Ls2)) )
                         => ( ( Y = merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),merge(B,L12,L22)),X2),Ls2) )
                           => ~ aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),X2),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L12),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L22),Ls2)))) ) ) ) ) ) ) ) ) ) ).

% merge_list.pelims
tff(fact_3912_merge__list_Opsimps_I5_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Acc22: list(list(B)),L1: list(B),L2: list(B),Ls: list(list(B))] :
          ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),Acc22),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L1),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L2),Ls))))
         => ( merge_list(B,Acc22,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L1),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L2),Ls))) = merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),merge(B,L1,L2)),Acc22),Ls) ) ) ) ).

% merge_list.psimps(5)
tff(fact_3913_partition__filter__conv,axiom,
    ! [B: $tType,F: fun(B,$o),Xsa: list(B)] : aa(list(B),product_prod(list(B),list(B)),partition(B,F),Xsa) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),filter(B,F,Xsa)),filter(B,aa(fun(B,$o),fun(B,$o),aa(fun($o,$o),fun(fun(B,$o),fun(B,$o)),comp($o,$o,B),fNot),F),Xsa)) ).

% partition_filter_conv
tff(fact_3914_partition__rev__filter__conv,axiom,
    ! [B: $tType,P: fun(B,$o),Yes2: list(B),No2: list(B),Xsa: list(B)] : partition_rev(B,P,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),No2),Xsa) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),rev(B,filter(B,P,Xsa))),Yes2)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),rev(B,filter(B,aa(fun(B,$o),fun(B,$o),aa(fun($o,$o),fun(fun(B,$o),fun(B,$o)),comp($o,$o,B),fNot),P),Xsa))),No2)) ).

% partition_rev_filter_conv
tff(fact_3915_merge_Osimps_I1_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L2: list(B)] : merge(B,nil(B),L2) = L2 ) ).

% merge.simps(1)
tff(fact_3916_merge_Osimps_I3_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X1: B,L1: list(B),X22: B,L2: list(B)] :
          merge(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),L1),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),L2)) = $ite(
            aa(B,$o,aa(B,fun(B,$o),ord_less(B),X1),X22),
            aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),merge(B,L1,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),L2))),
            $ite(X1 = X22,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),merge(B,L1,L2)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X22),merge(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X1),L1),L2))) ) ) ).

% merge.simps(3)
tff(fact_3917_merge_Osimps_I2_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [V: B,Va2: list(B)] : merge(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V),Va2),nil(B)) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V),Va2) ) ).

% merge.simps(2)
tff(fact_3918_partition__rev_Osimps_I2_J,axiom,
    ! [B: $tType,P: fun(B,$o),Yes2: list(B),No2: list(B),X2: B,Xsa: list(B)] :
      partition_rev(B,P,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),No2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = partition_rev(B,P,
        $ite(aa(B,$o,P,X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Yes2)),No2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),No2))),
        Xsa) ).

% partition_rev.simps(2)
tff(fact_3919_partition__rev_Osimps_I1_J,axiom,
    ! [B: $tType,P: fun(B,$o),Yes2: list(B),No2: list(B)] : partition_rev(B,P,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),No2),nil(B)) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),No2) ).

% partition_rev.simps(1)
tff(fact_3920_merge__list_Osimps_I5_J,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Acc22: list(list(B)),L1: list(B),L2: list(B),Ls: list(list(B))] : merge_list(B,Acc22,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L1),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L2),Ls))) = merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),merge(B,L1,L2)),Acc22),Ls) ) ).

% merge_list.simps(5)
tff(fact_3921_partition_Osimps_I1_J,axiom,
    ! [B: $tType,P: fun(B,$o)] : aa(list(B),product_prod(list(B),list(B)),partition(B,P),nil(B)) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)) ).

% partition.simps(1)
tff(fact_3922_partition__P,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),Yes2: list(B),No2: list(B)] :
      ( ( aa(list(B),product_prod(list(B),list(B)),partition(B,P),Xsa) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),No2) )
     => ( ! [X: B] :
            ( member(B,X,aa(list(B),set(B),set2(B),Yes2))
           => aa(B,$o,P,X) )
        & ! [X: B] :
            ( member(B,X,aa(list(B),set(B),set2(B),No2))
           => ~ aa(B,$o,P,X) ) ) ) ).

% partition_P
tff(fact_3923_merge_Oelims,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: list(B),Xa: list(B),Y: list(B)] :
          ( ( merge(B,X2,Xa) = Y )
         => ( ( ( X2 = nil(B) )
             => ( Y != Xa ) )
           => ( ! [V4: B,Va: list(B)] :
                  ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                 => ( ( Xa = nil(B) )
                   => ( Y != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) ) ) )
             => ~ ! [X12: B,L12: list(B)] :
                    ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),L12) )
                   => ! [X23: B,L22: list(B)] :
                        ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),L22) )
                       => ( Y != $ite(
                              aa(B,$o,aa(B,fun(B,$o),ord_less(B),X12),X23),
                              aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),merge(B,L12,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),L22))),
                              $ite(X12 = X23,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),merge(B,L12,L22)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),merge(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),L12),L22))) ) ) ) ) ) ) ) ) ).

% merge.elims
tff(fact_3924_partition_Osimps_I2_J,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B,Xsa: list(B)] : aa(list(B),product_prod(list(B),list(B)),partition(B,P),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(product_prod(list(B),list(B)),product_prod(list(B),list(B)),aa(fun(list(B),fun(list(B),product_prod(list(B),list(B)))),fun(product_prod(list(B),list(B)),product_prod(list(B),list(B))),product_case_prod(list(B),list(B),product_prod(list(B),list(B))),aa(B,fun(list(B),fun(list(B),product_prod(list(B),list(B)))),aTP_Lamp_rc(fun(B,$o),fun(B,fun(list(B),fun(list(B),product_prod(list(B),list(B))))),P),X2)),aa(list(B),product_prod(list(B),list(B)),partition(B,P),Xsa)) ).

% partition.simps(2)
tff(fact_3925_partition__rev_Oelims,axiom,
    ! [B: $tType,X2: fun(B,$o),Xa: product_prod(list(B),list(B)),Xb: list(B),Y: product_prod(list(B),list(B))] :
      ( ( partition_rev(B,X2,Xa,Xb) = Y )
     => ( ! [Yes: list(B),No: list(B)] :
            ( ( Xa = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No) )
           => ( ( Xb = nil(B) )
             => ( Y != aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No) ) ) )
       => ~ ! [Yes: list(B),No: list(B)] :
              ( ( Xa = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No) )
             => ! [X3: B,Xs: list(B)] :
                  ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
                 => ( Y != partition_rev(B,X2,
                        $ite(aa(B,$o,X2,X3),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Yes)),No),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),No))),
                        Xs) ) ) ) ) ) ).

% partition_rev.elims
tff(fact_3926_partition__set,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B),Yes2: list(B),No2: list(B)] :
      ( ( aa(list(B),product_prod(list(B),list(B)),partition(B,P),Xsa) = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes2),No2) )
     => ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(list(B),set(B),set2(B),Yes2)),aa(list(B),set(B),set2(B),No2)) = aa(list(B),set(B),set2(B),Xsa) ) ) ).

% partition_set
tff(fact_3927_inv__image__partition,axiom,
    ! [B: $tType,Xsa: list(B),P: fun(B,$o),Ys: list(B)] :
      ( ! [X3: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => aa(B,$o,P,X3) )
     => ( ! [Y4: B] :
            ( member(B,Y4,aa(list(B),set(B),set2(B),Ys))
           => ~ aa(B,$o,P,Y4) )
       => ( aa(set(product_prod(list(B),list(B))),set(list(B)),vimage(list(B),product_prod(list(B),list(B)),partition(B,P)),aa(set(product_prod(list(B),list(B))),set(product_prod(list(B),list(B))),insert2(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys)),bot_bot(set(product_prod(list(B),list(B)))))) = shuffles(B,Xsa,Ys) ) ) ) ).

% inv_image_partition
tff(fact_3928_merge__list_Oelims,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: list(list(B)),Xa: list(list(B)),Y: list(B)] :
          ( ( merge_list(B,X2,Xa) = Y )
         => ( ( ( X2 = nil(list(B)) )
             => ( ( Xa = nil(list(B)) )
               => ( Y != nil(B) ) ) )
           => ( ( ( X2 = nil(list(B)) )
               => ! [L5: list(B)] :
                    ( ( Xa = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))) )
                   => ( Y != L5 ) ) )
             => ( ! [La2: list(B),Acc23: list(list(B))] :
                    ( ( X2 = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23) )
                   => ( ( Xa = nil(list(B)) )
                     => ( Y != merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)) ) ) )
               => ( ! [La2: list(B),Acc23: list(list(B))] :
                      ( ( X2 = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23) )
                     => ! [L5: list(B)] :
                          ( ( Xa = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B))) )
                         => ( Y != merge_list(B,nil(list(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23))) ) ) )
                 => ~ ! [L12: list(B),L22: list(B),Ls2: list(list(B))] :
                        ( ( Xa = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L12),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L22),Ls2)) )
                       => ( Y != merge_list(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),merge(B,L12,L22)),X2),Ls2) ) ) ) ) ) ) ) ) ).

% merge_list.elims
tff(fact_3929_merge__correct,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L1: list(B),L2: list(B)] :
          ( ( distinct(B,L1)
            & sorted_wrt(B,ord_less_eq(B),L1) )
         => ( ( distinct(B,L2)
              & sorted_wrt(B,ord_less_eq(B),L2) )
           => ( distinct(B,merge(B,L1,L2))
              & sorted_wrt(B,ord_less_eq(B),merge(B,L1,L2))
              & ( aa(list(B),set(B),set2(B),merge(B,L1,L2)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(list(B),set(B),set2(B),L1)),aa(list(B),set(B),set2(B),L2)) ) ) ) ) ) ).

% merge_correct
tff(fact_3930_merge__list_Opinduct,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [A0: list(list(B)),A1: list(list(B)),P: fun(list(list(B)),fun(list(list(B)),$o))] :
          ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),A0),A1))
         => ( ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),nil(list(B))))
             => aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,nil(list(B))),nil(list(B))) )
           => ( ! [L5: list(B)] :
                  ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B)))))
                 => aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B)))) )
             => ( ! [La2: list(B),Acc23: list(list(B))] :
                    ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),nil(list(B))))
                   => ( aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23))
                     => aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),nil(list(B))) ) )
               => ( ! [La2: list(B),Acc23: list(list(B)),L5: list(B)] :
                      ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B)))))
                     => ( aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,nil(list(B))),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)))
                       => aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),La2),Acc23)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L5),nil(list(B)))) ) )
                 => ( ! [Acc23: list(list(B)),L12: list(B),L22: list(B),Ls2: list(list(B))] :
                        ( aa(product_prod(list(list(B)),list(list(B))),$o,accp(product_prod(list(list(B)),list(list(B))),merge_list_rel(B)),aa(list(list(B)),product_prod(list(list(B)),list(list(B))),aa(list(list(B)),fun(list(list(B)),product_prod(list(list(B)),list(list(B)))),product_Pair(list(list(B)),list(list(B))),Acc23),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L12),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L22),Ls2))))
                       => ( aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),merge(B,L12,L22)),Acc23)),Ls2)
                         => aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,Acc23),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L12),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),L22),Ls2))) ) )
                   => aa(list(list(B)),$o,aa(list(list(B)),fun(list(list(B)),$o),P,A0),A1) ) ) ) ) ) ) ) ).

% merge_list.pinduct
tff(fact_3931_partition__rev_Opelims,axiom,
    ! [B: $tType,X2: fun(B,$o),Xa: product_prod(list(B),list(B)),Xb: list(B),Y: product_prod(list(B),list(B))] :
      ( ( partition_rev(B,X2,Xa,Xb) = Y )
     => ( aa(product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),$o,accp(product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),partition_rev_rel(B)),aa(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),aa(fun(B,$o),fun(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B)))),product_Pair(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),X2),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),Xa),Xb)))
       => ( ! [Yes: list(B),No: list(B)] :
              ( ( Xa = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No) )
             => ( ( Xb = nil(B) )
               => ( ( Y = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No) )
                 => ~ aa(product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),$o,accp(product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),partition_rev_rel(B)),aa(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),aa(fun(B,$o),fun(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B)))),product_Pair(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),X2),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No)),nil(B)))) ) ) )
         => ~ ! [Yes: list(B),No: list(B)] :
                ( ( Xa = aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No) )
               => ! [X3: B,Xs: list(B)] :
                    ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
                   => ( ( Y = partition_rev(B,X2,
                            $ite(aa(B,$o,X2,X3),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Yes)),No),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),No))),
                            Xs) )
                     => ~ aa(product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),$o,accp(product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),partition_rev_rel(B)),aa(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),aa(fun(B,$o),fun(product_prod(product_prod(list(B),list(B)),list(B)),product_prod(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B)))),product_Pair(fun(B,$o),product_prod(product_prod(list(B),list(B)),list(B))),X2),aa(list(B),product_prod(product_prod(list(B),list(B)),list(B)),aa(product_prod(list(B),list(B)),fun(list(B),product_prod(product_prod(list(B),list(B)),list(B))),product_Pair(product_prod(list(B),list(B)),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Yes),No)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)))) ) ) ) ) ) ) ).

% partition_rev.pelims
tff(fact_3932_merge_Opelims,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: list(B),Xa: list(B),Y: list(B)] :
          ( ( merge(B,X2,Xa) = Y )
         => ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),merge_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Xa))
           => ( ( ( X2 = nil(B) )
               => ( ( Y = Xa )
                 => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),merge_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Xa)) ) )
             => ( ! [V4: B,Va: list(B)] :
                    ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                   => ( ( Xa = nil(B) )
                     => ( ( Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                       => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),merge_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)),nil(B))) ) ) )
               => ~ ! [X12: B,L12: list(B)] :
                      ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),L12) )
                     => ! [X23: B,L22: list(B)] :
                          ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),L22) )
                         => ( ( Y = $ite(
                                  aa(B,$o,aa(B,fun(B,$o),ord_less(B),X12),X23),
                                  aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),merge(B,L12,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),L22))),
                                  $ite(X12 = X23,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),merge(B,L12,L22)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),merge(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),L12),L22))) ) )
                           => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),merge_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X12),L12)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X23),L22))) ) ) ) ) ) ) ) ) ).

% merge.pelims
tff(fact_3933_transpose_Opinduct,axiom,
    ! [B: $tType,A0: list(list(B)),P: fun(list(list(B)),$o)] :
      ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),A0)
     => ( ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),nil(list(B)))
         => aa(list(list(B)),$o,P,nil(list(B))) )
       => ( ! [Xss2: list(list(B))] :
              ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),nil(B)),Xss2))
             => ( aa(list(list(B)),$o,P,Xss2)
               => aa(list(list(B)),$o,P,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),nil(B)),Xss2)) ) )
         => ( ! [X3: B,Xs: list(B),Xss2: list(list(B))] :
                ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Xss2))
               => ( aa(list(list(B)),$o,P,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),Xs),concat(list(B),aa(list(list(B)),list(list(list(B))),map(list(B),list(list(B)),case_list(list(list(B)),B,nil(list(B)),aTP_Lamp_rd(B,fun(list(B),list(list(B)))))),Xss2))))
                 => aa(list(list(B)),$o,P,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Xss2)) ) )
           => aa(list(list(B)),$o,P,A0) ) ) ) ) ).

% transpose.pinduct
tff(fact_3934_quicksort__by__rel_Oelims,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Xb: list(B),Y: list(B)] :
      ( ( aa(list(B),list(B),quicksort_by_rel(B,X2,Xa),Xb) = Y )
     => ( ( ( Xb = nil(B) )
         => ( Y != Xa ) )
       => ~ ! [X3: B,Xs: list(B)] :
              ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
             => ( Y != aa(product_prod(list(B),list(B)),list(B),aa(fun(list(B),fun(list(B),list(B))),fun(product_prod(list(B),list(B)),list(B)),product_case_prod(list(B),list(B),list(B)),aa(B,fun(list(B),fun(list(B),list(B))),aa(list(B),fun(B,fun(list(B),fun(list(B),list(B)))),aTP_Lamp_re(fun(B,fun(B,$o)),fun(list(B),fun(B,fun(list(B),fun(list(B),list(B))))),X2),Xa),X3)),partition_rev(B,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),X2),X3),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xs)) ) ) ) ) ).

% quicksort_by_rel.elims
tff(fact_3935_set__quicksort__by__rel,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B),Xsa: list(B)] : aa(list(B),set(B),set2(B),aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),Xsa)) = aa(list(B),set(B),set2(B),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Sl2)) ).

% set_quicksort_by_rel
tff(fact_3936_quicksort__by__rel_Osimps_I1_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B)] : aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),nil(B)) = Sl2 ).

% quicksort_by_rel.simps(1)
tff(fact_3937_quicksort__by__rel__remove__acc,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B),Xsa: list(B)] : aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),Xsa) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),aa(list(B),list(B),quicksort_by_rel(B,R4,nil(B)),Xsa)),Sl2) ).

% quicksort_by_rel_remove_acc
tff(fact_3938_quicksort__by__rel__remove__acc__guared,axiom,
    ! [B: $tType,Sl2: list(B),R4: fun(B,fun(B,$o)),Xsa: list(B)] :
      ( ( Sl2 != nil(B) )
     => ( aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),Xsa) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),aa(list(B),list(B),quicksort_by_rel(B,R4,nil(B)),Xsa)),Sl2) ) ) ).

% quicksort_by_rel_remove_acc_guared
tff(fact_3939_sorted__wrt__quicksort__by__rel,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] :
      ( ! [X3: B,Y4: B] :
          ( aa(B,$o,aa(B,fun(B,$o),R4,X3),Y4)
          | aa(B,$o,aa(B,fun(B,$o),R4,Y4),X3) )
     => ( ! [X3: B,Y4: B,Z3: B] :
            ( aa(B,$o,aa(B,fun(B,$o),R4,X3),Y4)
           => ( aa(B,$o,aa(B,fun(B,$o),R4,Y4),Z3)
             => aa(B,$o,aa(B,fun(B,$o),R4,X3),Z3) ) )
       => sorted_wrt(B,R4,aa(list(B),list(B),quicksort_by_rel(B,R4,nil(B)),Xsa)) ) ) ).

% sorted_wrt_quicksort_by_rel
tff(fact_3940_sorted__quicksort__by__rel,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B)] : sorted_wrt(B,ord_less_eq(B),aa(list(B),list(B),quicksort_by_rel(B,ord_less_eq(B),nil(B)),Xsa)) ) ).

% sorted_quicksort_by_rel
tff(fact_3941_quicksort__by__rel_Osimps_I2_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B),X2: B,Xsa: list(B)] : aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(product_prod(list(B),list(B)),list(B),aa(fun(list(B),fun(list(B),list(B))),fun(product_prod(list(B),list(B)),list(B)),product_case_prod(list(B),list(B),list(B)),aa(B,fun(list(B),fun(list(B),list(B))),aa(list(B),fun(B,fun(list(B),fun(list(B),list(B)))),aTP_Lamp_re(fun(B,fun(B,$o)),fun(list(B),fun(B,fun(list(B),fun(list(B),list(B))))),R4),Sl2),X2)),partition_rev(B,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),R4),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xsa)) ).

% quicksort_by_rel.simps(2)
tff(fact_3942_transpose_Opsimps_I3_J,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Xss: list(list(B))] :
      ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),Xss))
     => ( transpose(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),Xss)) = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),concat(B,aa(list(list(B)),list(list(B)),map(list(B),list(B),case_list(list(B),B,nil(B),aTP_Lamp_rg(B,fun(list(B),list(B))))),Xss)))),transpose(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),Xsa),concat(list(B),aa(list(list(B)),list(list(list(B))),map(list(B),list(list(B)),case_list(list(list(B)),B,nil(list(B)),aTP_Lamp_rd(B,fun(list(B),list(list(B)))))),Xss))))) ) ) ).

% transpose.psimps(3)
tff(fact_3943_transpose_Opelims,axiom,
    ! [B: $tType,X2: list(list(B)),Y: list(list(B))] :
      ( ( transpose(B,X2) = Y )
     => ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),X2)
       => ( ( ( X2 = nil(list(B)) )
           => ( ( Y = nil(list(B)) )
             => ~ aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),nil(list(B))) ) )
         => ( ! [Xss2: list(list(B))] :
                ( ( X2 = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),nil(B)),Xss2) )
               => ( ( Y = transpose(B,Xss2) )
                 => ~ aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),nil(B)),Xss2)) ) )
           => ~ ! [X3: B,Xs: list(B),Xss2: list(list(B))] :
                  ( ( X2 = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Xss2) )
                 => ( ( Y = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),concat(B,aa(list(list(B)),list(list(B)),map(list(B),list(B),case_list(list(B),B,nil(B),aTP_Lamp_rg(B,fun(list(B),list(B))))),Xss2)))),transpose(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),Xs),concat(list(B),aa(list(list(B)),list(list(list(B))),map(list(B),list(list(B)),case_list(list(list(B)),B,nil(list(B)),aTP_Lamp_rd(B,fun(list(B),list(list(B)))))),Xss2))))) )
                   => ~ aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),Xss2)) ) ) ) ) ) ) ).

% transpose.pelims
tff(fact_3944_quicksort__by__rel_Opsimps_I2_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B),X2: B,Xsa: list(B)] :
      ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R4),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Sl2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa))))
     => ( aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(product_prod(list(B),list(B)),list(B),aa(fun(list(B),fun(list(B),list(B))),fun(product_prod(list(B),list(B)),list(B)),product_case_prod(list(B),list(B),list(B)),aa(B,fun(list(B),fun(list(B),list(B))),aa(list(B),fun(B,fun(list(B),fun(list(B),list(B)))),aTP_Lamp_re(fun(B,fun(B,$o)),fun(list(B),fun(B,fun(list(B),fun(list(B),list(B))))),R4),Sl2),X2)),partition_rev(B,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),R4),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xsa)) ) ) ).

% quicksort_by_rel.psimps(2)
tff(fact_3945_quicksort__by__rel_Opelims,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Xb: list(B),Y: list(B)] :
      ( ( aa(list(B),list(B),quicksort_by_rel(B,X2,Xa),Xb) = Y )
     => ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xa),Xb)))
       => ( ( ( Xb = nil(B) )
           => ( ( Y = Xa )
             => ~ aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xa),nil(B)))) ) )
         => ~ ! [X3: B,Xs: list(B)] :
                ( ( Xb = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
               => ( ( Y = aa(product_prod(list(B),list(B)),list(B),aa(fun(list(B),fun(list(B),list(B))),fun(product_prod(list(B),list(B)),list(B)),product_case_prod(list(B),list(B),list(B)),aa(B,fun(list(B),fun(list(B),list(B))),aa(list(B),fun(B,fun(list(B),fun(list(B),list(B)))),aTP_Lamp_re(fun(B,fun(B,$o)),fun(list(B),fun(B,fun(list(B),fun(list(B),list(B))))),X2),Xa),X3)),partition_rev(B,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),X2),X3),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xs)) )
                 => ~ aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),X2),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)))) ) ) ) ) ) ).

% quicksort_by_rel.pelims
tff(fact_3946_transpose_Opsimps_I1_J,axiom,
    ! [B: $tType] :
      ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),nil(list(B)))
     => ( transpose(B,nil(list(B))) = nil(list(B)) ) ) ).

% transpose.psimps(1)
tff(fact_3947_transpose_Opsimps_I2_J,axiom,
    ! [B: $tType,Xss: list(list(B))] :
      ( aa(list(list(B)),$o,accp(list(list(B)),transpose_rel(B)),aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),nil(B)),Xss))
     => ( transpose(B,aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),nil(B)),Xss)) = transpose(B,Xss) ) ) ).

% transpose.psimps(2)
tff(fact_3948_quicksort__by__rel_Opsimps_I1_J,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B)] :
      ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R4),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Sl2),nil(B))))
     => ( aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),nil(B)) = Sl2 ) ) ).

% quicksort_by_rel.psimps(1)
tff(fact_3949_quicksort__by__rel_Opinduct,axiom,
    ! [B: $tType,A0: fun(B,fun(B,$o)),A1: list(B),A22: list(B),P: fun(fun(B,fun(B,$o)),fun(list(B),fun(list(B),$o)))] :
      ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),A0),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),A1),A22)))
     => ( ! [R7: fun(B,fun(B,$o)),Sl: list(B)] :
            ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Sl),nil(B))))
           => aa(list(B),$o,aa(list(B),fun(list(B),$o),aa(fun(B,fun(B,$o)),fun(list(B),fun(list(B),$o)),P,R7),Sl),nil(B)) )
       => ( ! [R7: fun(B,fun(B,$o)),Sl: list(B),X3: B,Xs: list(B)] :
              ( aa(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),$o,accp(product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),quicksort_by_rel_rel(B)),aa(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B))),aa(fun(B,fun(B,$o)),fun(product_prod(list(B),list(B)),product_prod(fun(B,fun(B,$o)),product_prod(list(B),list(B)))),product_Pair(fun(B,fun(B,$o)),product_prod(list(B),list(B))),R7),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Sl),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs))))
             => ( ! [Xa3: product_prod(list(B),list(B)),Xb2: list(B),Y5: list(B)] :
                    ( ( Xa3 = partition_rev(B,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),R7),X3),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xs) )
                   => ( ( aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xb2),Y5) = Xa3 )
                     => aa(list(B),$o,aa(list(B),fun(list(B),$o),aa(fun(B,fun(B,$o)),fun(list(B),fun(list(B),$o)),P,R7),Sl),Y5) ) )
               => ( ! [Xa3: product_prod(list(B),list(B)),Xb2: list(B),Y5: list(B)] :
                      ( ( Xa3 = partition_rev(B,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),R7),X3),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),nil(B)),Xs) )
                     => ( ( aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xb2),Y5) = Xa3 )
                       => aa(list(B),$o,aa(list(B),fun(list(B),$o),aa(fun(B,fun(B,$o)),fun(list(B),fun(list(B),$o)),P,R7),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),quicksort_by_rel(B,R7,Sl),Y5))),Xb2) ) )
                 => aa(list(B),$o,aa(list(B),fun(list(B),$o),aa(fun(B,fun(B,$o)),fun(list(B),fun(list(B),$o)),P,R7),Sl),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)) ) ) )
         => aa(list(B),$o,aa(list(B),fun(list(B),$o),aa(fun(B,fun(B,$o)),fun(list(B),fun(list(B),$o)),P,A0),A1),A22) ) ) ) ).

% quicksort_by_rel.pinduct
tff(fact_3950_filter__rev__aux__alt,axiom,
    ! [B: $tType,A3: list(B),P: fun(B,$o),L: list(B)] : aa(list(B),list(B),aa(fun(B,$o),fun(list(B),list(B)),filter_rev_aux(B,A3),P),L) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),filter(B,P,rev(B,L))),A3) ).

% filter_rev_aux_alt
tff(fact_3951_lexord__take__index__conv,axiom,
    ! [B: $tType,X2: list(B),Y: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lexord(B,R))
    <=> ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),X2)),aa(list(B),nat,size_size(list(B)),Y))
          & ( take(B,aa(list(B),nat,size_size(list(B)),X2),Y) = X2 ) )
        | ? [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(nat,nat,ord_min(nat,aa(list(B),nat,size_size(list(B)),X2)),aa(list(B),nat,size_size(list(B)),Y)))
            & ( take(B,I3,X2) = take(B,I3,Y) )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,nth(B,X2),I3)),aa(nat,B,nth(B,Y),I3)),R) ) ) ) ).

% lexord_take_index_conv
tff(fact_3952_last__take__nth__conv,axiom,
    ! [B: $tType,N: nat,L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(B),nat,size_size(list(B)),L))
     => ( ( N != zero_zero(nat) )
       => ( last(B,take(B,N,L)) = aa(nat,B,nth(B,L),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ) ) ) ).

% last_take_nth_conv
tff(fact_3953_revg__fun,axiom,
    ! [B: $tType,A3: list(B),B2: list(B)] : revg(B,A3,B2) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),rev(B,A3)),B2) ).

% revg_fun
tff(fact_3954_take__upt,axiom,
    ! [I: nat,M: 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),M)),N)
     => ( take(nat,M,upt(I,N)) = upt(I,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),M)) ) ) ).

% take_upt
tff(fact_3955_take__Cons__numeral,axiom,
    ! [B: $tType,V: num,X2: B,Xsa: list(B)] : take(B,aa(num,nat,numeral_numeral(nat),V),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(num,nat,numeral_numeral(nat),V)),one_one(nat)),Xsa)) ).

% take_Cons_numeral
tff(fact_3956_take__drop,axiom,
    ! [B: $tType,N: nat,M: nat,Xsa: list(B)] : take(B,N,drop(B,M,Xsa)) = drop(B,M,take(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),M),Xsa)) ).

% take_drop
tff(fact_3957_revg_Osimps_I2_J,axiom,
    ! [B: $tType,A3: B,As2: list(B),B2: list(B)] : revg(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),As2),B2) = revg(B,As2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),B2)) ).

% revg.simps(2)
tff(fact_3958_revg_Osimps_I1_J,axiom,
    ! [B: $tType,B2: list(B)] : revg(B,nil(B),B2) = B2 ).

% revg.simps(1)
tff(fact_3959_filter__rev__aux_Osimps_I2_J,axiom,
    ! [B: $tType,A3: list(B),P: fun(B,$o),X2: B,Xsa: list(B)] :
      aa(list(B),list(B),aa(fun(B,$o),fun(list(B),list(B)),filter_rev_aux(B,A3),P),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = $ite(aa(B,$o,P,X2),aa(list(B),list(B),aa(fun(B,$o),fun(list(B),list(B)),filter_rev_aux(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),A3)),P),Xsa),aa(list(B),list(B),aa(fun(B,$o),fun(list(B),list(B)),filter_rev_aux(B,A3),P),Xsa)) ).

% filter_rev_aux.simps(2)
tff(fact_3960_filter__rev__aux_Osimps_I1_J,axiom,
    ! [B: $tType,A3: list(B),P: fun(B,$o)] : aa(list(B),list(B),aa(fun(B,$o),fun(list(B),list(B)),filter_rev_aux(B,A3),P),nil(B)) = A3 ).

% filter_rev_aux.simps(1)
tff(fact_3961_drop__take__drop__unsplit,axiom,
    ! [B: $tType,I: nat,J: nat,L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),drop(B,I,take(B,J,L))),drop(B,J,L)) = drop(B,I,L) ) ) ).

% drop_take_drop_unsplit
tff(fact_3962_take__add,axiom,
    ! [B: $tType,I: nat,J: nat,Xsa: list(B)] : take(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J),Xsa) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),take(B,I,Xsa)),take(B,J,drop(B,I,Xsa))) ).

% take_add
tff(fact_3963_slice__def,axiom,
    ! [B: $tType,From: nat,To: nat,List: list(B)] : slice(B,From,To,List) = take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),To),From),drop(B,From,List)) ).

% slice_def
tff(fact_3964_filter__upt__take__conv,axiom,
    ! [B: $tType,P: fun(B,$o),M: nat,L: list(B),N: nat] : filter(nat,aa(list(B),fun(nat,$o),aa(nat,fun(list(B),fun(nat,$o)),aTP_Lamp_rh(fun(B,$o),fun(nat,fun(list(B),fun(nat,$o))),P),M),L),upt(N,M)) = filter(nat,aa(list(B),fun(nat,$o),aTP_Lamp_ph(fun(B,$o),fun(list(B),fun(nat,$o)),P),L),upt(N,M)) ).

% filter_upt_take_conv
tff(fact_3965_zip__replicate1,axiom,
    ! [B: $tType,C: $tType,N: nat,X2: B,Ys: list(C)] : zip(B,C,replicate(B,N,X2),Ys) = aa(list(C),list(product_prod(B,C)),map(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2)),take(C,N,Ys)) ).

% zip_replicate1
tff(fact_3966_revg_Oelims,axiom,
    ! [B: $tType,X2: list(B),Xa: list(B),Y: list(B)] :
      ( ( revg(B,X2,Xa) = Y )
     => ( ( ( X2 = nil(B) )
         => ( Y != Xa ) )
       => ~ ! [A5: B,As: list(B)] :
              ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
             => ( Y != revg(B,As,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),Xa)) ) ) ) ) ).

% revg.elims
tff(fact_3967_zip__replicate2,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),N: nat,Y: C] : zip(B,C,Xsa,replicate(C,N,Y)) = aa(list(B),list(product_prod(B,C)),map(B,product_prod(B,C),aa(C,fun(B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))),Y)),take(B,N,Xsa)) ).

% zip_replicate2
tff(fact_3968_take__Cons_H,axiom,
    ! [B: $tType,N: nat,X2: B,Xsa: list(B)] :
      take(B,N,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = $ite(N = zero_zero(nat),nil(B),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),Xsa))) ).

% take_Cons'
tff(fact_3969_filter__nth__ex__nth,axiom,
    ! [B: $tType,N: nat,P: fun(B,$o),Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(B),nat,size_size(list(B)),filter(B,P,Xsa)))
     => ? [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(B),nat,size_size(list(B)),Xsa))
          & ( aa(nat,B,nth(B,filter(B,P,Xsa)),N) = aa(nat,B,nth(B,Xsa),M4) )
          & ( filter(B,P,take(B,M4,Xsa)) = take(B,N,filter(B,P,Xsa)) ) ) ) ).

% filter_nth_ex_nth
tff(fact_3970_map__upd__upds__conv__if,axiom,
    ! [B: $tType,C: $tType,F: fun(B,option(C)),X2: B,Y: C,Xsa: list(B),Ys: list(C)] :
      map_upds(B,C,fun_upd(B,option(C),F,X2,aa(C,option(C),some(C),Y)),Xsa,Ys) = $ite(member(B,X2,aa(list(B),set(B),set2(B),take(B,aa(list(C),nat,size_size(list(C)),Ys),Xsa))),map_upds(B,C,F,Xsa,Ys),fun_upd(B,option(C),map_upds(B,C,F,Xsa,Ys),X2,aa(C,option(C),some(C),Y))) ).

% map_upd_upds_conv_if
tff(fact_3971_Union__take__drop__id,axiom,
    ! [B: $tType,N: nat,L: list(set(B))] : aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(list(set(B)),set(set(B)),set2(set(B)),drop(set(B),N,L)))),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(list(set(B)),set(set(B)),set2(set(B)),take(set(B),N,L)))) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(list(set(B)),set(set(B)),set2(set(B)),L)) ).

% Union_take_drop_id
tff(fact_3972_lex__take__index,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lex(B,R))
     => ~ ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(B),nat,size_size(list(B)),Xsa))
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(B),nat,size_size(list(B)),Ys))
             => ( ( take(B,I2,Xsa) = take(B,I2,Ys) )
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,nth(B,Xsa),I2)),aa(nat,B,nth(B,Ys),I2)),R) ) ) ) ) ).

% lex_take_index
tff(fact_3973_map__nth__upt__drop__take__conv,axiom,
    ! [B: $tType,N5: nat,L: list(B),M2: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N5),aa(list(B),nat,size_size(list(B)),L))
     => ( aa(list(nat),list(B),map(nat,B,nth(B,L)),upt(M2,N5)) = drop(B,M2,take(B,N5,L)) ) ) ).

% map_nth_upt_drop_take_conv
tff(fact_3974_filter__rev__def,axiom,
    ! [B: $tType] : filter_rev(B) = filter_rev_aux(B,nil(B)) ).

% filter_rev_def
tff(fact_3975_revg_Opelims,axiom,
    ! [B: $tType,X2: list(B),Xa: list(B),Y: list(B)] :
      ( ( revg(B,X2,Xa) = Y )
     => ( aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),revg_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Xa))
       => ( ( ( X2 = nil(B) )
           => ( ( Y = Xa )
             => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),revg_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),nil(B)),Xa)) ) )
         => ~ ! [A5: B,As: list(B)] :
                ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
               => ( ( Y = revg(B,As,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),Xa)) )
                 => ~ aa(product_prod(list(B),list(B)),$o,accp(product_prod(list(B),list(B)),revg_rel(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),Xa)) ) ) ) ) ) ).

% revg.pelims
tff(fact_3976_take__butlast__conv,axiom,
    ! [B: $tType,L: list(B)] : take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),L)),aa(nat,nat,suc,zero_zero(nat))),L) = butlast(B,L) ).

% take_butlast_conv
tff(fact_3977_take__minus__one__conv__butlast,axiom,
    ! [B: $tType,N: nat,L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(B),nat,size_size(list(B)),L))
     => ( take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),aa(nat,nat,suc,zero_zero(nat))),L) = butlast(B,take(B,N,L)) ) ) ).

% take_minus_one_conv_butlast
tff(fact_3978_take__update__last,axiom,
    ! [B: $tType,N: nat,List: list(B),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(B),nat,size_size(list(B)),List))
     => ( list_update(B,take(B,aa(nat,nat,suc,N),List),N,X2) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),take(B,N,List)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) ) ) ).

% take_update_last
tff(fact_3979_take__update,axiom,
    ! [B: $tType,N: nat,L: list(B),I: nat,X2: B] : take(B,N,list_update(B,L,I,X2)) = list_update(B,take(B,N,L),I,X2) ).

% take_update
tff(fact_3980_drop__upd__irrelevant,axiom,
    ! [B: $tType,M: nat,N: nat,L: list(B),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
     => ( drop(B,N,list_update(B,L,M,X2)) = drop(B,N,L) ) ) ).

% drop_upd_irrelevant
tff(fact_3981_nth__update__invalid,axiom,
    ! [B: $tType,I: nat,L: list(B),J: nat,X2: B] :
      ( ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
     => ( aa(nat,B,nth(B,list_update(B,L,J,X2)),I) = aa(nat,B,nth(B,L),I) ) ) ).

% nth_update_invalid
tff(fact_3982_length__butlast,axiom,
    ! [B: $tType,Xsa: list(B)] : aa(list(B),nat,size_size(list(B)),butlast(B,Xsa)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)) ).

% length_butlast
tff(fact_3983_butlast__upd__last__eq,axiom,
    ! [B: $tType,L: list(B),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(list(B),nat,size_size(list(B)),L))
     => ( list_update(B,butlast(B,L),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),L)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),X2) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),L)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),L)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) ) ) ).

% butlast_upd_last_eq
tff(fact_3984_butlast__update_H,axiom,
    ! [B: $tType,L: list(B),I: nat,X2: B] : list_update(B,butlast(B,L),I,X2) = butlast(B,list_update(B,L,I,X2)) ).

% butlast_update'
tff(fact_3985_distinct__butlast__swap,axiom,
    ! [B: $tType,Pq: list(B),I: nat] :
      ( distinct(B,Pq)
     => distinct(B,butlast(B,list_update(B,Pq,I,last(B,Pq)))) ) ).

% distinct_butlast_swap
tff(fact_3986_zip__update,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),I: nat,X2: B,Ys: list(C),Y: C] : zip(B,C,list_update(B,Xsa,I,X2),list_update(C,Ys,I,Y)) = list_update(product_prod(B,C),zip(B,C,Xsa,Ys),I,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)) ).

% zip_update
tff(fact_3987_butlast__list__update,axiom,
    ! [B: $tType,Xsa: list(B),K: nat,X2: B] :
      butlast(B,list_update(B,Xsa,K,X2)) = $ite(K = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)),butlast(B,Xsa),list_update(B,butlast(B,Xsa),K,X2)) ).

% butlast_list_update
tff(fact_3988_in__set__upd__eq__aux,axiom,
    ! [B: $tType,I: nat,L: list(B),X2: B,Y: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
     => ( member(B,X2,aa(list(B),set(B),set2(B),list_update(B,L,I,Y)))
      <=> ( ( X2 = Y )
          | ! [Y3: B] : member(B,X2,aa(list(B),set(B),set2(B),list_update(B,L,I,Y3))) ) ) ) ).

% in_set_upd_eq_aux
tff(fact_3989_in__set__upd__cases,axiom,
    ! [B: $tType,X2: B,L: list(B),I: nat,Y: B] :
      ( member(B,X2,aa(list(B),set(B),set2(B),list_update(B,L,I,Y)))
     => ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
         => ( X2 != Y ) )
       => member(B,X2,aa(list(B),set(B),set2(B),L)) ) ) ).

% in_set_upd_cases
tff(fact_3990_in__set__upd__eq,axiom,
    ! [B: $tType,I: nat,L: list(B),X2: B,Y: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
     => ( member(B,X2,aa(list(B),set(B),set2(B),list_update(B,L,I,Y)))
      <=> ( ( X2 = Y )
          | ( member(B,X2,aa(list(B),set(B),set2(B),L))
            & ! [Y3: B] : member(B,X2,aa(list(B),set(B),set2(B),list_update(B,L,I,Y3))) ) ) ) ) ).

% in_set_upd_eq
tff(fact_3991_nth__list__update_H,axiom,
    ! [B: $tType,L: list(B),I: nat,X2: B,J: nat] :
      aa(nat,B,nth(B,list_update(B,L,I,X2)),J) = $ite(
        ( ( I = J )
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L)) ),
        X2,
        aa(nat,B,nth(B,L),J) ) ).

% nth_list_update'
tff(fact_3992_butlast__subset,axiom,
    ! [B: $tType,Xsa: list(B),A4: set(B)] :
      ( ( Xsa != nil(B) )
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),Xsa)),A4)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),butlast(B,Xsa))),A4) ) ) ).

% butlast_subset
tff(fact_3993_butlast__eq__cons__conv,axiom,
    ! [B: $tType,L: list(B),X2: B,Xsa: list(B)] :
      ( ( butlast(B,L) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) )
    <=> ? [Xl: B] : L = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Xl),nil(B)))) ) ).

% butlast_eq_cons_conv
tff(fact_3994_butlast__eq__consE,axiom,
    ! [B: $tType,L: list(B),X2: B,Xsa: list(B)] :
      ( ( butlast(B,L) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa) )
     => ~ ! [Xl2: B] : L != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Xl2),nil(B)))) ) ).

% butlast_eq_consE
tff(fact_3995_butlast__upt,axiom,
    ! [M: nat,N: nat] : butlast(nat,upt(M,N)) = upt(M,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ).

% butlast_upt
tff(fact_3996_map__upd__eq,axiom,
    ! [C: $tType,B: $tType,I: nat,L: list(B),F: fun(B,C),X2: B] :
      ( ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
       => ( aa(B,C,F,aa(nat,B,nth(B,L),I)) = aa(B,C,F,X2) ) )
     => ( aa(list(B),list(C),map(B,C,F),list_update(B,L,I,X2)) = aa(list(B),list(C),map(B,C,F),L) ) ) ).

% map_upd_eq
tff(fact_3997_snoc__eq__iff__butlast_H,axiom,
    ! [B: $tType,Ys: list(B),Xsa: list(B),X2: B] :
      ( ( Ys = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),nil(B))) )
    <=> ( ( Ys != nil(B) )
        & ( butlast(B,Ys) = Xsa )
        & ( last(B,Ys) = X2 ) ) ) ).

% snoc_eq_iff_butlast'
tff(fact_3998_butlast__conv__take,axiom,
    ! [B: $tType,Xsa: list(B)] : butlast(B,Xsa) = take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)),Xsa) ).

% butlast_conv_take
tff(fact_3999_insert__swap__set__eq,axiom,
    ! [B: $tType,I: nat,L: list(B),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
     => ( aa(set(B),set(B),insert2(B,aa(nat,B,nth(B,L),I)),aa(list(B),set(B),set2(B),list_update(B,L,I,X2))) = aa(set(B),set(B),insert2(B,X2),aa(list(B),set(B),set2(B),L)) ) ) ).

% insert_swap_set_eq
tff(fact_4000_rev__update,axiom,
    ! [B: $tType,K: nat,Xsa: list(B),Y: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( rev(B,list_update(B,Xsa,K,Y)) = list_update(B,rev(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),K)),one_one(nat)),Y) ) ) ).

% rev_update
tff(fact_4001_last__list__update,axiom,
    ! [B: $tType,Xsa: list(B),K: nat,X2: B] :
      ( ( Xsa != nil(B) )
     => ( last(B,list_update(B,Xsa,K,X2)) = $ite(K = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)),X2,last(B,Xsa)) ) ) ).

% last_list_update
tff(fact_4002_butlast__take,axiom,
    ! [B: $tType,N: nat,Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( butlast(B,take(B,N,Xsa)) = take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),Xsa) ) ) ).

% butlast_take
tff(fact_4003_listrel1__iff__update,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
    <=> ? [Y3: B,N7: nat] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,nth(B,Xsa),N7)),Y3),R)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N7),aa(list(B),nat,size_size(list(B)),Xsa))
          & ( Ys = list_update(B,Xsa,N7,Y3) ) ) ) ).

% listrel1_iff_update
tff(fact_4004_map__distinct__upd__conv,axiom,
    ! [C: $tType,B: $tType,I: nat,L: list(B),F: fun(B,C),X2: C] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
     => ( distinct(B,L)
       => ( list_update(C,aa(list(B),list(C),map(B,C,F),L),I,X2) = aa(list(B),list(C),map(B,C,fun_upd(B,C,F,aa(nat,B,nth(B,L),I),X2)),L) ) ) ) ).

% map_distinct_upd_conv
tff(fact_4005_foldl__list__update,axiom,
    ! [C: $tType,B: $tType,N: nat,Xsa: list(B),F: fun(C,fun(B,C)),A3: C,X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,F),A3),list_update(B,Xsa,N,X2)) = aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,F),aa(B,C,aa(C,fun(B,C),F,aa(list(B),C,aa(C,fun(list(B),C),foldl(C,B,F),A3),take(B,N,Xsa))),X2)),drop(B,aa(nat,nat,suc,N),Xsa)) ) ) ).

% foldl_list_update
tff(fact_4006_case__natural__def,axiom,
    ! [B: $tType,X: B,Xa3: fun(code_natural,B)] : code_case_natural(B,X,Xa3) = code_rec_natural(B,X,aTP_Lamp_ri(fun(code_natural,B),fun(code_natural,fun(B,B)),Xa3)) ).

% case_natural_def
tff(fact_4007_nth__rotate,axiom,
    ! [B: $tType,N: nat,Xsa: list(B),M: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( aa(nat,B,nth(B,aa(list(B),list(B),rotate(B,M),Xsa)),N) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),aa(list(B),nat,size_size(list(B)),Xsa))) ) ) ).

% nth_rotate
tff(fact_4008_list_Osize__gen_I2_J,axiom,
    ! [B: $tType,X2: fun(B,nat),X21: B,X222: list(B)] : size_list(B,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X21),X222)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,X2,X21)),size_list(B,X2,X222))),aa(nat,nat,suc,zero_zero(nat))) ).

% list.size_gen(2)
tff(fact_4009_rotate1__length01,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat))
     => ( rotate1(B,Xsa) = Xsa ) ) ).

% rotate1_length01
tff(fact_4010_natural_Osimps_I6_J,axiom,
    ! [B: $tType,F1: B,F22: fun(code_natural,fun(B,B))] : aa(code_natural,B,code_rec_natural(B,F1,F22),zero_zero(code_natural)) = F1 ).

% natural.simps(6)
tff(fact_4011_size__list__append,axiom,
    ! [B: $tType,F: fun(B,nat),Xsa: list(B),Ys: list(B)] : size_list(B,F,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),size_list(B,F,Xsa)),size_list(B,F,Ys)) ).

% size_list_append
tff(fact_4012_rotate__length01,axiom,
    ! [B: $tType,Xsa: list(B),N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat))
     => ( aa(list(B),list(B),rotate(B,N),Xsa) = Xsa ) ) ).

% rotate_length01
tff(fact_4013_rotate__rotate,axiom,
    ! [B: $tType,M: nat,N: nat,Xsa: list(B)] : aa(list(B),list(B),rotate(B,M),aa(list(B),list(B),rotate(B,N),Xsa)) = aa(list(B),list(B),rotate(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)),Xsa) ).

% rotate_rotate
tff(fact_4014_rotate__add,axiom,
    ! [B: $tType,M: nat,N: nat] : rotate(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N)) = aa(fun(list(B),list(B)),fun(list(B),list(B)),aa(fun(list(B),list(B)),fun(fun(list(B),list(B)),fun(list(B),list(B))),comp(list(B),list(B),list(B)),rotate(B,M)),rotate(B,N)) ).

% rotate_add
tff(fact_4015_rec__natural__def,axiom,
    ! [B: $tType,X: B,Xa3: fun(code_natural,fun(B,B)),Xb2: code_natural] : aa(code_natural,B,code_rec_natural(B,X,Xa3),Xb2) = the(B,code_rec_set_natural(B,X,Xa3,Xb2)) ).

% rec_natural_def
tff(fact_4016_lenlex__append2,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),Us: list(B),Xsa: list(B),Ys: list(B)] :
      ( irrefl(B,R4)
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us),Xsa)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us),Ys)),lenlex(B,R4))
      <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lenlex(B,R4)) ) ) ).

% lenlex_append2
tff(fact_4017_zipf__zip,axiom,
    ! [B: $tType,C: $tType,L1: list(B),L2: list(C)] :
      ( ( aa(list(B),nat,size_size(list(B)),L1) = aa(list(C),nat,size_size(list(C)),L2) )
     => ( zipf(B,C,product_prod(B,C),product_Pair(B,C),L1,L2) = zip(B,C,L1,L2) ) ) ).

% zipf_zip
tff(fact_4018_map__tailrec__rev_Opelims,axiom,
    ! [C: $tType,B: $tType,X2: fun(C,B),Xa: list(C),Xb: list(B),Y: list(B)] :
      ( ( map_tailrec_rev(C,B,X2,Xa,Xb) = Y )
     => ( aa(product_prod(fun(C,B),product_prod(list(C),list(B))),$o,accp(product_prod(fun(C,B),product_prod(list(C),list(B))),map_tailrec_rev_rel(C,B)),aa(product_prod(list(C),list(B)),product_prod(fun(C,B),product_prod(list(C),list(B))),aa(fun(C,B),fun(product_prod(list(C),list(B)),product_prod(fun(C,B),product_prod(list(C),list(B)))),product_Pair(fun(C,B),product_prod(list(C),list(B))),X2),aa(list(B),product_prod(list(C),list(B)),aa(list(C),fun(list(B),product_prod(list(C),list(B))),product_Pair(list(C),list(B)),Xa),Xb)))
       => ( ( ( Xa = nil(C) )
           => ( ( Y = Xb )
             => ~ aa(product_prod(fun(C,B),product_prod(list(C),list(B))),$o,accp(product_prod(fun(C,B),product_prod(list(C),list(B))),map_tailrec_rev_rel(C,B)),aa(product_prod(list(C),list(B)),product_prod(fun(C,B),product_prod(list(C),list(B))),aa(fun(C,B),fun(product_prod(list(C),list(B)),product_prod(fun(C,B),product_prod(list(C),list(B)))),product_Pair(fun(C,B),product_prod(list(C),list(B))),X2),aa(list(B),product_prod(list(C),list(B)),aa(list(C),fun(list(B),product_prod(list(C),list(B))),product_Pair(list(C),list(B)),nil(C)),Xb))) ) )
         => ~ ! [A5: C,As: list(C)] :
                ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
               => ( ( Y = map_tailrec_rev(C,B,X2,As,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(C,B,X2,A5)),Xb)) )
                 => ~ aa(product_prod(fun(C,B),product_prod(list(C),list(B))),$o,accp(product_prod(fun(C,B),product_prod(list(C),list(B))),map_tailrec_rev_rel(C,B)),aa(product_prod(list(C),list(B)),product_prod(fun(C,B),product_prod(list(C),list(B))),aa(fun(C,B),fun(product_prod(list(C),list(B)),product_prod(fun(C,B),product_prod(list(C),list(B)))),product_Pair(fun(C,B),product_prod(list(C),list(B))),X2),aa(list(B),product_prod(list(C),list(B)),aa(list(C),fun(list(B),product_prod(list(C),list(B))),product_Pair(list(C),list(B)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As)),Xb))) ) ) ) ) ) ).

% map_tailrec_rev.pelims
tff(fact_4019_lexord__same__pref__if__irrefl,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),Xsa: list(B),Ys: list(B),Zs: list(B)] :
      ( irrefl(B,R)
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Zs)),lexord(B,R))
      <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),lexord(B,R)) ) ) ).

% lexord_same_pref_if_irrefl
tff(fact_4020_irreflI,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( ! [A5: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),A5),R4)
     => irrefl(B,R4) ) ).

% irreflI
tff(fact_4021_irrefl__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( irrefl(B,R)
    <=> ! [A7: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),A7),R) ) ).

% irrefl_def
tff(fact_4022_zipf_Osimps_I2_J,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,fun(D,B)),A3: C,As2: list(C),B2: D,Bs2: list(D)] : zipf(C,D,B,F,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),Bs2)) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(D,B,aa(C,fun(D,B),F,A3),B2)),zipf(C,D,B,F,As2,Bs2)) ).

% zipf.simps(2)
tff(fact_4023_zipf_Osimps_I1_J,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(C,fun(D,B))] : zipf(C,D,B,F,nil(C),nil(D)) = nil(B) ).

% zipf.simps(1)
tff(fact_4024_lexl__not__refl,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: list(B)] :
      ( irrefl(B,R)
     => ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),X2),lex(B,R)) ) ).

% lexl_not_refl
tff(fact_4025_zipf_Oelims,axiom,
    ! [D: $tType,C: $tType,B: $tType,X2: fun(C,fun(D,B)),Xa: list(C),Xb: list(D),Y: list(B)] :
      ( ( zipf(C,D,B,X2,Xa,Xb) = Y )
     => ( ( ( Xa = nil(C) )
         => ( ( Xb = nil(D) )
           => ( Y != nil(B) ) ) )
       => ( ! [A5: C,As: list(C)] :
              ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),A5),As) )
             => ! [B3: D,Bs: list(D)] :
                  ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B3),Bs) )
                 => ( Y != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(D,B,aa(C,fun(D,B),X2,A5),B3)),zipf(C,D,B,X2,As,Bs)) ) ) )
         => ( ( ? [V4: C,Va: list(C)] : Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va)
             => ( ( Xb = nil(D) )
               => ( Y != undefined(list(B)) ) ) )
           => ~ ( ( Xa = nil(C) )
               => ( ? [V4: D,Va: list(D)] : Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V4),Va)
                 => ( Y != undefined(list(B)) ) ) ) ) ) ) ) ).

% zipf.elims
tff(fact_4026_zipf_Opelims,axiom,
    ! [B: $tType,C: $tType,D: $tType,X2: fun(C,fun(D,B)),Xa: list(C),Xb: list(D),Y: list(B)] :
      ( ( zipf(C,D,B,X2,Xa,Xb) = Y )
     => ( aa(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),$o,accp(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),zipf_rel(C,D,B)),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),aa(fun(C,fun(D,B)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,B)),product_prod(list(C),list(D))),X2),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 = nil(B) )
               => ~ aa(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),$o,accp(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),zipf_rel(C,D,B)),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),aa(fun(C,fun(D,B)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,B)),product_prod(list(C),list(D))),X2),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) )
               => ! [B3: D,Bs: list(D)] :
                    ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),B3),Bs) )
                   => ( ( Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(D,B,aa(C,fun(D,B),X2,A5),B3)),zipf(C,D,B,X2,As,Bs)) )
                     => ~ aa(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),$o,accp(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),zipf_rel(C,D,B)),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),aa(fun(C,fun(D,B)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,B)),product_prod(list(C),list(D))),X2),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),B3),Bs)))) ) ) )
           => ( ! [V4: C,Va: list(C)] :
                  ( ( Xa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va) )
                 => ( ( Xb = nil(D) )
                   => ( ( Y = undefined(list(B)) )
                     => ~ aa(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),$o,accp(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),zipf_rel(C,D,B)),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),aa(fun(C,fun(D,B)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,B)),product_prod(list(C),list(D))),X2),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),V4),Va)),nil(D)))) ) ) )
             => ~ ( ( Xa = nil(C) )
                 => ! [V4: D,Va: list(D)] :
                      ( ( Xb = aa(list(D),list(D),aa(D,fun(list(D),list(D)),cons(D),V4),Va) )
                     => ( ( Y = undefined(list(B)) )
                       => ~ aa(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),$o,accp(product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),zipf_rel(C,D,B)),aa(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D))),aa(fun(C,fun(D,B)),fun(product_prod(list(C),list(D)),product_prod(fun(C,fun(D,B)),product_prod(list(C),list(D)))),product_Pair(fun(C,fun(D,B)),product_prod(list(C),list(D))),X2),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),V4),Va)))) ) ) ) ) ) ) ) ) ).

% zipf.pelims
tff(fact_4027_count__list_Osimps_I2_J,axiom,
    ! [B: $tType,X2: B,Xsa: list(B),Y: B] :
      count_list(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa),Y) = $ite(X2 = Y,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),count_list(B,Xsa,Y)),one_one(nat)),count_list(B,Xsa,Y)) ).

% count_list.simps(2)
tff(fact_4028_effect__makeE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,F: fun(nat,B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: array(B),N2: nat] :
          ( heap_Time_effect(array(B),array_make(B,N,F),Ha,H2,R,N2)
         => ~ ( ( R = aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,aa(list(nat),list(B),map(nat,B,F),upt(zero_zero(nat),N)),Ha)) )
             => ( ( H2 = aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,aa(list(nat),list(B),map(nat,B,F),upt(zero_zero(nat),N)),Ha)) )
               => ( ( array_get(B,H2,R) = aa(list(nat),list(B),map(nat,B,F),upt(zero_zero(nat),N)) )
                 => ( aa(array(B),$o,array_present(B,H2),R)
                   => ( ~ aa(array(B),$o,array_present(B,Ha),R)
                     => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)) != N2 ) ) ) ) ) ) ) ) ).

% effect_makeE
tff(fact_4029_listrel__iff__nth,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xsa),Ys),listrel(B,C,R))
    <=> ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
        & ! [N7: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N7),aa(list(B),nat,size_size(list(B)),Xsa))
           => member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(nat,B,nth(B,Xsa),N7)),aa(nat,C,nth(C,Ys),N7)),R) ) ) ) ).

% listrel_iff_nth
tff(fact_4030_listrel__rtrancl__refl,axiom,
    ! [B: $tType,Xsa: list(B),R: set(product_prod(B,B))] : member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Xsa),listrel(B,B,transitive_rtrancl(B,R))) ).

% listrel_rtrancl_refl
tff(fact_4031_Array__Time_Oget__alloc,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit),Ys: list(B)] : array_get(B,aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha)),aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,Ys,Ha))) = Xsa ) ).

% Array_Time.get_alloc
tff(fact_4032_Array__Time_Opresent__alloc,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit)] : aa(array(B),$o,array_present(B,aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha))),aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha))) ) ).

% Array_Time.present_alloc
tff(fact_4033_Array__Time_Onot__present__alloc,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),Xsa: list(B)] : ~ aa(array(B),$o,array_present(B,Ha),aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha))) ) ).

% Array_Time.not_present_alloc
tff(fact_4034_listrel_ONil,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C))] : member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),nil(C)),listrel(B,C,R)) ).

% listrel.Nil
tff(fact_4035_listrel__Nil1,axiom,
    ! [B: $tType,C: $tType,Xsa: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),Xsa),listrel(B,C,R))
     => ( Xsa = nil(C) ) ) ).

% listrel_Nil1
tff(fact_4036_listrel__Nil2,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xsa),nil(C)),listrel(B,C,R))
     => ( Xsa = nil(B) ) ) ).

% listrel_Nil2
tff(fact_4037_listrel__eq__len,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xsa),Ys),listrel(B,C,R))
     => ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) ) ) ).

% listrel_eq_len
tff(fact_4038_listrel__rtrancl__trans,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B)),Zs: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel(B,B,transitive_rtrancl(B,R)))
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Ys),Zs),listrel(B,B,transitive_rtrancl(B,R)))
       => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Zs),listrel(B,B,transitive_rtrancl(B,R))) ) ) ).

% listrel_rtrancl_trans
tff(fact_4039_listrel_OCons,axiom,
    ! [C: $tType,B: $tType,X2: B,Y: C,R: set(product_prod(B,C)),Xsa: list(B),Ys: list(C)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),R)
     => ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xsa),Ys),listrel(B,C,R))
       => member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),listrel(B,C,R)) ) ) ).

% listrel.Cons
tff(fact_4040_listrel__Cons1,axiom,
    ! [C: $tType,B: $tType,Y: B,Ys: list(B),Xsa: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y),Ys)),Xsa),listrel(B,C,R))
     => ~ ! [Y4: C,Ys2: list(C)] :
            ( ( Xsa = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),Ys2) )
           => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y),Y4),R)
             => ~ member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Ys),Ys2),listrel(B,C,R)) ) ) ) ).

% listrel_Cons1
tff(fact_4041_listrel__Cons2,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Y: C,Ys: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xsa),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),Ys)),listrel(B,C,R))
     => ~ ! [X3: B,Xs: list(B)] :
            ( ( Xsa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
           => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y),R)
             => ~ member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xs),Ys),listrel(B,C,R)) ) ) ) ).

% listrel_Cons2
tff(fact_4042_listrel__reflcl__if__listrel1,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel1(B,R))
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel(B,B,transitive_rtrancl(B,R))) ) ).

% listrel_reflcl_if_listrel1
tff(fact_4043_rtrancl__listrel1__if__listrel,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),listrel(B,B,R))
     => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),transitive_rtrancl(list(B),listrel1(B,R))) ) ).

% rtrancl_listrel1_if_listrel
tff(fact_4044_effect__of__listE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: array(B),N2: nat] :
          ( heap_Time_effect(array(B),array_of_list(B,Xsa),Ha,H2,R,N2)
         => ~ ( ( R = aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha)) )
             => ( ( H2 = aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha)) )
               => ( ( array_get(B,H2,R) = Xsa )
                 => ( aa(array(B),$o,array_present(B,H2),R)
                   => ( ~ aa(array(B),$o,array_present(B,Ha),R)
                     => ( N2 != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),aa(list(B),nat,size_size(list(B)),Xsa)) ) ) ) ) ) ) ) ) ).

% effect_of_listE
tff(fact_4045_effect__newE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: array(B),N2: nat] :
          ( heap_Time_effect(array(B),aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2),Ha,H2,R,N2)
         => ~ ( ( R = aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,replicate(B,N,X2),Ha)) )
             => ( ( H2 = aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,replicate(B,N,X2),Ha)) )
               => ( ( array_get(B,H2,R) = replicate(B,N,X2) )
                 => ( aa(array(B),$o,array_present(B,H2),R)
                   => ( ~ aa(array(B),$o,array_present(B,Ha),R)
                     => ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)) != N2 ) ) ) ) ) ) ) ) ).

% effect_newE
tff(fact_4046_listrel_Ocases,axiom,
    ! [C: $tType,B: $tType,A1: list(B),A22: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),A1),A22),listrel(B,C,R))
     => ( ( ( A1 = nil(B) )
         => ( A22 != nil(C) ) )
       => ~ ! [X3: B,Y4: C,Xs: list(B)] :
              ( ( A1 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
             => ! [Ys2: list(C)] :
                  ( ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y4),Ys2) )
                 => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4),R)
                   => ~ member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xs),Ys2),listrel(B,C,R)) ) ) ) ) ) ).

% listrel.cases
tff(fact_4047_listrel_Osimps,axiom,
    ! [C: $tType,B: $tType,A1: list(B),A22: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),A1),A22),listrel(B,C,R))
    <=> ( ( ( A1 = nil(B) )
          & ( A22 = nil(C) ) )
        | ? [X4: B,Y3: C,Xs4: list(B),Ys4: list(C)] :
            ( ( A1 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X4),Xs4) )
            & ( A22 = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y3),Ys4) )
            & member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Y3),R)
            & member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xs4),Ys4),listrel(B,C,R)) ) ) ) ).

% listrel.simps
tff(fact_4048_listrel__iff__zip,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C),R: set(product_prod(B,C))] :
      ( member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xsa),Ys),listrel(B,C,R))
    <=> ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
        & ! [X4: product_prod(B,C)] :
            ( member(product_prod(B,C),X4,aa(list(product_prod(B,C)),set(product_prod(B,C)),set2(product_prod(B,C)),zip(B,C,Xsa,Ys)))
           => aa(product_prod(B,C),$o,aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R)),X4) ) ) ) ).

% listrel_iff_zip
tff(fact_4049_present__alloc__noteq,axiom,
    ! [B: $tType,C: $tType] :
      ( ( heap(C)
        & heap(B) )
     => ! [Ha: heap_ext(product_unit),A3: array(B),Xsa: list(C)] :
          ( aa(array(B),$o,array_present(B,Ha),A3)
         => array_noteq(B,C,A3,aa(product_prod(array(C),heap_ext(product_unit)),array(C),product_fst(array(C),heap_ext(product_unit)),array_alloc(C,Xsa,Ha))) ) ) ).

% present_alloc_noteq
tff(fact_4050_listrel__def,axiom,
    ! [C: $tType,B: $tType,X: set(product_prod(B,C))] : listrel(B,C,X) = aa(fun(product_prod(list(B),list(C)),$o),set(product_prod(list(B),list(C))),collect(product_prod(list(B),list(C))),aa(fun(list(B),fun(list(C),$o)),fun(product_prod(list(B),list(C)),$o),product_case_prod(list(B),list(C),$o),listrelp(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),X)))) ).

% listrel_def
tff(fact_4051_set,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ls: list(B),Ha: heap_ext(product_unit),New_ls: list(B)] : aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,Ls,Ha)),New_ls),aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,Ls,Ha))) = aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,New_ls,Ha)) ) ).

% set
tff(fact_4052_Array__Time_Oset__same,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: array(B),X2: list(B),Y: list(B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,X2),aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,Y),Ha)) = aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,X2),Ha) ) ).

% Array_Time.set_same
tff(fact_4053_Array__Time_Ounequal,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),A6: array(B)] :
          ( ( A3 != A6 )
        <=> array_noteq(B,B,A3,A6) ) ) ).

% Array_Time.unequal
tff(fact_4054_Array__Time_Oget__set__eq,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: array(B),X2: list(B),Ha: heap_ext(product_unit)] : array_get(B,aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,X2),Ha),R) = X2 ) ).

% Array_Time.get_set_eq
tff(fact_4055_Array__Time_Oget__set__neq,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [R: array(B),S: array(C),X2: list(C),Ha: heap_ext(product_unit)] :
          ( array_noteq(B,C,R,S)
         => ( array_get(B,aa(heap_ext(product_unit),heap_ext(product_unit),array_set(C,S,X2),Ha),R) = array_get(B,Ha,R) ) ) ) ).

% Array_Time.get_set_neq
tff(fact_4056_Array__Time_Oset__set__swap,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [R: array(B),R3: array(C),X2: list(B),X6: list(C),Ha: heap_ext(product_unit)] :
          ( array_noteq(B,C,R,R3)
         => ( aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,X2),aa(heap_ext(product_unit),heap_ext(product_unit),array_set(C,R3,X6),Ha)) = aa(heap_ext(product_unit),heap_ext(product_unit),array_set(C,R3,X6),aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,X2),Ha)) ) ) ) ).

% Array_Time.set_set_swap
tff(fact_4057_Array__Time_Onoteq__irrefl,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: array(B)] : ~ array_noteq(B,B,R,R) ) ).

% Array_Time.noteq_irrefl
tff(fact_4058_Array__Time_Onoteq__sym,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [A3: array(B),B2: array(C)] :
          ( array_noteq(B,C,A3,B2)
         => array_noteq(C,B,B2,A3) ) ) ).

% Array_Time.noteq_sym
tff(fact_4059_Field__not__elem,axiom,
    ! [B: $tType,V: B,R4: set(product_prod(B,B))] :
      ( ~ member(B,V,field2(B,R4))
     => ! [X: product_prod(B,B)] :
          ( member(product_prod(B,B),X,R4)
         => aa(product_prod(B,B),$o,aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aTP_Lamp_rj(B,fun(B,fun(B,$o)),V)),X) ) ) ).

% Field_not_elem
tff(fact_4060_refl__on__def_H,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( refl_on(B,A4,R)
    <=> ( ! [X4: product_prod(B,B)] :
            ( member(product_prod(B,B),X4,R)
           => aa(product_prod(B,B),$o,aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aTP_Lamp_rk(set(B),fun(B,fun(B,$o)),A4)),X4) )
        & ! [X4: B] :
            ( member(B,X4,A4)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),X4),R) ) ) ) ).

% refl_on_def'
tff(fact_4061_listrelp__listrel__eq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C)),X: list(B),Xa3: list(C)] :
      ( aa(list(C),$o,aa(list(B),fun(list(C),$o),listrelp(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R)),X),Xa3)
    <=> member(product_prod(list(B),list(C)),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),X),Xa3),listrel(B,C,R)) ) ).

% listrelp_listrel_eq
tff(fact_4062_Under__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B)] : order_Under(B,R,A4) = aa(fun(B,$o),set(B),collect(B),aa(set(B),fun(B,$o),aTP_Lamp_rl(set(product_prod(B,B)),fun(set(B),fun(B,$o)),R),A4)) ).

% Under_def
tff(fact_4063_UnderS__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B)] : order_UnderS(B,R,A4) = aa(fun(B,$o),set(B),collect(B),aa(set(B),fun(B,$o),aTP_Lamp_rm(set(product_prod(B,B)),fun(set(B),fun(B,$o)),R),A4)) ).

% UnderS_def
tff(fact_4064_sorted__wrt_Opelims_I2_J,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B)] :
      ( sorted_wrt(B,X2,Xa)
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ( ( ( Xa = nil(B) )
           => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),nil(B))) )
         => ~ ! [X3: B,Ys2: list(B)] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2) )
               => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2)))
                 => ~ ( ! [Xa3: B] :
                          ( member(B,Xa3,aa(list(B),set(B),set2(B),Ys2))
                         => aa(B,$o,aa(B,fun(B,$o),X2,X3),Xa3) )
                      & sorted_wrt(B,X2,Ys2) ) ) ) ) ) ) ).

% sorted_wrt.pelims(2)
tff(fact_4065_sorted__wrt_Opelims_I1_J,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Y: $o] :
      ( ( sorted_wrt(B,X2,Xa)
      <=> (Y) )
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ( ( ( Xa = nil(B) )
           => ( (Y)
             => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),nil(B))) ) )
         => ~ ! [X3: B,Ys2: list(B)] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2) )
               => ( ( (Y)
                  <=> ( ! [Xa2: B] :
                          ( member(B,Xa2,aa(list(B),set(B),set2(B),Ys2))
                         => aa(B,$o,aa(B,fun(B,$o),X2,X3),Xa2) )
                      & sorted_wrt(B,X2,Ys2) ) )
                 => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2))) ) ) ) ) ) ).

% sorted_wrt.pelims(1)
tff(fact_4066_sorted__wrt_Opelims_I3_J,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B)] :
      ( ~ sorted_wrt(B,X2,Xa)
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ~ ! [X3: B,Ys2: list(B)] :
              ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2) )
             => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),sorted_wrt_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ys2)))
               => ( ! [Xa4: B] :
                      ( member(B,Xa4,aa(list(B),set(B),set2(B),Ys2))
                     => aa(B,$o,aa(B,fun(B,$o),X2,X3),Xa4) )
                  & sorted_wrt(B,X2,Ys2) ) ) ) ) ) ).

% sorted_wrt.pelims(3)
tff(fact_4067_Above__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B)] : order_Above(B,R,A4) = aa(fun(B,$o),set(B),collect(B),aa(set(B),fun(B,$o),aTP_Lamp_rn(set(product_prod(B,B)),fun(set(B),fun(B,$o)),R),A4)) ).

% Above_def
tff(fact_4068_execute__nth_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),aa(nat,heap_Time_Heap(B),array_nth(B,A3),I)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(nat,B,nth(B,array_get(B,Ha,A3)),I)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),one_one(nat)))) ) ) ) ).

% execute_nth(1)
tff(fact_4069_Array__Time_Olength__alloc,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit),Ys: list(B)] : aa(array(B),nat,array_length(B,aa(product_prod(array(B),heap_ext(product_unit)),heap_ext(product_unit),product_snd(array(B),heap_ext(product_unit)),array_alloc(B,Xsa,Ha))),aa(product_prod(array(B),heap_ext(product_unit)),array(B),product_fst(array(B),heap_ext(product_unit)),array_alloc(B,Ys,Ha))) = aa(list(B),nat,size_size(list(B)),Xsa) ) ).

% Array_Time.length_alloc
tff(fact_4070_Array__Time_Onth__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),I: nat] : aa(nat,heap_Time_Heap(B),array_nth(B,A3),I) = heap_Time_guard(B,aa(nat,fun(heap_ext(product_unit),$o),aTP_Lamp_ro(array(B),fun(nat,fun(heap_ext(product_unit),$o)),A3),I),aa(nat,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_rp(array(B),fun(nat,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))),A3),I)) ) ).

% Array_Time.nth_def
tff(fact_4071_success__nthI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => heap_Time_success(B,aa(nat,heap_Time_Heap(B),array_nth(B,A3),I),Ha) ) ) ).

% success_nthI
tff(fact_4072_fails__array__nth,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [P3: array(B),I: nat,Ha: heap_ext(product_unit)] :
          ( time_fails(B,aa(nat,heap_Time_Heap(B),array_nth(B,P3),I),Ha)
        <=> ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),P3)) ) ) ).

% fails_array_nth
tff(fact_4073_execute__nth_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B),I: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(array(B),nat,array_length(B,Ha),A3)),I)
         => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),aa(nat,heap_Time_Heap(B),array_nth(B,A3),I)),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ) ).

% execute_nth(2)
tff(fact_4074_length__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B)] : aa(array(B),nat,array_length(B,Ha),A3) = aa(list(B),nat,size_size(list(B)),array_get(B,Ha,A3)) ) ).

% length_def
tff(fact_4075_effect__nthE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),I: nat,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
          ( heap_Time_effect(B,aa(nat,heap_Time_Heap(B),array_nth(B,A3),I),Ha,H2,R,N)
         => ~ ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
             => ( ( R = aa(nat,B,nth(B,array_get(B,Ha,A3)),I) )
               => ( ( H2 = Ha )
                 => ( N != one_one(nat) ) ) ) ) ) ) ).

% effect_nthE
tff(fact_4076_effect__nthI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),H2: heap_ext(product_unit),R: B,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( ( H2 = Ha )
           => ( ( R = aa(nat,B,nth(B,array_get(B,Ha,A3)),I) )
             => ( ( N = one_one(nat) )
               => heap_Time_effect(B,aa(nat,heap_Time_Heap(B),array_nth(B,A3),I),Ha,H2,R,N) ) ) ) ) ) ).

% effect_nthI
tff(fact_4077_nth_H__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B)] : array_nth2(B,A3) = aa(fun(code_integer,nat),fun(code_integer,heap_Time_Heap(B)),aa(fun(nat,heap_Time_Heap(B)),fun(fun(code_integer,nat),fun(code_integer,heap_Time_Heap(B))),comp(nat,heap_Time_Heap(B),code_integer),array_nth(B,A3)),code_nat_of_integer) ) ).

% nth'_def
tff(fact_4078_freeze__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B)] : array_freeze(B,A3) = heap_Time_heap(list(B),aTP_Lamp_rq(array(B),fun(heap_ext(product_unit),product_prod(list(B),product_prod(heap_ext(product_unit),nat))),A3)) ) ).

% freeze_def
tff(fact_4079_execute__map__entry_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B),I: nat,F: fun(B,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(array(B),nat,array_length(B,Ha),A3)),I)
         => ( aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),array_map_entry(B,I,F,A3)),Ha) = none(product_prod(array(B),product_prod(heap_ext(product_unit),nat))) ) ) ) ).

% execute_map_entry(2)
tff(fact_4080_execute__freeze,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(list(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(list(B)),fun(heap_ext(product_unit),option(product_prod(list(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(list(B)),array_freeze(B,A3)),Ha) = aa(product_prod(list(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(list(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(list(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(list(B),product_prod(heap_ext(product_unit),nat)),aa(list(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(list(B),product_prod(heap_ext(product_unit),nat))),product_Pair(list(B),product_prod(heap_ext(product_unit),nat)),array_get(B,Ha,A3)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),aa(array(B),nat,array_length(B,Ha),A3))))) ) ).

% execute_freeze
tff(fact_4081_success__freezeI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),Ha: heap_ext(product_unit)] : heap_Time_success(list(B),array_freeze(B,A3),Ha) ) ).

% success_freezeI
tff(fact_4082_success__map__entryI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),F: fun(B,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => heap_Time_success(array(B),array_map_entry(B,I,F,A3),Ha) ) ) ).

% success_map_entryI
tff(fact_4083_effect__freezeE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: list(B),N: nat] :
          ( heap_Time_effect(list(B),array_freeze(B,A3),Ha,H2,R,N)
         => ~ ( ( H2 = Ha )
             => ( ( R = array_get(B,Ha,A3) )
               => ( N != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(array(B),nat,array_length(B,Ha),A3)),one_one(nat)) ) ) ) ) ) ).

% effect_freezeE
tff(fact_4084_effect__freezeI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [H2: heap_ext(product_unit),Ha: heap_ext(product_unit),R: list(B),A3: array(B),N: nat] :
          ( ( H2 = Ha )
         => ( ( R = array_get(B,Ha,A3) )
           => ( ( N = aa(array(B),nat,array_length(B,Ha),A3) )
             => heap_Time_effect(list(B),array_freeze(B,A3),Ha,H2,R,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat))) ) ) ) ) ).

% effect_freezeI
tff(fact_4085_execute__map__entry_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),F: fun(B,B)] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),array_map_entry(B,I,F,A3)),Ha) = aa(product_prod(array(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_Pair(array(B),product_prod(heap_ext(product_unit),nat)),A3),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),array_update(B,A3,I,aa(B,B,F,aa(nat,B,nth(B,array_get(B,Ha,A3)),I)),Ha)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))) ) ) ) ).

% execute_map_entry(1)
tff(fact_4086_map__entry__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,F: fun(B,B),A3: array(B)] : array_map_entry(B,I,F,A3) = heap_Time_guard(array(B),aa(array(B),fun(heap_ext(product_unit),$o),aTP_Lamp_rr(nat,fun(array(B),fun(heap_ext(product_unit),$o)),I),A3),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(fun(B,B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_rs(nat,fun(fun(B,B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))))),I),F),A3)) ) ).

% map_entry_def
tff(fact_4087_effect__map__entryI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),H2: heap_ext(product_unit),F: fun(B,B),R: array(B),N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( ( H2 = array_update(B,A3,I,aa(B,B,F,aa(nat,B,nth(B,array_get(B,Ha,A3)),I)),Ha) )
           => ( ( R = A3 )
             => ( ( N = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) )
               => heap_Time_effect(array(B),array_map_entry(B,I,F,A3),Ha,H2,R,N) ) ) ) ) ) ).

% effect_map_entryI
tff(fact_4088_effect__map__entryE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,F: fun(B,B),A3: array(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: array(B),N: nat] :
          ( heap_Time_effect(array(B),array_map_entry(B,I,F,A3),Ha,H2,R,N)
         => ~ ( ( R = A3 )
             => ( ( H2 = array_update(B,A3,I,aa(B,B,F,aa(nat,B,nth(B,array_get(B,Ha,A3)),I)),Ha) )
               => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
                 => ( N != aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) ) ) ) ) ) ) ).

% effect_map_entryE
tff(fact_4089_length__update,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [B2: array(C),I: nat,V: C,Ha: heap_ext(product_unit)] : array_length(B,array_update(C,B2,I,V,Ha)) = array_length(B,Ha) ) ).

% length_update
tff(fact_4090_Array__Time_Opresent__update,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [B2: array(C),I: nat,V: C,Ha: heap_ext(product_unit)] : array_present(B,array_update(C,B2,I,V,Ha)) = array_present(B,Ha) ) ).

% Array_Time.present_update
tff(fact_4091_get__update__elem__neqIndex,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,J: nat,A3: array(B),V: B,Ha: heap_ext(product_unit)] :
          ( ( I != J )
         => ( aa(nat,B,nth(B,array_get(B,array_update(B,A3,J,V,Ha),A3)),I) = aa(nat,B,nth(B,array_get(B,Ha,A3)),I) ) ) ) ).

% get_update_elem_neqIndex
tff(fact_4092_get__update__eq,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),I: nat,V: B,Ha: heap_ext(product_unit)] : array_get(B,array_update(B,A3,I,V,Ha),A3) = list_update(B,array_get(B,Ha,A3),I,V) ) ).

% get_update_eq
tff(fact_4093_nth__update__neq,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [A3: array(B),B2: array(C),J: nat,V: C,Ha: heap_ext(product_unit),I: nat] :
          ( array_noteq(B,C,A3,B2)
         => ( aa(nat,B,nth(B,array_get(B,array_update(C,B2,J,V,Ha),A3)),I) = aa(nat,B,nth(B,array_get(B,Ha,A3)),I) ) ) ) ).

% nth_update_neq
tff(fact_4094_update__swap__neqIndex,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,I6: nat,A3: array(B),V: B,V6: B,Ha: heap_ext(product_unit)] :
          ( ( I != I6 )
         => ( array_update(B,A3,I,V,array_update(B,A3,I6,V6,Ha)) = array_update(B,A3,I6,V6,array_update(B,A3,I,V,Ha)) ) ) ) ).

% update_swap_neqIndex
tff(fact_4095_update__swap__neq,axiom,
    ! [C: $tType,B: $tType] :
      ( ( heap(B)
        & heap(C) )
     => ! [A3: array(B),A6: array(C),I: nat,V: B,I6: nat,V6: C,Ha: heap_ext(product_unit)] :
          ( array_noteq(B,C,A3,A6)
         => ( array_update(B,A3,I,V,array_update(C,A6,I6,V6,Ha)) = array_update(C,A6,I6,V6,array_update(B,A3,I,V,Ha)) ) ) ) ).

% update_swap_neq
tff(fact_4096_Array__Time_Oupdate__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),I: nat,X2: B,Ha: heap_ext(product_unit)] : array_update(B,A3,I,X2,Ha) = aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,A3,list_update(B,array_get(B,Ha,A3),I,X2)),Ha) ) ).

% Array_Time.update_def
tff(fact_4097_execute__swap_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),array_swap(B,I,X2,A3)),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(nat,B,nth(B,array_get(B,Ha,A3)),I)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),array_update(B,A3,I,X2,Ha)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))))) ) ) ) ).

% execute_swap(1)
tff(fact_4098_swap__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,X2: B,A3: array(B)] : array_swap(B,I,X2,A3) = heap_Time_guard(B,aa(array(B),fun(heap_ext(product_unit),$o),aTP_Lamp_rr(nat,fun(array(B),fun(heap_ext(product_unit),$o)),I),A3),aa(array(B),fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(B,fun(array(B),fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_rt(nat,fun(B,fun(array(B),fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))))),I),X2),A3)) ) ).

% swap_def
tff(fact_4099_effect__swapI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),H2: heap_ext(product_unit),X2: B,R: B,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( ( H2 = array_update(B,A3,I,X2,Ha) )
           => ( ( R = aa(nat,B,nth(B,array_get(B,Ha,A3)),I) )
             => ( ( N = aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) )
               => heap_Time_effect(B,array_swap(B,I,X2,A3),Ha,H2,R,N) ) ) ) ) ) ).

% effect_swapI
tff(fact_4100_effect__swapE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,X2: B,A3: array(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: B,N: nat] :
          ( heap_Time_effect(B,array_swap(B,I,X2,A3),Ha,H2,R,N)
         => ~ ( ( R = aa(nat,B,nth(B,array_get(B,Ha,A3)),I) )
             => ( ( H2 = array_update(B,A3,I,X2,Ha) )
               => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
                 => ( N != aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)) ) ) ) ) ) ) ).

% effect_swapE
tff(fact_4101_success__swapI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => heap_Time_success(B,array_swap(B,I,X2,A3),Ha) ) ) ).

% success_swapI
tff(fact_4102_execute__swap_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B),I: nat,X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(array(B),nat,array_length(B,Ha),A3)),I)
         => ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),array_swap(B,I,X2,A3)),Ha) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ) ) ) ).

% execute_swap(2)
tff(fact_4103_execute__upd_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),array_upd(B,I,X2,A3)),Ha) = aa(product_prod(array(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_Pair(array(B),product_prod(heap_ext(product_unit),nat)),A3),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),array_update(B,A3,I,X2,Ha)),one_one(nat)))) ) ) ) ).

% execute_upd(1)
tff(fact_4104_upd__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,X2: B,A3: array(B)] : array_upd(B,I,X2,A3) = heap_Time_guard(array(B),aa(array(B),fun(heap_ext(product_unit),$o),aTP_Lamp_rr(nat,fun(array(B),fun(heap_ext(product_unit),$o)),I),A3),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(B,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_ru(nat,fun(B,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))))),I),X2),A3)) ) ).

% upd_def
tff(fact_4105_execute__upd_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B),I: nat,X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(array(B),nat,array_length(B,Ha),A3)),I)
         => ( aa(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(B)),fun(heap_ext(product_unit),option(product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(B)),array_upd(B,I,X2,A3)),Ha) = none(product_prod(array(B),product_prod(heap_ext(product_unit),nat))) ) ) ) ).

% execute_upd(2)
tff(fact_4106_effect__updI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),H2: heap_ext(product_unit),V: B,N: nat] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => ( ( H2 = array_update(B,A3,I,V,Ha) )
           => ( ( N = one_one(nat) )
             => heap_Time_effect(array(B),array_upd(B,I,V,A3),Ha,H2,A3,N) ) ) ) ) ).

% effect_updI
tff(fact_4107_upd__ureturn,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,X2: B,A3: array(B)] : heap_Time_bind(array(B),array(B),array_upd(B,I,X2,A3),aTP_Lamp_rv(array(B),fun(array(B),heap_Time_Heap(array(B))),A3)) = array_upd(B,I,X2,A3) ) ).

% upd_ureturn
tff(fact_4108_success__updI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,Ha: heap_ext(product_unit),A3: array(B),X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
         => heap_Time_success(array(B),array_upd(B,I,X2,A3),Ha) ) ) ).

% success_updI
tff(fact_4109_fails__array__upd,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,X2: B,P3: array(B),Ha: heap_ext(product_unit)] :
          ( time_fails(array(B),array_upd(B,I,X2,P3),Ha)
        <=> ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),P3)) ) ) ).

% fails_array_upd
tff(fact_4110_effect__updE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [I: nat,V: B,A3: array(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: array(B),N: nat] :
          ( heap_Time_effect(array(B),array_upd(B,I,V,A3),Ha,H2,R,N)
         => ~ ( ( R = A3 )
             => ( ( H2 = array_update(B,A3,I,V,Ha) )
               => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(array(B),nat,array_length(B,Ha),A3))
                 => ( N != one_one(nat) ) ) ) ) ) ) ).

% effect_updE
tff(fact_4111_upd_H__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),I: code_integer,X2: B] : array_upd2(B,A3,I,X2) = heap_Time_bind(array(B),product_unit,array_upd(B,aa(code_integer,nat,code_nat_of_integer,I),X2,A3),aTP_Lamp_rw(array(B),heap_Time_Heap(product_unit))) ) ).

% upd'_def
tff(fact_4112_execute__len,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(nat,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(nat),fun(heap_ext(product_unit),option(product_prod(nat,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(nat),array_len(B,A3)),Ha) = aa(product_prod(nat,product_prod(heap_ext(product_unit),nat)),option(product_prod(nat,product_prod(heap_ext(product_unit),nat))),some(product_prod(nat,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(nat,product_prod(heap_ext(product_unit),nat)),aa(nat,fun(product_prod(heap_ext(product_unit),nat),product_prod(nat,product_prod(heap_ext(product_unit),nat))),product_Pair(nat,product_prod(heap_ext(product_unit),nat)),aa(array(B),nat,array_length(B,Ha),A3)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Ha),one_one(nat)))) ) ).

% execute_len
tff(fact_4113_in__measures_I2_J,axiom,
    ! [B: $tType,X2: B,Y: B,F: fun(B,nat),Fs: list(fun(B,nat))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measures(B,aa(list(fun(B,nat)),list(fun(B,nat)),aa(fun(B,nat),fun(list(fun(B,nat)),list(fun(B,nat))),cons(fun(B,nat)),F),Fs)))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y))
        | ( ( aa(B,nat,F,X2) = aa(B,nat,F,Y) )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measures(B,Fs)) ) ) ) ).

% in_measures(2)
tff(fact_4114_mset__mergesort__by__rel__split,axiom,
    ! [B: $tType,Xs1: list(B),Xs2: list(B),Xsa: list(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),mset(B,aa(product_prod(list(B),list(B)),list(B),product_fst(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),Xsa)))),mset(B,aa(product_prod(list(B),list(B)),list(B),product_snd(list(B),list(B)),merges295452479951948502_split(B,aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xs1),Xs2),Xsa)))) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),mset(B,Xsa)),mset(B,Xs1))),mset(B,Xs2)) ).

% mset_mergesort_by_rel_split
tff(fact_4115_union__eq__empty,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5) = zero_zero(multiset(B)) )
    <=> ( ( M2 = zero_zero(multiset(B)) )
        & ( N5 = zero_zero(multiset(B)) ) ) ) ).

% union_eq_empty
tff(fact_4116_empty__eq__union,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B)] :
      ( ( zero_zero(multiset(B)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5) )
    <=> ( ( M2 = zero_zero(multiset(B)) )
        & ( N5 = zero_zero(multiset(B)) ) ) ) ).

% empty_eq_union
tff(fact_4117_subset__mset_Ozero__eq__add__iff__both__eq__0,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B)] :
      ( ( zero_zero(multiset(B)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Y) )
    <=> ( ( X2 = zero_zero(multiset(B)) )
        & ( Y = zero_zero(multiset(B)) ) ) ) ).

% subset_mset.zero_eq_add_iff_both_eq_0
tff(fact_4118_subset__mset_Oadd__eq__0__iff__both__eq__0,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Y) = zero_zero(multiset(B)) )
    <=> ( ( X2 = zero_zero(multiset(B)) )
        & ( Y = zero_zero(multiset(B)) ) ) ) ).

% subset_mset.add_eq_0_iff_both_eq_0
tff(fact_4119_diff__diff__add__mset,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B),P: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),N5)),P) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),P)) ).

% diff_diff_add_mset
tff(fact_4120_mergesort__by__rel__permutes,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B)] : mset(B,aa(list(B),list(B),mergesort_by_rel(B,R4),Xsa)) = mset(B,Xsa) ).

% mergesort_by_rel_permutes
tff(fact_4121_in__measures_I1_J,axiom,
    ! [B: $tType,X2: B,Y: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measures(B,nil(fun(B,nat)))) ).

% in_measures(1)
tff(fact_4122_mset__append,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] : mset(B,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),mset(B,Xsa)),mset(B,Ys)) ).

% mset_append
tff(fact_4123_quicksort__by__rel__permutes,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Sl2: list(B),Xsa: list(B)] : mset(B,aa(list(B),list(B),quicksort_by_rel(B,R4,Sl2),Xsa)) = mset(B,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Sl2)) ).

% quicksort_by_rel_permutes
tff(fact_4124_mset__mergesort__by__rel__merge,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o)),Xsa: list(B),Ys: list(B)] : mset(B,merges9089515139780605204_merge(B,R4,Xsa,Ys)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),mset(B,Xsa)),mset(B,Ys)) ).

% mset_mergesort_by_rel_merge
tff(fact_4125_success__lenI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),Ha: heap_ext(product_unit)] : heap_Time_success(nat,array_len(B,A3),Ha) ) ).

% success_lenI
tff(fact_4126_fails__array__len,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [P3: array(B),Ha: heap_ext(product_unit)] : ~ time_fails(nat,array_len(B,P3),Ha) ) ).

% fails_array_len
tff(fact_4127_mset__distrib,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),M2: multiset(B),N5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5) )
     => ~ ! [Am: multiset(B),An: multiset(B)] :
            ( ( A4 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Am),An) )
           => ! [Bm: multiset(B),Bn: multiset(B)] :
                ( ( B5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Bm),Bn) )
               => ( ( M2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Am),Bm) )
                 => ( N5 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),An),Bn) ) ) ) ) ) ).

% mset_distrib
tff(fact_4128_mset__shuffles,axiom,
    ! [B: $tType,Zs: list(B),Xsa: list(B),Ys: list(B)] :
      ( member(list(B),Zs,shuffles(B,Xsa,Ys))
     => ( mset(B,Zs) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),mset(B,Xsa)),mset(B,Ys)) ) ) ).

% mset_shuffles
tff(fact_4129_union__less__mono,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [A4: multiset(B),C5: multiset(B),B5: multiset(B),D4: multiset(B)] :
          ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),A4),C5)
         => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),B5),D4)
           => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),D4)) ) ) ) ).

% union_less_mono
tff(fact_4130_union__le__mono2,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [B5: multiset(B),D4: multiset(B),C5: multiset(B)] :
          ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),B5),D4)
         => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),B5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),D4)) ) ) ).

% union_le_mono2
tff(fact_4131_union__le__mono1,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [B5: multiset(B),D4: multiset(B),C5: multiset(B)] :
          ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),B5),D4)
         => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),ord_less(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),D4),C5)) ) ) ).

% union_le_mono1
tff(fact_4132_multi__union__self__other__eq,axiom,
    ! [B: $tType,A4: multiset(B),X7: multiset(B),Y7: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),X7) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),Y7) )
     => ( X7 = Y7 ) ) ).

% multi_union_self_other_eq
tff(fact_4133_union__right__cancel,axiom,
    ! [B: $tType,M2: multiset(B),K2: multiset(B),N5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),K2) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),K2) )
    <=> ( M2 = N5 ) ) ).

% union_right_cancel
tff(fact_4134_union__left__cancel,axiom,
    ! [B: $tType,K2: multiset(B),M2: multiset(B),N5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),K2),M2) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),K2),N5) )
    <=> ( M2 = N5 ) ) ).

% union_left_cancel
tff(fact_4135_union__commute,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),M2) ).

% union_commute
tff(fact_4136_union__lcomm,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B),K2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),K2)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),K2)) ).

% union_lcomm
tff(fact_4137_union__assoc,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B),K2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)),K2) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),K2)) ).

% union_assoc
tff(fact_4138_empty__neutral_I1_J,axiom,
    ! [B: $tType,X2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),zero_zero(multiset(B))),X2) = X2 ).

% empty_neutral(1)
tff(fact_4139_empty__neutral_I2_J,axiom,
    ! [B: $tType,X2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),zero_zero(multiset(B))) = X2 ).

% empty_neutral(2)
tff(fact_4140_diff__union__cancelR,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)),N5) = M2 ).

% diff_union_cancelR
tff(fact_4141_diff__union__cancelL,axiom,
    ! [B: $tType,N5: multiset(B),M2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),M2)),N5) = M2 ).

% diff_union_cancelL
tff(fact_4142_Multiset_Odiff__add,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B),Q: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),N5),Q)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),N5)),Q) ).

% Multiset.diff_add
tff(fact_4143_union__diff__assoc,axiom,
    ! [B: $tType,C5: multiset(B),B5: multiset(B),A4: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C5),B5) = zero_zero(multiset(B)) )
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),C5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),C5)) ) ) ).

% union_diff_assoc
tff(fact_4144_comp__fun__commute__plus__mset,axiom,
    ! [B: $tType] : finite6289374366891150609ommute(multiset(B),multiset(B),plus_plus(multiset(B))) ).

% comp_fun_commute_plus_mset
tff(fact_4145_len__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B)] : array_len(B,A3) = heap_Time_tap(nat,aTP_Lamp_rx(array(B),fun(heap_ext(product_unit),nat),A3)) ) ).

% len_def
tff(fact_4146_measures__less,axiom,
    ! [B: $tType,F: fun(B,nat),X2: B,Y: B,Fs: list(fun(B,nat))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measures(B,aa(list(fun(B,nat)),list(fun(B,nat)),aa(fun(B,nat),fun(list(fun(B,nat)),list(fun(B,nat))),cons(fun(B,nat)),F),Fs))) ) ).

% measures_less
tff(fact_4147_measures__lesseq,axiom,
    ! [B: $tType,F: fun(B,nat),X2: B,Y: B,Fs: list(fun(B,nat))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,F,X2)),aa(B,nat,F,Y))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measures(B,Fs))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),measures(B,aa(list(fun(B,nat)),list(fun(B,nat)),aa(fun(B,nat),fun(list(fun(B,nat)),list(fun(B,nat))),cons(fun(B,nat)),F),Fs))) ) ) ).

% measures_lesseq
tff(fact_4148_effect__lengthE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: nat,N: nat] :
          ( heap_Time_effect(nat,array_len(B,A3),Ha,H2,R,N)
         => ~ ( ( R = aa(array(B),nat,array_length(B,H2),A3) )
             => ( ( H2 = Ha )
               => ( N != one_one(nat) ) ) ) ) ) ).

% effect_lengthE
tff(fact_4149_effect__lengthI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [H2: heap_ext(product_unit),Ha: heap_ext(product_unit),R: nat,A3: array(B),N: nat] :
          ( ( H2 = Ha )
         => ( ( R = aa(array(B),nat,array_length(B,Ha),A3) )
           => ( ( N = one_one(nat) )
             => heap_Time_effect(nat,array_len(B,A3),Ha,H2,R,N) ) ) ) ) ).

% effect_lengthI
tff(fact_4150_len_H__def,axiom,
    ! [C: $tType,B: $tType] :
      ( ( semiring_1(B)
        & heap(C) )
     => ! [A3: array(C)] : array_len2(C,B,A3) = heap_Time_bind(nat,B,array_len(C,A3),aTP_Lamp_ry(nat,heap_Time_Heap(B))) ) ).

% len'_def
tff(fact_4151_mset__zip__take__Cons__drop__twice,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C),J: nat,X2: B,Y: C] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),aa(list(B),nat,size_size(list(B)),Xsa))
       => ( mset(product_prod(B,C),zip(B,C,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),take(B,J,Xsa)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),drop(B,J,Xsa))),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),take(C,J,Ys)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),Y),drop(C,J,Ys))))) = aa(multiset(product_prod(B,C)),multiset(product_prod(B,C)),aa(product_prod(B,C),fun(multiset(product_prod(B,C)),multiset(product_prod(B,C))),add_mset(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)),mset(product_prod(B,C),zip(B,C,Xsa,Ys))) ) ) ) ).

% mset_zip_take_Cons_drop_twice
tff(fact_4152_image__mset__map__of,axiom,
    ! [C: $tType,B: $tType,Xsa: list(product_prod(B,C))] :
      ( distinct(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa))
     => ( aa(multiset(B),multiset(C),image_mset(B,C,aTP_Lamp_rz(list(product_prod(B,C)),fun(B,C),Xsa)),mset(B,aa(list(product_prod(B,C)),list(B),map(product_prod(B,C),B,product_fst(B,C)),Xsa))) = mset(C,aa(list(product_prod(B,C)),list(C),map(product_prod(B,C),C,product_snd(B,C)),Xsa)) ) ) ).

% image_mset_map_of
tff(fact_4153_mset__set__Union,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(B,B5)
       => ( ( aa(set(B),set(B),inf_inf(set(B),A4),B5) = bot_bot(set(B)) )
         => ( mset_set(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),mset_set(B,A4)),mset_set(B,B5)) ) ) ) ) ).

% mset_set_Union
tff(fact_4154_union__mset__add__mset__right,axiom,
    ! [B: $tType,A4: multiset(B),A3: B,B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),B5)) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) ).

% union_mset_add_mset_right
tff(fact_4155_union__mset__add__mset__left,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),A4)),B5) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) ).

% union_mset_add_mset_left
tff(fact_4156_image__mset__union,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),M2: multiset(C),N5: multiset(C)] : aa(multiset(C),multiset(B),image_mset(C,B,F),aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),M2),N5)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(C),multiset(B),image_mset(C,B,F),M2)),aa(multiset(C),multiset(B),image_mset(C,B,F),N5)) ).

% image_mset_union
tff(fact_4157_mset__map__split__orig,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),P: multiset(C),M13: multiset(B),M24: multiset(B)] :
      ( ( aa(multiset(C),multiset(B),image_mset(C,B,F),P) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M13),M24) )
     => ~ ! [P1: multiset(C),P22: multiset(C)] :
            ( ( P = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),P1),P22) )
           => ( ( aa(multiset(C),multiset(B),image_mset(C,B,F),P1) = M13 )
             => ( aa(multiset(C),multiset(B),image_mset(C,B,F),P22) != M24 ) ) ) ) ).

% mset_map_split_orig
tff(fact_4158_add__mset__add__single,axiom,
    ! [B: $tType,A3: B,A4: multiset(B)] : aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),A4) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))) ).

% add_mset_add_single
tff(fact_4159_union__is__single,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B),A3: B] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) )
    <=> ( ( ( M2 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) )
          & ( N5 = zero_zero(multiset(B)) ) )
        | ( ( M2 = zero_zero(multiset(B)) )
          & ( N5 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) ) ) ) ) ).

% union_is_single
tff(fact_4160_single__is__union,axiom,
    ! [B: $tType,A3: B,M2: multiset(B),N5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5) )
    <=> ( ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) = M2 )
          & ( N5 = zero_zero(multiset(B)) ) )
        | ( ( M2 = zero_zero(multiset(B)) )
          & ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) = N5 ) ) ) ) ).

% single_is_union
tff(fact_4161_add__mset__replicate__mset__safe,axiom,
    ! [B: $tType,C: $tType,M2: multiset(C),A3: C] :
      ( nO_MATCH(multiset(B),multiset(C),zero_zero(multiset(B)),M2)
     => ( aa(multiset(C),multiset(C),aa(C,fun(multiset(C),multiset(C)),add_mset(C),A3),M2) = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),aa(multiset(C),multiset(C),aa(C,fun(multiset(C),multiset(C)),add_mset(C),A3),zero_zero(multiset(C)))),M2) ) ) ).

% add_mset_replicate_mset_safe
tff(fact_4162_mset__single__cases,axiom,
    ! [B: $tType,S: B,C2: multiset(B),R3: B,C6: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),C2) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),C6) )
     => ( ( ( S = R3 )
         => ( C2 != C6 ) )
       => ~ ( ( C6 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C6),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) )
           => ( ( C2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B))))) )
             => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))) != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C6),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))) ) ) ) ) ) ).

% mset_single_cases
tff(fact_4163_mset__single__cases_H,axiom,
    ! [B: $tType,S: B,C2: multiset(B),R3: B,C6: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),C2) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),C6) )
     => ( ( ( S = R3 )
         => ( C2 != C6 ) )
       => ~ ! [Cc: multiset(B)] :
              ( ( C6 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),Cc) )
             => ( ( C2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))),Cc) )
               => ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C6),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))) = Cc )
                 => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))) != Cc ) ) ) ) ) ) ).

% mset_single_cases'
tff(fact_4164_mset__single__cases2,axiom,
    ! [B: $tType,S: B,C2: multiset(B),R3: B,C6: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),C2) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),C6) )
     => ( ( ( S = R3 )
         => ( C2 != C6 ) )
       => ~ ( ( C6 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C6),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))) )
           => ( ( C2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B))))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))) )
             => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))) != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C6),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))) ) ) ) ) ) ).

% mset_single_cases2
tff(fact_4165_mset__single__cases2_H,axiom,
    ! [B: $tType,S: B,C2: multiset(B),R3: B,C6: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),C2) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),C6) )
     => ( ( ( S = R3 )
         => ( C2 != C6 ) )
       => ~ ! [Cc: multiset(B)] :
              ( ( C6 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Cc),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))) )
             => ( ( C2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Cc),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))) )
               => ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C6),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))) = Cc )
                 => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),R3),zero_zero(multiset(B)))) != Cc ) ) ) ) ) ) ).

% mset_single_cases2'
tff(fact_4166_mset__unplusm__dist__cases,axiom,
    ! [B: $tType,S: B,A4: multiset(B),B5: multiset(B),C5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),A4) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5) )
     => ( ( ( B5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) )
         => ( A4 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))),C5) ) )
       => ~ ( ( C5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) )
           => ( A4 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) ) ) ) ) ).

% mset_unplusm_dist_cases
tff(fact_4167_mset__unplusm__dist__cases2,axiom,
    ! [B: $tType,B5: multiset(B),C5: multiset(B),S: B,A4: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),A4) )
     => ( ( ( B5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) )
         => ( A4 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))),C5) ) )
       => ~ ( ( C5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) )
           => ( A4 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),S),zero_zero(multiset(B))))) ) ) ) ) ).

% mset_unplusm_dist_cases2
tff(fact_4168_image__mset_Ocompositionality,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(C,B),G: fun(D,C),Multiset: multiset(D)] : aa(multiset(C),multiset(B),image_mset(C,B,F),aa(multiset(D),multiset(C),image_mset(D,C,G),Multiset)) = aa(multiset(D),multiset(B),image_mset(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),F),G)),Multiset) ).

% image_mset.compositionality
tff(fact_4169_multiset_Omap__comp,axiom,
    ! [C: $tType,B: $tType,D: $tType,G: fun(C,B),F: fun(D,C),V: multiset(D)] : aa(multiset(C),multiset(B),image_mset(C,B,G),aa(multiset(D),multiset(C),image_mset(D,C,F),V)) = aa(multiset(D),multiset(B),image_mset(D,B,aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),V) ).

% multiset.map_comp
tff(fact_4170_image__mset_Ocomp,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(D,C),G: fun(B,D)] : aa(fun(multiset(B),multiset(D)),fun(multiset(B),multiset(C)),aa(fun(multiset(D),multiset(C)),fun(fun(multiset(B),multiset(D)),fun(multiset(B),multiset(C))),comp(multiset(D),multiset(C),multiset(B)),image_mset(D,C,F)),image_mset(B,D,G)) = image_mset(B,C,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),G)) ).

% image_mset.comp
tff(fact_4171_mset__map__id,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),G: fun(B,C),X7: multiset(B)] :
      ( ! [X3: B] : aa(C,B,F,aa(B,C,G,X3)) = X3
     => ( aa(multiset(C),multiset(B),image_mset(C,B,F),aa(multiset(B),multiset(C),image_mset(B,C,G),X7)) = X7 ) ) ).

% mset_map_id
tff(fact_4172_mset__union__2__elem,axiom,
    ! [B: $tType,A3: B,B2: B,C2: B,M2: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B)))) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),C2),M2) )
     => ( ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) = M2 )
          & ( B2 = C2 ) )
        | ( ( A3 = C2 )
          & ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B))) = M2 ) ) ) ) ).

% mset_union_2_elem
tff(fact_4173_wcount__add__mset,axiom,
    ! [B: $tType,F: fun(B,nat),X2: B,M2: multiset(B),A3: B] :
      wcount(B,F,aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),M2),A3) = aa(nat,nat,
        aa(nat,fun(nat,nat),plus_plus(nat),
          $ite(X2 = A3,aa(nat,nat,suc,aa(B,nat,F,A3)),zero_zero(nat))),
        wcount(B,F,M2,A3)) ).

% wcount_add_mset
tff(fact_4174_subset__mset_Osum__list__update,axiom,
    ! [B: $tType,K: nat,Xsa: list(multiset(B)),X2: multiset(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),aa(list(multiset(B)),nat,size_size(list(multiset(B))),Xsa))
     => ( groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),list_update(multiset(B),Xsa,K,X2)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Xsa)),X2)),aa(nat,multiset(B),nth(multiset(B),Xsa),K)) ) ) ).

% subset_mset.sum_list_update
tff(fact_4175_size__multiset__add__mset,axiom,
    ! [B: $tType,F: fun(B,nat),A3: B,M2: multiset(B)] : size_multiset(B,F,aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),M2)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,suc,aa(B,nat,F,A3))),size_multiset(B,F,M2)) ).

% size_multiset_add_mset
tff(fact_4176_subset__mset_Osum__eq__0__iff,axiom,
    ! [B: $tType,C: $tType,F5: set(B),F: fun(B,multiset(C))] :
      ( finite_finite2(B,F5)
     => ( ( groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,F5) = zero_zero(multiset(C)) )
      <=> ! [X4: B] :
            ( member(B,X4,F5)
           => ( aa(B,multiset(C),F,X4) = zero_zero(multiset(C)) ) ) ) ) ).

% subset_mset.sum_eq_0_iff
tff(fact_4177_size__multiset__union,axiom,
    ! [B: $tType,F: fun(B,nat),M2: multiset(B),N5: multiset(B)] : size_multiset(B,F,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),size_multiset(B,F,M2)),size_multiset(B,F,N5)) ).

% size_multiset_union
tff(fact_4178_subset__mset_Osum__list__eq__0__iff,axiom,
    ! [B: $tType,Ns: list(multiset(B))] :
      ( ( groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Ns) = zero_zero(multiset(B)) )
    <=> ! [X4: multiset(B)] :
          ( member(multiset(B),X4,aa(list(multiset(B)),set(multiset(B)),set2(multiset(B)),Ns))
         => ( X4 = zero_zero(multiset(B)) ) ) ) ).

% subset_mset.sum_list_eq_0_iff
tff(fact_4179_wcount__union,axiom,
    ! [B: $tType,F: fun(B,nat),M2: multiset(B),N5: multiset(B),A3: B] : wcount(B,F,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5),A3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),wcount(B,F,M2,A3)),wcount(B,F,N5,A3)) ).

% wcount_union
tff(fact_4180_subset__mset_Oelem__le__sum__list,axiom,
    ! [B: $tType,K: nat,Ns: list(multiset(B))] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),aa(list(multiset(B)),nat,size_size(list(multiset(B))),Ns))
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(nat,multiset(B),nth(multiset(B),Ns),K)),groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Ns)) ) ).

% subset_mset.elem_le_sum_list
tff(fact_4181_subset__mset_Osum__mono2,axiom,
    ! [C: $tType,B: $tType,B5: set(B),A4: set(B),F: fun(B,multiset(C))] :
      ( finite_finite2(B,B5)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
       => ( ! [B3: B] :
              ( member(B,B3,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),B5),A4))
             => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),aa(B,multiset(C),F,B3)) )
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,A4)),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,B5)) ) ) ) ).

% subset_mset.sum_mono2
tff(fact_4182_next_Osimps,axiom,
    ! [V: code_natural,W: code_natural] :
      aa(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),next,aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),V),W)) = $let(
        v: code_natural,
        v:= minus_shift(aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2))))))))))))))))))))))))))))))),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),modulo_modulo(code_natural),V),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,one2)))))))))))))))))),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,one2))))))))))))))))),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),V),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,one2)))))))))))))))))),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,one2)))))))))))))))),
        $let(
          w: code_natural,
          w:= minus_shift(aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2))))))))))))))))))))))))))))))),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),modulo_modulo(code_natural),W),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,one2)))))))))))))))))),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,one2))))))))))))))))),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),W),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,one2)))))))))))))))))),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,one2)))))))))))))),
          aa(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),product_Pair(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),minus_shift(aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2))))))))))))))))))))))))))))))),v,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),w),one_one(code_natural)))),one_one(code_natural))),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),v),w)) ) ) ).

% next.simps
tff(fact_4183_find__dropWhile,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B)] : find(B,P,Xsa) = aa(list(B),option(B),case_list(option(B),B,none(B),aTP_Lamp_sa(B,fun(list(B),option(B)))),dropWhile(B,aa(fun(B,$o),fun(B,$o),aa(fun($o,$o),fun(fun(B,$o),fun(B,$o)),comp($o,$o,B),fNot),P),Xsa)) ).

% find_dropWhile
tff(fact_4184_mset__subset__eq__mono__add__right__cancel,axiom,
    ! [B: $tType,A4: multiset(B),C5: multiset(B),B5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),C5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5))
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),B5) ) ).

% mset_subset_eq_mono_add_right_cancel
tff(fact_4185_mset__subset__eq__mono__add__left__cancel,axiom,
    ! [B: $tType,C5: multiset(B),A4: multiset(B),B5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),A4)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),B5))
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),B5) ) ).

% mset_subset_eq_mono_add_left_cancel
tff(fact_4186_subset__mset_Oadd__le__cancel__right,axiom,
    ! [B: $tType,A3: multiset(B),C2: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2))
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% subset_mset.add_le_cancel_right
tff(fact_4187_subset__mset_Oadd__le__cancel__left,axiom,
    ! [B: $tType,C2: multiset(B),A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2))
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% subset_mset.add_le_cancel_left
tff(fact_4188_subset__mset_Ole__add__same__cancel2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),A3))
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),B2) ) ).

% subset_mset.le_add_same_cancel2
tff(fact_4189_subset__mset_Ole__add__same__cancel1,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2))
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),B2) ) ).

% subset_mset.le_add_same_cancel1
tff(fact_4190_subset__mset_Oadd__le__same__cancel2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2)),B2)
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),zero_zero(multiset(B))) ) ).

% subset_mset.add_le_same_cancel2
tff(fact_4191_subset__mset_Oadd__le__same__cancel1,axiom,
    ! [B: $tType,B2: multiset(B),A3: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),A3)),B2)
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),zero_zero(multiset(B))) ) ).

% subset_mset.add_le_same_cancel1
tff(fact_4192_mset__subset__eq__multiset__union__diff__commute,axiom,
    ! [B: $tType,B5: multiset(B),A4: multiset(B),C5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),A4)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),A4),B5)),C5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),C5)),B5) ) ) ).

% mset_subset_eq_multiset_union_diff_commute
tff(fact_4193_subset__mset_Oadd__diff__assoc2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)),C2) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2)),A3) ) ) ).

% subset_mset.add_diff_assoc2
tff(fact_4194_subset__mset_Oadd__diff__assoc,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2)),A3) ) ) ).

% subset_mset.add_diff_assoc
tff(fact_4195_subset__mset_Odiff__add,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)),A3) = B2 ) ) ).

% subset_mset.diff_add
tff(fact_4196_mset__le__add__mset__decr__left1,axiom,
    ! [B: $tType,C2: B,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),C2),A3)),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% mset_le_add_mset_decr_left1
tff(fact_4197_mset__le__incr__right2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2)) ) ).

% mset_le_incr_right2
tff(fact_4198_mset__le__incr__right1,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2)) ) ).

% mset_le_incr_right1
tff(fact_4199_mset__le__decr__left2,axiom,
    ! [B: $tType,C2: multiset(B),A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3)),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% mset_le_decr_left2
tff(fact_4200_mset__le__decr__left1,axiom,
    ! [B: $tType,A3: multiset(B),C2: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% mset_le_decr_left1
tff(fact_4201_mset__union__subset,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),C5)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),C5)
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),C5) ) ) ).

% mset_union_subset
tff(fact_4202_mset__le__distrib,axiom,
    ! [B: $tType,X7: multiset(B),A4: multiset(B),B5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),X7),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5))
     => ~ ! [Xa5: multiset(B),Xb5: multiset(B)] :
            ( ( X7 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Xa5),Xb5) )
           => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),Xa5),A4)
             => ~ aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),Xb5),B5) ) ) ) ).

% mset_le_distrib
tff(fact_4203_mset__le__addE,axiom,
    ! [B: $tType,Xsa: multiset(B),Ys: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),Xsa),Ys)
     => ~ ! [Zs2: multiset(B)] : Ys != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Xsa),Zs2) ) ).

% mset_le_addE
tff(fact_4204_mset__subset__eq__exists__conv,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),B5)
    <=> ? [C7: multiset(B)] : B5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),C7) ) ).

% mset_subset_eq_exists_conv
tff(fact_4205_mset__subset__eq__add__right,axiom,
    ! [B: $tType,B5: multiset(B),A4: multiset(B)] : aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) ).

% mset_subset_eq_add_right
tff(fact_4206_mset__subset__eq__mono__add,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B),D4: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),B5)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C5),D4)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),C5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),D4)) ) ) ).

% mset_subset_eq_mono_add
tff(fact_4207_mset__subset__eq__add__left,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) ).

% mset_subset_eq_add_left
tff(fact_4208_subset__mset_Oadd__le__imp__le__right,axiom,
    ! [B: $tType,A3: multiset(B),C2: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2))
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% subset_mset.add_le_imp_le_right
tff(fact_4209_subset__mset_Oadd__le__imp__le__left,axiom,
    ! [B: $tType,C2: multiset(B),A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2))
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2) ) ).

% subset_mset.add_le_imp_le_left
tff(fact_4210_subset__mset_Oadd__right__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2)) ) ).

% subset_mset.add_right_mono
tff(fact_4211_subset__mset_Oadd__left__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2)) ) ).

% subset_mset.add_left_mono
tff(fact_4212_subset__mset_Ole__iff__add,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
    <=> ? [C4: multiset(B)] : B2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C4) ) ).

% subset_mset.le_iff_add
tff(fact_4213_subset__mset_Oless__eqE,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ~ ! [C3: multiset(B)] : B2 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C3) ) ).

% subset_mset.less_eqE
tff(fact_4214_subset__mset_Oadd__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B),D3: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C2),D3)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),D3)) ) ) ).

% subset_mset.add_mono
tff(fact_4215_full__exhaustive__natural_H_Ocases,axiom,
    ! [X2: product_prod(fun(product_prod(code_natural,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))] :
      ~ ! [F3: fun(product_prod(code_natural,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),D2: code_natural,I2: code_natural] : X2 != aa(product_prod(code_natural,code_natural),product_prod(fun(product_prod(code_natural,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),aa(fun(product_prod(code_natural,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),fun(product_prod(code_natural,code_natural),product_prod(fun(product_prod(code_natural,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))),product_Pair(fun(product_prod(code_natural,fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),F3),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),D2),I2)) ).

% full_exhaustive_natural'.cases
tff(fact_4216_full__exhaustive__fun_H_Ocases,axiom,
    ! [B: $tType,C: $tType] :
      ( ( quickc3360725361186068524ustive(C)
        & cl_HOL_Oequal(B)
        & quickc3360725361186068524ustive(B) )
     => ! [X2: product_prod(fun(product_prod(fun(B,C),fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))] :
          ~ ! [F3: fun(product_prod(fun(B,C),fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),I2: code_natural,D2: code_natural] : X2 != aa(product_prod(code_natural,code_natural),product_prod(fun(product_prod(fun(B,C),fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),aa(fun(product_prod(fun(B,C),fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),fun(product_prod(code_natural,code_natural),product_prod(fun(product_prod(fun(B,C),fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))),product_Pair(fun(product_prod(fun(B,C),fun(product_unit,code_term)),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),F3),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),I2),D2)) ) ).

% full_exhaustive_fun'.cases
tff(fact_4217_exhaustive__natural_H_Ocases,axiom,
    ! [X2: product_prod(fun(code_natural,option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))] :
      ~ ! [F3: fun(code_natural,option(product_prod($o,list(code_term)))),D2: code_natural,I2: code_natural] : X2 != aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),aa(fun(code_natural,option(product_prod($o,list(code_term)))),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),F3),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),D2),I2)) ).

% exhaustive_natural'.cases
tff(fact_4218_exhaustive__fun_H_Ocases,axiom,
    ! [B: $tType,C: $tType] :
      ( ( quickc658316121487927005ustive(C)
        & cl_HOL_Oequal(B)
        & quickc658316121487927005ustive(B) )
     => ! [X2: product_prod(fun(fun(B,C),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))] :
          ~ ! [F3: fun(fun(B,C),option(product_prod($o,list(code_term)))),I2: code_natural,D2: code_natural] : X2 != aa(product_prod(code_natural,code_natural),product_prod(fun(fun(B,C),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),aa(fun(fun(B,C),option(product_prod($o,list(code_term)))),fun(product_prod(code_natural,code_natural),product_prod(fun(fun(B,C),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural))),product_Pair(fun(fun(B,C),option(product_prod($o,list(code_term)))),product_prod(code_natural,code_natural)),F3),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),I2),D2)) ) ).

% exhaustive_fun'.cases
tff(fact_4219_Lazy__Sequence_Oiterate__upto_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))] :
      ~ ! [F3: fun(code_natural,B),N3: code_natural,M4: code_natural] : X2 != aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),aa(fun(code_natural,B),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,B),product_prod(code_natural,code_natural)),F3),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),N3),M4)) ).

% Lazy_Sequence.iterate_upto.cases
tff(fact_4220_iter_Ocases,axiom,
    ! [B: $tType,X2: product_prod(fun(product_prod(code_natural,code_natural),product_prod(product_prod(B,fun(product_unit,code_term)),product_prod(code_natural,code_natural))),product_prod(code_natural,product_prod(code_natural,code_natural)))] :
      ~ ! [Random: fun(product_prod(code_natural,code_natural),product_prod(product_prod(B,fun(product_unit,code_term)),product_prod(code_natural,code_natural))),Nrandom: code_natural,Seed: product_prod(code_natural,code_natural)] : X2 != aa(product_prod(code_natural,product_prod(code_natural,code_natural)),product_prod(fun(product_prod(code_natural,code_natural),product_prod(product_prod(B,fun(product_unit,code_term)),product_prod(code_natural,code_natural))),product_prod(code_natural,product_prod(code_natural,code_natural))),aa(fun(product_prod(code_natural,code_natural),product_prod(product_prod(B,fun(product_unit,code_term)),product_prod(code_natural,code_natural))),fun(product_prod(code_natural,product_prod(code_natural,code_natural)),product_prod(fun(product_prod(code_natural,code_natural),product_prod(product_prod(B,fun(product_unit,code_term)),product_prod(code_natural,code_natural))),product_prod(code_natural,product_prod(code_natural,code_natural)))),product_Pair(fun(product_prod(code_natural,code_natural),product_prod(product_prod(B,fun(product_unit,code_term)),product_prod(code_natural,code_natural))),product_prod(code_natural,product_prod(code_natural,code_natural))),Random),aa(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),product_Pair(code_natural,product_prod(code_natural,code_natural)),Nrandom),Seed)) ).

% iter.cases
tff(fact_4221_log_Ocases,axiom,
    ! [X2: product_prod(code_natural,code_natural)] :
      ~ ! [B3: code_natural,I2: code_natural] : X2 != aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),B3),I2) ).

% log.cases
tff(fact_4222_mset__le__subtract,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),B5)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),A4),C5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),C5)) ) ).

% mset_le_subtract
tff(fact_4223_mset__le__add__mset__decr__left2,axiom,
    ! [B: $tType,C2: B,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),C2),A3)),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),C2),zero_zero(multiset(B)))),B2) ) ).

% mset_le_add_mset_decr_left2
tff(fact_4224_mset__le__single__cases,axiom,
    ! [B: $tType,M2: multiset(B),A3: B] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),M2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))))
     => ( ( M2 != zero_zero(multiset(B)) )
       => ( M2 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) ) ) ) ).

% mset_le_single_cases
tff(fact_4225_mset__le__add__mset,axiom,
    ! [B: $tType,X2: B,B5: multiset(B),C5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),B5)),C5)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))),C5)
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),C5) ) ) ).

% mset_le_add_mset
tff(fact_4226_subset__mset_Oadd__nonpos__eq__0__iff,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),X2),zero_zero(multiset(B)))
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),Y),zero_zero(multiset(B)))
       => ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Y) = zero_zero(multiset(B)) )
        <=> ( ( X2 = zero_zero(multiset(B)) )
            & ( Y = zero_zero(multiset(B)) ) ) ) ) ) ).

% subset_mset.add_nonpos_eq_0_iff
tff(fact_4227_subset__mset_Oadd__nonneg__eq__0__iff,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),X2)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),Y)
       => ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Y) = zero_zero(multiset(B)) )
        <=> ( ( X2 = zero_zero(multiset(B)) )
            & ( Y = zero_zero(multiset(B)) ) ) ) ) ) ).

% subset_mset.add_nonneg_eq_0_iff
tff(fact_4228_subset__mset_Oadd__nonpos__nonpos,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),zero_zero(multiset(B)))
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),zero_zero(multiset(B)))
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2)),zero_zero(multiset(B))) ) ) ).

% subset_mset.add_nonpos_nonpos
tff(fact_4229_subset__mset_Oadd__nonneg__nonneg,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),A3)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),B2)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2)) ) ) ).

% subset_mset.add_nonneg_nonneg
tff(fact_4230_subset__mset_Oadd__increasing2,axiom,
    ! [B: $tType,C2: multiset(B),B2: multiset(B),A3: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),C2)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),A3)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)) ) ) ).

% subset_mset.add_increasing2
tff(fact_4231_subset__mset_Oadd__decreasing2,axiom,
    ! [B: $tType,C2: multiset(B),A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C2),zero_zero(multiset(B)))
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),B2) ) ) ).

% subset_mset.add_decreasing2
tff(fact_4232_subset__mset_Oadd__increasing,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),A3)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),C2)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)) ) ) ).

% subset_mset.add_increasing
tff(fact_4233_subset__mset_Oadd__decreasing,axiom,
    ! [B: $tType,A3: multiset(B),C2: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),zero_zero(multiset(B)))
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C2),B2)
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)),B2) ) ) ).

% subset_mset.add_decreasing
tff(fact_4234_mset__le__subtract__left,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),X7: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),X7)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),X7),A4))
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),X7) ) ) ).

% mset_le_subtract_left
tff(fact_4235_mset__le__subtract__right,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),X7: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),X7)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),X7),B5))
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),X7) ) ) ).

% mset_le_subtract_right
tff(fact_4236_multiset__diff__union__assoc,axiom,
    ! [B: $tType,C5: multiset(B),B5: multiset(B),A4: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C5),B5)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),C5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),C5)) ) ) ).

% multiset_diff_union_assoc
tff(fact_4237_subset__eq__diff__conv,axiom,
    ! [B: $tType,A4: multiset(B),C5: multiset(B),B5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),A4),C5)),B5)
    <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5)) ) ).

% subset_eq_diff_conv
tff(fact_4238_subset__mset_Ole__imp__diff__is__add,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
       => ( ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3) = C2 )
        <=> ( B2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3) ) ) ) ) ).

% subset_mset.le_imp_diff_is_add
tff(fact_4239_subset__mset_Oadd__diff__inverse,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)) = B2 ) ) ).

% subset_mset.add_diff_inverse
tff(fact_4240_subset__mset_Odiff__diff__right,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3)),B2) ) ) ).

% subset_mset.diff_diff_right
tff(fact_4241_subset__mset_Odiff__add__assoc2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2)),A3) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)),C2) ) ) ).

% subset_mset.diff_add_assoc2
tff(fact_4242_subset__mset_Odiff__add__assoc,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2)),A3) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3)) ) ) ).

% subset_mset.diff_add_assoc
tff(fact_4243_subset__mset_Ole__diff__conv2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B2),A3))
      <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3)),B2) ) ) ).

% subset_mset.le_diff_conv2
tff(fact_4244_subset__mset_Ole__add__diff,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2)),A3)) ) ).

% subset_mset.le_add_diff
tff(fact_4245_mset__map__split__orig__le,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),P: multiset(C),M13: multiset(B),M24: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,F),P)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M13),M24))
     => ~ ! [P1: multiset(C),P22: multiset(C)] :
            ( ( P = aa(multiset(C),multiset(C),aa(multiset(C),fun(multiset(C),multiset(C)),plus_plus(multiset(C)),P1),P22) )
           => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,F),P1)),M13)
             => ~ aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,F),P22)),M24) ) ) ) ).

% mset_map_split_orig_le
tff(fact_4246_mset__le__subtract__add__mset__right,axiom,
    ! [B: $tType,X2: B,B5: multiset(B),X7: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),B5)),X7)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),X7),B5))
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),X7) ) ) ).

% mset_le_subtract_add_mset_right
tff(fact_4247_mset__le__subtract__add__mset__left,axiom,
    ! [B: $tType,X2: B,B5: multiset(B),X7: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),B5)),X7)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),X7),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))))
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))),X7) ) ) ).

% mset_le_subtract_add_mset_left
tff(fact_4248_subset__mset_Osum__nonneg,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,multiset(C))] :
      ( ! [X3: B] :
          ( member(B,X3,A4)
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),aa(B,multiset(C),F,X3)) )
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,A4)) ) ).

% subset_mset.sum_nonneg
tff(fact_4249_subset__mset_Osum__nonpos,axiom,
    ! [B: $tType,C: $tType,A4: set(B),F: fun(B,multiset(C))] :
      ( ! [X3: B] :
          ( member(B,X3,A4)
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(B,multiset(C),F,X3)),zero_zero(multiset(C))) )
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,A4)),zero_zero(multiset(C))) ) ).

% subset_mset.sum_nonpos
tff(fact_4250_subset__mset_Osum__list__nonneg,axiom,
    ! [B: $tType,Xsa: list(multiset(B))] :
      ( ! [X3: multiset(B)] :
          ( member(multiset(B),X3,aa(list(multiset(B)),set(multiset(B)),set2(multiset(B)),Xsa))
         => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),X3) )
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Xsa)) ) ).

% subset_mset.sum_list_nonneg
tff(fact_4251_subset__mset_Osum__list__nonpos,axiom,
    ! [B: $tType,Xsa: list(multiset(B))] :
      ( ! [X3: multiset(B)] :
          ( member(multiset(B),X3,aa(list(multiset(B)),set(multiset(B)),set2(multiset(B)),Xsa))
         => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),X3),zero_zero(multiset(B))) )
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Xsa)),zero_zero(multiset(B))) ) ).

% subset_mset.sum_list_nonpos
tff(fact_4252_subset__mset_Omember__le__sum__list,axiom,
    ! [B: $tType,X2: multiset(B),Xsa: list(multiset(B))] :
      ( member(multiset(B),X2,aa(list(multiset(B)),set(multiset(B)),set2(multiset(B)),Xsa))
     => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),X2),groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Xsa)) ) ).

% subset_mset.member_le_sum_list
tff(fact_4253_subset__mset_Osum__list__nonneg__eq__0__iff,axiom,
    ! [B: $tType,Xsa: list(multiset(B))] :
      ( ! [X3: multiset(B)] :
          ( member(multiset(B),X3,aa(list(multiset(B)),set(multiset(B)),set2(multiset(B)),Xsa))
         => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),X3) )
     => ( ( groups4543113879258116180m_list(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),Xsa) = zero_zero(multiset(B)) )
      <=> ! [X4: multiset(B)] :
            ( member(multiset(B),X4,aa(list(multiset(B)),set(multiset(B)),set2(multiset(B)),Xsa))
           => ( X4 = zero_zero(multiset(B)) ) ) ) ) ).

% subset_mset.sum_list_nonneg_eq_0_iff
tff(fact_4254_subset__mset_Osum__mono,axiom,
    ! [C: $tType,B: $tType,K2: set(B),F: fun(B,multiset(C)),G: fun(B,multiset(C))] :
      ( ! [I2: B] :
          ( member(B,I2,K2)
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(B,multiset(C),F,I2)),aa(B,multiset(C),G,I2)) )
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,K2)),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),G,K2)) ) ).

% subset_mset.sum_mono
tff(fact_4255_subset__mset_Osum__le__included,axiom,
    ! [B: $tType,D: $tType,C: $tType,S: set(B),T2: set(C),G: fun(C,multiset(D)),I: fun(C,B),F: fun(B,multiset(D))] :
      ( finite_finite2(B,S)
     => ( finite_finite2(C,T2)
       => ( ! [X3: C] :
              ( member(C,X3,T2)
             => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),zero_zero(multiset(D))),aa(C,multiset(D),G,X3)) )
         => ( ! [X3: B] :
                ( member(B,X3,S)
               => ? [Xa3: C] :
                    ( member(C,Xa3,T2)
                    & ( aa(C,B,I,Xa3) = X3 )
                    & aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),aa(B,multiset(D),F,X3)),aa(C,multiset(D),G,Xa3)) ) )
           => aa(multiset(D),$o,aa(multiset(D),fun(multiset(D),$o),subseteq_mset(D),groups3894954378712506084id_sum(multiset(D),B,plus_plus(multiset(D)),zero_zero(multiset(D)),F,S)),groups3894954378712506084id_sum(multiset(D),C,plus_plus(multiset(D)),zero_zero(multiset(D)),G,T2)) ) ) ) ) ).

% subset_mset.sum_le_included
tff(fact_4256_subset__mset_Osum__nonneg__eq__0__iff,axiom,
    ! [B: $tType,C: $tType,A4: set(B),F: fun(B,multiset(C))] :
      ( finite_finite2(B,A4)
     => ( ! [X3: B] :
            ( member(B,X3,A4)
           => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),aa(B,multiset(C),F,X3)) )
       => ( ( groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,A4) = zero_zero(multiset(C)) )
        <=> ! [X4: B] :
              ( member(B,X4,A4)
             => ( aa(B,multiset(C),F,X4) = zero_zero(multiset(C)) ) ) ) ) ) ).

% subset_mset.sum_nonneg_eq_0_iff
tff(fact_4257_subset__mset_Osum__nonneg__0,axiom,
    ! [B: $tType,C: $tType,S: set(B),F: fun(B,multiset(C)),I: B] :
      ( finite_finite2(B,S)
     => ( ! [I2: B] :
            ( member(B,I2,S)
           => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),aa(B,multiset(C),F,I2)) )
       => ( ( groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,S) = zero_zero(multiset(C)) )
         => ( member(B,I,S)
           => ( aa(B,multiset(C),F,I) = zero_zero(multiset(C)) ) ) ) ) ) ).

% subset_mset.sum_nonneg_0
tff(fact_4258_subset__mset_Osum__nonneg__leq__bound,axiom,
    ! [B: $tType,C: $tType,S: set(B),F: fun(B,multiset(C)),B5: multiset(C),I: B] :
      ( finite_finite2(B,S)
     => ( ! [I2: B] :
            ( member(B,I2,S)
           => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),aa(B,multiset(C),F,I2)) )
       => ( ( groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,S) = B5 )
         => ( member(B,I,S)
           => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(B,multiset(C),F,I)),B5) ) ) ) ) ).

% subset_mset.sum_nonneg_leq_bound
tff(fact_4259_minus__shift__def,axiom,
    ! [R: code_natural,K: code_natural,L: code_natural] :
      minus_shift(R,K,L) = $ite(aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),K),L),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),R),K)),L),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),K),L)) ).

% minus_shift_def
tff(fact_4260_split__seed__def,axiom,
    ! [S: product_prod(code_natural,code_natural)] : split_seed(S) = aa(product_prod(code_natural,code_natural),product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),aa(fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)))),fun(product_prod(code_natural,code_natural),product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),product_case_prod(code_natural,code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),aTP_Lamp_sc(product_prod(code_natural,code_natural),fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)))),S)),S) ).

% split_seed_def
tff(fact_4261_log_Osimps,axiom,
    ! [B2: code_natural,I: code_natural] :
      log(B2,I) = $ite(
        ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less_eq(code_natural),B2),one_one(code_natural))
        | aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),I),B2) ),
        one_one(code_natural),
        aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),one_one(code_natural)),log(B2,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),I),B2))) ) ).

% log.simps
tff(fact_4262_log_Oelims,axiom,
    ! [X2: code_natural,Xa: code_natural,Y: code_natural] :
      ( ( log(X2,Xa) = Y )
     => ( Y = $ite(
            ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less_eq(code_natural),X2),one_one(code_natural))
            | aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),Xa),X2) ),
            one_one(code_natural),
            aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),one_one(code_natural)),log(X2,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),Xa),X2))) ) ) ) ).

% log.elims
tff(fact_4263_extract__def,axiom,
    ! [B: $tType,P: fun(B,$o),Xsa: list(B)] : extract(B,P,Xsa) = aa(list(B),option(product_prod(list(B),product_prod(B,list(B)))),case_list(option(product_prod(list(B),product_prod(B,list(B)))),B,none(product_prod(list(B),product_prod(B,list(B)))),aa(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B)))))),aTP_Lamp_sd(fun(B,$o),fun(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B))))))),P),Xsa)),dropWhile(B,aa(fun(B,$o),fun(B,$o),aa(fun($o,$o),fun(fun(B,$o),fun(B,$o)),comp($o,$o,B),fNot),P),Xsa)) ).

% extract_def
tff(fact_4264_drop__takeWhile,axiom,
    ! [B: $tType,I: nat,P: fun(B,$o),L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),aa(list(B),nat,size_size(list(B)),takeWhile(B,P,L)))
     => ( drop(B,I,takeWhile(B,P,L)) = takeWhile(B,P,drop(B,I,L)) ) ) ).

% drop_takeWhile
tff(fact_4265_eq__len__takeWhile__conv,axiom,
    ! [B: $tType,I: nat,P: fun(B,$o),L: list(B)] :
      ( ( I = aa(list(B),nat,size_size(list(B)),takeWhile(B,P,L)) )
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),aa(list(B),nat,size_size(list(B)),L))
        & ! [J2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J2),I)
           => aa(B,$o,P,aa(nat,B,nth(B,L),J2)) )
        & ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
         => ~ aa(B,$o,P,aa(nat,B,nth(B,L),I)) ) ) ) ).

% eq_len_takeWhile_conv
tff(fact_4266_less__length__takeWhile__conv,axiom,
    ! [B: $tType,I: nat,P: fun(B,$o),L: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),takeWhile(B,P,L)))
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I),aa(list(B),nat,size_size(list(B)),L))
        & ! [J2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J2),I)
           => aa(B,$o,P,aa(nat,B,nth(B,L),J2)) ) ) ) ).

% less_length_takeWhile_conv
tff(fact_4267_length__dropWhile__takeWhile,axiom,
    ! [B: $tType,X2: nat,P: fun(B,$o),Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X2),aa(list(B),nat,size_size(list(B)),dropWhile(B,P,Xsa)))
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),X2),aa(list(B),nat,size_size(list(B)),takeWhile(B,P,Xsa)))),aa(list(B),nat,size_size(list(B)),Xsa)) ) ).

% length_dropWhile_takeWhile
tff(fact_4268_dropWhile__nth,axiom,
    ! [B: $tType,J: nat,P: fun(B,$o),Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),J),aa(list(B),nat,size_size(list(B)),dropWhile(B,P,Xsa)))
     => ( aa(nat,B,nth(B,dropWhile(B,P,Xsa)),J) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),J),aa(list(B),nat,size_size(list(B)),takeWhile(B,P,Xsa)))) ) ) ).

% dropWhile_nth
tff(fact_4269_inc__shift__def,axiom,
    ! [V: code_natural,K: code_natural] :
      inc_shift(V,K) = $ite(V = K,one_one(code_natural),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),K),one_one(code_natural))) ).

% inc_shift_def
tff(fact_4270_log_Opelims,axiom,
    ! [X2: code_natural,Xa: code_natural,Y: code_natural] :
      ( ( log(X2,Xa) = Y )
     => ( aa(product_prod(code_natural,code_natural),$o,accp(product_prod(code_natural,code_natural),log_rel),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),X2),Xa))
       => ~ ( ( Y = $ite(
                  ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less_eq(code_natural),X2),one_one(code_natural))
                  | aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),Xa),X2) ),
                  one_one(code_natural),
                  aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),one_one(code_natural)),log(X2,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),Xa),X2))) ) )
           => ~ aa(product_prod(code_natural,code_natural),$o,accp(product_prod(code_natural,code_natural),log_rel),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),X2),Xa)) ) ) ) ).

% log.pelims
tff(fact_4271_Random_Orange__def,axiom,
    ! [K: code_natural] : range(K) = product_scomp(product_prod(code_natural,code_natural),code_natural,product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),iterate(code_natural,product_prod(code_natural,code_natural),log(aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2))))))))))))))))))))))))))))))),K),aTP_Lamp_sf(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))))),one_one(code_natural)),aTP_Lamp_sg(code_natural,fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)))),K)) ).

% Random.range_def
tff(fact_4272_Predicate_Oiterate__upto_Opinduct,axiom,
    ! [B: $tType,A0: fun(code_natural,B),A1: code_natural,A22: code_natural,P: fun(fun(code_natural,B),fun(code_natural,fun(code_natural,$o)))] :
      ( aa(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),$o,accp(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),iterate_upto_rel(B)),aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),aa(fun(code_natural,B),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,B),product_prod(code_natural,code_natural)),A0),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),A1),A22)))
     => ( ! [F3: fun(code_natural,B),N3: code_natural,M4: code_natural] :
            ( aa(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),$o,accp(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),iterate_upto_rel(B)),aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),aa(fun(code_natural,B),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,B),product_prod(code_natural,code_natural)),F3),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),N3),M4)))
           => ( ! [X: product_unit] :
                  ( ~ aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),M4),N3)
                 => aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),aa(fun(code_natural,B),fun(code_natural,fun(code_natural,$o)),P,F3),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),N3),one_one(code_natural))),M4) )
             => aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),aa(fun(code_natural,B),fun(code_natural,fun(code_natural,$o)),P,F3),N3),M4) ) )
       => aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),aa(fun(code_natural,B),fun(code_natural,fun(code_natural,$o)),P,A0),A1),A22) ) ) ).

% Predicate.iterate_upto.pinduct
tff(fact_4273_mset__size2elem,axiom,
    ! [B: $tType,P: multiset(B),Q3: B,Q4: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(multiset(B),nat,size_size(multiset(B)),P)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Q3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Q4),zero_zero(multiset(B))))),P)
       => ( P = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Q3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Q4),zero_zero(multiset(B)))) ) ) ) ).

% mset_size2elem
tff(fact_4274_scomp__apply,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,F: fun(C,product_prod(D,E)),G: fun(D,fun(E,B)),X2: C] : aa(C,B,product_scomp(C,D,E,B,F,G),X2) = aa(product_prod(D,E),B,aa(fun(D,fun(E,B)),fun(product_prod(D,E),B),product_case_prod(D,E,B),G),aa(C,product_prod(D,E),F,X2)) ).

% scomp_apply
tff(fact_4275_size__union,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B)] : aa(multiset(B),nat,size_size(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(multiset(B),nat,size_size(multiset(B)),M2)),aa(multiset(B),nat,size_size(multiset(B)),N5)) ).

% size_union
tff(fact_4276_scomp__scomp,axiom,
    ! [B: $tType,F4: $tType,G2: $tType,C: $tType,E: $tType,D: $tType,F: fun(B,product_prod(F4,G2)),G: fun(F4,fun(G2,product_prod(D,E))),Ha: fun(D,fun(E,C))] : product_scomp(B,D,E,C,product_scomp(B,F4,G2,product_prod(D,E),F,G),Ha) = product_scomp(B,F4,G2,C,F,aa(fun(D,fun(E,C)),fun(F4,fun(G2,C)),aTP_Lamp_sh(fun(F4,fun(G2,product_prod(D,E))),fun(fun(D,fun(E,C)),fun(F4,fun(G2,C))),G),Ha)) ).

% scomp_scomp
tff(fact_4277_scomp__Pair,axiom,
    ! [D: $tType,C: $tType,B: $tType,X2: fun(B,product_prod(C,D))] : product_scomp(B,C,D,product_prod(C,D),X2,product_Pair(C,D)) = X2 ).

% scomp_Pair
tff(fact_4278_Pair__scomp,axiom,
    ! [B: $tType,C: $tType,D: $tType,X2: D,F: fun(D,fun(B,C))] : product_scomp(B,D,B,C,aa(D,fun(B,product_prod(D,B)),product_Pair(D,B),X2),F) = aa(D,fun(B,C),F,X2) ).

% Pair_scomp
tff(fact_4279_scomp__def,axiom,
    ! [C: $tType,D: $tType,E: $tType,B: $tType,F: fun(B,product_prod(D,E)),G: fun(D,fun(E,C)),X: B] : aa(B,C,product_scomp(B,D,E,C,F,G),X) = aa(product_prod(D,E),C,aa(fun(D,fun(E,C)),fun(product_prod(D,E),C),product_case_prod(D,E,C),G),aa(B,product_prod(D,E),F,X)) ).

% scomp_def
tff(fact_4280_size__1__singleton__mset,axiom,
    ! [B: $tType,M2: multiset(B)] :
      ( ( aa(multiset(B),nat,size_size(multiset(B)),M2) = one_one(nat) )
     => ? [A5: B] : M2 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A5),zero_zero(multiset(B))) ) ).

% size_1_singleton_mset
tff(fact_4281_size__single,axiom,
    ! [B: $tType,B2: B] : aa(multiset(B),nat,size_size(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B)))) = one_one(nat) ).

% size_single
tff(fact_4282_iterate_Oelims,axiom,
    ! [B: $tType,C: $tType,X2: code_natural,Xa: fun(C,fun(B,product_prod(C,B))),Xb: C,Y: fun(B,product_prod(C,B))] :
      ( ( aa(C,fun(B,product_prod(C,B)),iterate(C,B,X2,Xa),Xb) = Y )
     => ( Y = $ite(X2 = zero_zero(code_natural),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Xb),product_scomp(B,C,B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),Xa,Xb),iterate(C,B,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),X2),one_one(code_natural)),Xa))) ) ) ).

% iterate.elims
tff(fact_4283_iterate_Osimps,axiom,
    ! [B: $tType,C: $tType,K: code_natural,F: fun(C,fun(B,product_prod(C,B))),X2: C] :
      aa(C,fun(B,product_prod(C,B)),iterate(C,B,K,F),X2) = $ite(K = zero_zero(code_natural),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),product_scomp(B,C,B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),F,X2),iterate(C,B,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),K),one_one(code_natural)),F))) ).

% iterate.simps
tff(fact_4284_size__mset__SucE,axiom,
    ! [B: $tType,A4: multiset(B),N: nat] :
      ( ( aa(multiset(B),nat,size_size(multiset(B)),A4) = aa(nat,nat,suc,N) )
     => ~ ! [A5: B,B8: multiset(B)] :
            ( ( A4 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A5),zero_zero(multiset(B)))),B8) )
           => ( aa(multiset(B),nat,size_size(multiset(B)),B8) != N ) ) ) ).

% size_mset_SucE
tff(fact_4285_scomp__unfold,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,X: fun(B,product_prod(C,D)),Xa3: fun(C,fun(D,E)),Xb2: B] : aa(B,E,product_scomp(B,C,D,E,X,Xa3),Xb2) = aa(D,E,aa(C,fun(D,E),Xa3,aa(product_prod(C,D),C,product_fst(C,D),aa(B,product_prod(C,D),X,Xb2))),aa(product_prod(C,D),D,product_snd(C,D),aa(B,product_prod(C,D),X,Xb2))) ).

% scomp_unfold
tff(fact_4286_mset__size__le1__cases,axiom,
    ! [B: $tType,M2: multiset(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(multiset(B),nat,size_size(multiset(B)),M2)),aa(nat,nat,suc,zero_zero(nat)))
     => ( ( M2 != zero_zero(multiset(B)) )
       => ~ ! [M4: B] : M2 != aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),M4),zero_zero(multiset(B))) ) ) ).

% mset_size_le1_cases
tff(fact_4287_iterate_Opelims,axiom,
    ! [B: $tType,C: $tType,X2: code_natural,Xa: fun(C,fun(B,product_prod(C,B))),Xb: C,Y: fun(B,product_prod(C,B))] :
      ( ( aa(C,fun(B,product_prod(C,B)),iterate(C,B,X2,Xa),Xb) = Y )
     => ( aa(product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),$o,accp(product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),iterate_rel(C,B)),aa(product_prod(fun(C,fun(B,product_prod(C,B))),C),product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),aa(code_natural,fun(product_prod(fun(C,fun(B,product_prod(C,B))),C),product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C))),product_Pair(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),X2),aa(C,product_prod(fun(C,fun(B,product_prod(C,B))),C),aa(fun(C,fun(B,product_prod(C,B))),fun(C,product_prod(fun(C,fun(B,product_prod(C,B))),C)),product_Pair(fun(C,fun(B,product_prod(C,B))),C),Xa),Xb)))
       => ~ ( ( Y = $ite(X2 = zero_zero(code_natural),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Xb),product_scomp(B,C,B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),Xa,Xb),iterate(C,B,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),X2),one_one(code_natural)),Xa))) )
           => ~ aa(product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),$o,accp(product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),iterate_rel(C,B)),aa(product_prod(fun(C,fun(B,product_prod(C,B))),C),product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),aa(code_natural,fun(product_prod(fun(C,fun(B,product_prod(C,B))),C),product_prod(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C))),product_Pair(code_natural,product_prod(fun(C,fun(B,product_prod(C,B))),C)),X2),aa(C,product_prod(fun(C,fun(B,product_prod(C,B))),C),aa(fun(C,fun(B,product_prod(C,B))),fun(C,product_prod(fun(C,fun(B,product_prod(C,B))),C)),product_Pair(fun(C,fun(B,product_prod(C,B))),C),Xa),Xb))) ) ) ) ).

% iterate.pelims
tff(fact_4288_size__Diff__singleton__if,axiom,
    ! [B: $tType,A4: multiset(B),X2: B] :
      aa(multiset(B),nat,size_size(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B))))) = $ite(member(B,X2,set_mset(B,A4)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(multiset(B),nat,size_size(multiset(B)),A4)),one_one(nat)),aa(multiset(B),nat,size_size(multiset(B)),A4)) ).

% size_Diff_singleton_if
tff(fact_4289_size__Diff__singleton,axiom,
    ! [B: $tType,X2: B,M2: multiset(B)] :
      ( member(B,X2,set_mset(B,M2))
     => ( aa(multiset(B),nat,size_size(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B))))) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(multiset(B),nat,size_size(multiset(B)),M2)),one_one(nat)) ) ) ).

% size_Diff_singleton
tff(fact_4290_size__diff__se,axiom,
    ! [B: $tType,T2: B,S2: multiset(B)] :
      ( member(B,T2,set_mset(B,S2))
     => ( aa(multiset(B),nat,size_size(multiset(B)),S2) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(multiset(B),nat,size_size(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),S2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),T2),zero_zero(multiset(B)))))),one_one(nat)) ) ) ).

% size_diff_se
tff(fact_4291_set__mset__union,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B)] : set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),set_mset(B,M2)),set_mset(B,N5)) ).

% set_mset_union
tff(fact_4292_mset__diff__cancel1elem,axiom,
    ! [B: $tType,A3: B,B5: multiset(B)] :
      ( ~ member(B,A3,set_mset(B,B5))
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))),B5) = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))) ) ) ).

% mset_diff_cancel1elem
tff(fact_4293_ex__Melem__conv,axiom,
    ! [B: $tType,A4: multiset(B)] :
      ( ? [X4: B] : member(B,X4,set_mset(B,A4))
    <=> ( A4 != zero_zero(multiset(B)) ) ) ).

% ex_Melem_conv
tff(fact_4294_union__iff,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B5: multiset(B)] :
      ( member(B,A3,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)))
    <=> ( member(B,A3,set_mset(B,A4))
        | member(B,A3,set_mset(B,B5)) ) ) ).

% union_iff
tff(fact_4295_mset__un__cases,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B5: multiset(B)] :
      ( member(B,A3,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)))
     => ( ~ member(B,A3,set_mset(B,A4))
       => member(B,A3,set_mset(B,B5)) ) ) ).

% mset_un_cases
tff(fact_4296_mset__left__cancel__union,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B5: multiset(B)] :
      ( member(B,A3,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)))
     => ( ~ member(B,A3,set_mset(B,A4))
       => member(B,A3,set_mset(B,B5)) ) ) ).

% mset_left_cancel_union
tff(fact_4297_mset__right__cancel__union,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B5: multiset(B)] :
      ( member(B,A3,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)))
     => ( ~ member(B,A3,set_mset(B,B5))
       => member(B,A3,set_mset(B,A4)) ) ) ).

% mset_right_cancel_union
tff(fact_4298_iterate_Ocases,axiom,
    ! [C: $tType,B: $tType,X2: product_prod(code_natural,product_prod(fun(B,fun(C,product_prod(B,C))),B))] :
      ~ ! [K3: code_natural,F3: fun(B,fun(C,product_prod(B,C))),X3: B] : X2 != aa(product_prod(fun(B,fun(C,product_prod(B,C))),B),product_prod(code_natural,product_prod(fun(B,fun(C,product_prod(B,C))),B)),aa(code_natural,fun(product_prod(fun(B,fun(C,product_prod(B,C))),B),product_prod(code_natural,product_prod(fun(B,fun(C,product_prod(B,C))),B))),product_Pair(code_natural,product_prod(fun(B,fun(C,product_prod(B,C))),B)),K3),aa(B,product_prod(fun(B,fun(C,product_prod(B,C))),B),aa(fun(B,fun(C,product_prod(B,C))),fun(B,product_prod(fun(B,fun(C,product_prod(B,C))),B)),product_Pair(fun(B,fun(C,product_prod(B,C))),B),F3),X3)) ).

% iterate.cases
tff(fact_4299_image__mset__cong__pair,axiom,
    ! [D: $tType,C: $tType,B: $tType,M2: multiset(product_prod(B,C)),F: fun(B,fun(C,D)),G: fun(B,fun(C,D))] :
      ( ! [X3: B,Y4: C] :
          ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4),set_mset(product_prod(B,C),M2))
         => ( aa(C,D,aa(B,fun(C,D),F,X3),Y4) = aa(C,D,aa(B,fun(C,D),G,X3),Y4) ) )
     => ( aa(multiset(product_prod(B,C)),multiset(D),image_mset(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),F)),M2) = aa(multiset(product_prod(B,C)),multiset(D),image_mset(product_prod(B,C),D,aa(fun(B,fun(C,D)),fun(product_prod(B,C),D),product_case_prod(B,C,D),G)),M2) ) ) ).

% image_mset_cong_pair
tff(fact_4300_multi__member__skip,axiom,
    ! [B: $tType,X2: B,XS: multiset(B),Y: B] :
      ( member(B,X2,set_mset(B,XS))
     => member(B,X2,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Y),zero_zero(multiset(B)))),XS))) ) ).

% multi_member_skip
tff(fact_4301_multi__member__this,axiom,
    ! [B: $tType,X2: B,XS: multiset(B)] : member(B,X2,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))),XS))) ).

% multi_member_this
tff(fact_4302_mset__right__cancel__elem,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B2: B] :
      ( member(B,A3,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B))))))
     => ( ( A3 != B2 )
       => member(B,A3,set_mset(B,A4)) ) ) ).

% mset_right_cancel_elem
tff(fact_4303_mset__left__cancel__elem,axiom,
    ! [B: $tType,A3: B,B2: B,A4: multiset(B)] :
      ( member(B,A3,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B)))),A4)))
     => ( ( A3 != B2 )
       => member(B,A3,set_mset(B,A4)) ) ) ).

% mset_left_cancel_elem
tff(fact_4304_mset__le__mono__add__single,axiom,
    ! [B: $tType,A3: B,Ys: multiset(B),B2: B,Ws: multiset(B)] :
      ( member(B,A3,set_mset(B,Ys))
     => ( member(B,B2,set_mset(B,Ws))
       => aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B))))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Ys),Ws)) ) ) ).

% mset_le_mono_add_single
tff(fact_4305_mset__union__subset__s,axiom,
    ! [B: $tType,A3: B,B5: multiset(B),C5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))),B5)),C5)
     => ( member(B,A3,set_mset(B,C5))
        & aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B5),C5) ) ) ).

% mset_union_subset_s
tff(fact_4306_mset__2dist2__cases,axiom,
    ! [B: $tType,A3: B,B2: B,A4: multiset(B),B5: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B))))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5))
     => ( ~ aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B))))),A4)
       => ( ~ aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B))))),B5)
         => ( ( member(B,A3,set_mset(B,A4))
             => ~ member(B,B2,set_mset(B,B5)) )
           => ~ ( member(B,A3,set_mset(B,B5))
               => ~ member(B,B2,set_mset(B,A4)) ) ) ) ) ) ).

% mset_2dist2_cases
tff(fact_4307_insert__DiffM2,axiom,
    ! [B: $tType,X2: B,M2: multiset(B)] :
      ( member(B,X2,set_mset(B,M2))
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B))))),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))) = M2 ) ) ).

% insert_DiffM2
tff(fact_4308_diff__union__single__conv,axiom,
    ! [B: $tType,A3: B,J4: multiset(B),I4: multiset(B)] :
      ( member(B,A3,set_mset(B,J4))
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I4),J4)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),J4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))))) ) ) ).

% diff_union_single_conv
tff(fact_4309_mset__un__single__un__cases,axiom,
    ! [B: $tType,A3: B,A4: multiset(B),B5: multiset(B),C5: multiset(B)] :
      ( ( aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),A4) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5) )
     => ( ( member(B,A3,set_mset(B,B5))
         => ( A4 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))))),C5) ) )
       => ~ ( member(B,A3,set_mset(B,C5))
           => ( A4 != aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),C5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))))) ) ) ) ) ).

% mset_un_single_un_cases
tff(fact_4310_diff__union__single__conv2,axiom,
    ! [B: $tType,A3: B,J4: multiset(B),I4: multiset(B)] :
      ( member(B,A3,set_mset(B,J4))
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),J4),I4)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B)))) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),J4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),zero_zero(multiset(B))))),I4) ) ) ).

% diff_union_single_conv2
tff(fact_4311_mset__union__diff__comm,axiom,
    ! [B: $tType,T2: B,S2: multiset(B),T5: multiset(B)] :
      ( member(B,T2,set_mset(B,S2))
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),T5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),S2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),T2),zero_zero(multiset(B))))) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),T5),S2)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),T2),zero_zero(multiset(B)))) ) ) ).

% mset_union_diff_comm
tff(fact_4312_mset__contains__eq,axiom,
    ! [B: $tType,M: B,M2: multiset(B)] :
      ( member(B,M,set_mset(B,M2))
    <=> ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),M),zero_zero(multiset(B)))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),M),zero_zero(multiset(B))))) = M2 ) ) ).

% mset_contains_eq
tff(fact_4313_mset__size1elem,axiom,
    ! [B: $tType,P: multiset(B),Q3: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(multiset(B),nat,size_size(multiset(B)),P)),one_one(nat))
     => ( member(B,Q3,set_mset(B,P))
       => ( P = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Q3),zero_zero(multiset(B))) ) ) ) ).

% mset_size1elem
tff(fact_4314_subset__mset_Osum__mset__mono,axiom,
    ! [C: $tType,B: $tType,K2: multiset(B),F: fun(B,multiset(C)),G: fun(B,multiset(C))] :
      ( ! [I2: B] :
          ( member(B,I2,set_mset(B,K2))
         => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),aa(B,multiset(C),F,I2)),aa(B,multiset(C),G,I2)) )
     => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),comm_monoid_sum_mset(multiset(C),plus_plus(multiset(C)),zero_zero(multiset(C)),aa(multiset(B),multiset(multiset(C)),image_mset(B,multiset(C),F),K2))),comm_monoid_sum_mset(multiset(C),plus_plus(multiset(C)),zero_zero(multiset(C)),aa(multiset(B),multiset(multiset(C)),image_mset(B,multiset(C),G),K2))) ) ).

% subset_mset.sum_mset_mono
tff(fact_4315_subset__mset_Osum__mset__0__iff,axiom,
    ! [B: $tType,M2: multiset(multiset(B))] :
      ( ( comm_monoid_sum_mset(multiset(B),plus_plus(multiset(B)),zero_zero(multiset(B)),M2) = zero_zero(multiset(B)) )
    <=> ! [X4: multiset(B)] :
          ( member(multiset(B),X4,set_mset(multiset(B),M2))
         => ( X4 = zero_zero(multiset(B)) ) ) ) ).

% subset_mset.sum_mset_0_iff
tff(fact_4316_wmsI,axiom,
    ! [A4: multiset(product_prod(nat,nat)),B5: multiset(product_prod(nat,nat)),Z7: multiset(product_prod(nat,nat))] :
      ( ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),set_mset(product_prod(nat,nat),A4)),set_mset(product_prod(nat,nat),B5)),fun_max_strict)
        | ( ( A4 = zero_zero(multiset(product_prod(nat,nat))) )
          & ( B5 = zero_zero(multiset(product_prod(nat,nat))) ) ) )
     => member(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_Pair(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),A4)),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),B5)),ms_weak) ) ).

% wmsI
tff(fact_4317_smsI,axiom,
    ! [A4: multiset(product_prod(nat,nat)),B5: multiset(product_prod(nat,nat)),Z7: multiset(product_prod(nat,nat))] :
      ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),set_mset(product_prod(nat,nat),A4)),set_mset(product_prod(nat,nat),B5)),fun_max_strict)
     => member(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_Pair(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),A4)),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),B5)),ms_strict) ) ).

% smsI
tff(fact_4318_ms__reduction__pair,axiom,
    fun_reduction_pair(multiset(product_prod(nat,nat)),aa(set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_prod(set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))))),aa(set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),fun(set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_prod(set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))))),product_Pair(set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),set(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))))),ms_strict),ms_weak)) ).

% ms_reduction_pair
tff(fact_4319_ms__strictI,axiom,
    ! [Z7: multiset(product_prod(nat,nat)),Z8: multiset(product_prod(nat,nat)),A4: multiset(product_prod(nat,nat)),B5: multiset(product_prod(nat,nat))] :
      ( pw_leq(Z7,Z8)
     => ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),set_mset(product_prod(nat,nat),A4)),set_mset(product_prod(nat,nat),B5)),fun_max_strict)
       => member(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_Pair(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),A4)),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z8),B5)),ms_strict) ) ) ).

% ms_strictI
tff(fact_4320_ms__weakI1,axiom,
    ! [Z7: multiset(product_prod(nat,nat)),Z8: multiset(product_prod(nat,nat)),A4: multiset(product_prod(nat,nat)),B5: multiset(product_prod(nat,nat))] :
      ( pw_leq(Z7,Z8)
     => ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),set_mset(product_prod(nat,nat),A4)),set_mset(product_prod(nat,nat),B5)),fun_max_strict)
       => member(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_Pair(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),A4)),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z8),B5)),ms_weak) ) ) ).

% ms_weakI1
tff(fact_4321_pw__leq__split,axiom,
    ! [X7: multiset(product_prod(nat,nat)),Y7: multiset(product_prod(nat,nat))] :
      ( pw_leq(X7,Y7)
     => ? [A10: multiset(product_prod(nat,nat)),B8: multiset(product_prod(nat,nat)),Z9: multiset(product_prod(nat,nat))] :
          ( ( X7 = aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),A10),Z9) )
          & ( Y7 = aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),B8),Z9) )
          & ( member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),set_mset(product_prod(nat,nat),A10)),set_mset(product_prod(nat,nat),B8)),fun_max_strict)
            | ( ( B8 = zero_zero(multiset(product_prod(nat,nat))) )
              & ( A10 = zero_zero(multiset(product_prod(nat,nat))) ) ) ) ) ) ).

% pw_leq_split
tff(fact_4322_ms__weakI2,axiom,
    ! [Z7: multiset(product_prod(nat,nat)),Z8: multiset(product_prod(nat,nat))] :
      ( pw_leq(Z7,Z8)
     => member(product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),product_prod(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)))),product_Pair(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z7),zero_zero(multiset(product_prod(nat,nat))))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),Z8),zero_zero(multiset(product_prod(nat,nat))))),ms_weak) ) ).

% ms_weakI2
tff(fact_4323_pw__leq__lstep,axiom,
    ! [X2: product_prod(nat,nat),Y: product_prod(nat,nat)] :
      ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X2),Y),fun_pair_leq)
     => pw_leq(aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),X2),zero_zero(multiset(product_prod(nat,nat)))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),Y),zero_zero(multiset(product_prod(nat,nat))))) ) ).

% pw_leq_lstep
tff(fact_4324_pw__leq__step,axiom,
    ! [X2: product_prod(nat,nat),Y: product_prod(nat,nat),X7: multiset(product_prod(nat,nat)),Y7: multiset(product_prod(nat,nat))] :
      ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X2),Y),fun_pair_leq)
     => ( pw_leq(X7,Y7)
       => pw_leq(aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),X2),zero_zero(multiset(product_prod(nat,nat))))),X7),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),Y),zero_zero(multiset(product_prod(nat,nat))))),Y7)) ) ) ).

% pw_leq_step
tff(fact_4325_pw__leq_Osimps,axiom,
    ! [A1: multiset(product_prod(nat,nat)),A22: multiset(product_prod(nat,nat))] :
      ( pw_leq(A1,A22)
    <=> ( ( ( A1 = zero_zero(multiset(product_prod(nat,nat))) )
          & ( A22 = zero_zero(multiset(product_prod(nat,nat))) ) )
        | ? [X4: product_prod(nat,nat),Y3: product_prod(nat,nat),X9: multiset(product_prod(nat,nat)),Y8: multiset(product_prod(nat,nat))] :
            ( ( A1 = aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),X4),zero_zero(multiset(product_prod(nat,nat))))),X9) )
            & ( A22 = aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),Y3),zero_zero(multiset(product_prod(nat,nat))))),Y8) )
            & member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X4),Y3),fun_pair_leq)
            & pw_leq(X9,Y8) ) ) ) ).

% pw_leq.simps
tff(fact_4326_pw__leq_Ocases,axiom,
    ! [A1: multiset(product_prod(nat,nat)),A22: multiset(product_prod(nat,nat))] :
      ( pw_leq(A1,A22)
     => ( ( ( A1 = zero_zero(multiset(product_prod(nat,nat))) )
         => ( A22 != zero_zero(multiset(product_prod(nat,nat))) ) )
       => ~ ! [X3: product_prod(nat,nat),Y4: product_prod(nat,nat),X10: multiset(product_prod(nat,nat))] :
              ( ( A1 = aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),X3),zero_zero(multiset(product_prod(nat,nat))))),X10) )
             => ! [Y9: multiset(product_prod(nat,nat))] :
                  ( ( A22 = aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(multiset(product_prod(nat,nat)),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),plus_plus(multiset(product_prod(nat,nat))),aa(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat)),aa(product_prod(nat,nat),fun(multiset(product_prod(nat,nat)),multiset(product_prod(nat,nat))),add_mset(product_prod(nat,nat)),Y4),zero_zero(multiset(product_prod(nat,nat))))),Y9) )
                 => ( member(product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat)),aa(product_prod(nat,nat),fun(product_prod(nat,nat),product_prod(product_prod(nat,nat),product_prod(nat,nat))),product_Pair(product_prod(nat,nat),product_prod(nat,nat)),X3),Y4),fun_pair_leq)
                   => ~ pw_leq(X10,Y9) ) ) ) ) ) ).

% pw_leq.cases
tff(fact_4327_mult1E,axiom,
    ! [B: $tType,N5: multiset(B),M2: multiset(B),R: set(product_prod(B,B))] :
      ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),N5),M2),mult1(B,R))
     => ~ ! [A5: B,M0: multiset(B)] :
            ( ( M2 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A5),M0) )
           => ! [K9: multiset(B)] :
                ( ( N5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M0),K9) )
               => ~ ! [B6: B] :
                      ( member(B,B6,set_mset(B,K9))
                     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B6),A5),R) ) ) ) ) ).

% mult1E
tff(fact_4328_mult1I,axiom,
    ! [B: $tType,M2: multiset(B),A3: B,M02: multiset(B),N5: multiset(B),K2: multiset(B),R: set(product_prod(B,B))] :
      ( ( M2 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),M02) )
     => ( ( N5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M02),K2) )
       => ( ! [B3: B] :
              ( member(B,B3,set_mset(B,K2))
             => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A3),R) )
         => member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),N5),M2),mult1(B,R)) ) ) ) ).

% mult1I
tff(fact_4329_less__add,axiom,
    ! [B: $tType,N5: multiset(B),A3: B,M02: multiset(B),R: set(product_prod(B,B))] :
      ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),N5),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),M02)),mult1(B,R))
     => ( ? [M8: multiset(B)] :
            ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),M8),M02),mult1(B,R))
            & ( N5 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),M8) ) )
        | ? [K9: multiset(B)] :
            ( ! [B6: B] :
                ( member(B,B6,set_mset(B,K9))
               => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B6),A3),R) )
            & ( N5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M02),K9) ) ) ) ) ).

% less_add
tff(fact_4330_one__step__implies__mult,axiom,
    ! [B: $tType,J4: multiset(B),K2: multiset(B),R: set(product_prod(B,B)),I4: multiset(B)] :
      ( ( J4 != zero_zero(multiset(B)) )
     => ( ! [X3: B] :
            ( member(B,X3,set_mset(B,K2))
           => ? [Xa3: B] :
                ( member(B,Xa3,set_mset(B,J4))
                & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Xa3),R) ) )
       => member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I4),K2)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I4),J4)),mult(B,R)) ) ) ).

% one_step_implies_mult
tff(fact_4331_not__less__empty,axiom,
    ! [B: $tType,M2: multiset(B),R: set(product_prod(B,B))] : ~ member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),M2),zero_zero(multiset(B))),mult1(B,R)) ).

% not_less_empty
tff(fact_4332_mult1__union,axiom,
    ! [B: $tType,B5: multiset(B),D4: multiset(B),R: set(product_prod(B,B)),C5: multiset(B)] :
      ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),B5),D4),mult1(B,R))
     => member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),B5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),D4)),mult1(B,R)) ) ).

% mult1_union
tff(fact_4333_mult1__lessE,axiom,
    ! [B: $tType,N5: multiset(B),M2: multiset(B),R: fun(B,fun(B,$o))] :
      ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),N5),M2),mult1(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R))))
     => ( asymp(B,R)
       => ~ ! [A5: B,M0: multiset(B)] :
              ( ( M2 = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A5),M0) )
             => ! [K9: multiset(B)] :
                  ( ( N5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M0),K9) )
                 => ( ~ member(B,A5,set_mset(B,K9))
                   => ~ ! [B6: B] :
                          ( member(B,B6,set_mset(B,K9))
                         => aa(B,$o,aa(B,fun(B,$o),R,B6),A5) ) ) ) ) ) ) ).

% mult1_lessE
tff(fact_4334_in__mset__fold__plus__iff,axiom,
    ! [B: $tType,X2: B,M2: multiset(B),NN: multiset(multiset(B))] :
      ( member(B,X2,set_mset(B,fold_mset(multiset(B),multiset(B),plus_plus(multiset(B)),M2,NN)))
    <=> ( member(B,X2,set_mset(B,M2))
        | ? [N8: multiset(B)] :
            ( member(multiset(B),N8,set_mset(multiset(B),NN))
            & member(B,X2,set_mset(B,N8)) ) ) ) ).

% in_mset_fold_plus_iff
tff(fact_4335_mult__implies__one__step,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),M2: multiset(B),N5: multiset(B)] :
      ( trans(B,R)
     => ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),M2),N5),mult(B,R))
       => ? [I7: multiset(B),J5: multiset(B)] :
            ( ( N5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I7),J5) )
            & ? [K9: multiset(B)] :
                ( ( M2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I7),K9) )
                & ( J5 != zero_zero(multiset(B)) )
                & ! [X: B] :
                    ( member(B,X,set_mset(B,K9))
                   => ? [Xa4: B] :
                        ( member(B,Xa4,set_mset(B,J5))
                        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa4),R) ) ) ) ) ) ) ).

% mult_implies_one_step
tff(fact_4336_mult1__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : mult1(B,R) = aa(fun(product_prod(multiset(B),multiset(B)),$o),set(product_prod(multiset(B),multiset(B))),collect(product_prod(multiset(B),multiset(B))),aa(fun(multiset(B),fun(multiset(B),$o)),fun(product_prod(multiset(B),multiset(B)),$o),product_case_prod(multiset(B),multiset(B),$o),aTP_Lamp_si(set(product_prod(B,B)),fun(multiset(B),fun(multiset(B),$o)),R))) ).

% mult1_def
tff(fact_4337_trans__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( trans(B,R)
    <=> ! [X4: B,Y3: B,Z4: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Y3),R)
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y3),Z4),R)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Z4),R) ) ) ) ).

% trans_def
tff(fact_4338_transI,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ! [X3: B,Y4: B,Z3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R)
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Z3),R) ) )
     => trans(B,R) ) ).

% transI
tff(fact_4339_transE,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: B,Y: B,Z2: B] :
      ( trans(B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),R)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),R) ) ) ) ).

% transE
tff(fact_4340_transD,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: B,Y: B,Z2: B] :
      ( trans(B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),R)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),R) ) ) ) ).

% transD
tff(fact_4341_lexord__trans,axiom,
    ! [B: $tType,X2: list(B),Y: list(B),R: set(product_prod(B,B)),Z2: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lexord(B,R))
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Y),Z2),lexord(B,R))
       => ( trans(B,R)
         => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Z2),lexord(B,R)) ) ) ) ).

% lexord_trans
tff(fact_4342_lenlex__trans,axiom,
    ! [B: $tType,X2: list(B),Y: list(B),R: set(product_prod(B,B)),Z2: list(B)] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),lenlex(B,R))
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Y),Z2),lenlex(B,R))
       => ( trans(B,R)
         => member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Z2),lenlex(B,R)) ) ) ) ).

% lenlex_trans
tff(fact_4343_union__fold__mset__add__mset,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5) = fold_mset(B,multiset(B),add_mset(B),A4,B5) ).

% union_fold_mset_add_mset
tff(fact_4344_trans__singleton,axiom,
    ! [B: $tType,A3: B] : trans(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A3)),bot_bot(set(product_prod(B,B))))) ).

% trans_singleton
tff(fact_4345_trans__rtrancl__eq__reflcl,axiom,
    ! [B: $tType,A4: set(product_prod(B,B))] :
      ( trans(B,A4)
     => ( transitive_rtrancl(B,A4) = aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),A4),id2(B)) ) ) ).

% trans_rtrancl_eq_reflcl
tff(fact_4346_comp__fun__commute_Ofold__mset__union,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C)),S: C,M2: multiset(B),N5: multiset(B)] :
      ( finite6289374366891150609ommute(B,C,F)
     => ( fold_mset(B,C,F,S,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = fold_mset(B,C,F,fold_mset(B,C,F,S,M2),N5) ) ) ).

% comp_fun_commute.fold_mset_union
tff(fact_4347_trans__join,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( trans(B,R)
    <=> ! [X4: product_prod(B,B)] :
          ( member(product_prod(B,B),X4,R)
         => aa(product_prod(B,B),$o,aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aTP_Lamp_sk(set(product_prod(B,B)),fun(B,fun(B,$o)),R)),X4) ) ) ).

% trans_join
tff(fact_4348_Image__absorb__rtrancl,axiom,
    ! [B: $tType,A4: set(product_prod(B,B)),B5: set(B),C5: set(B)] :
      ( trans(B,A4)
     => ( refl_on(B,B5,A4)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),C5),B5)
         => ( image(B,B,transitive_rtrancl(B,A4),C5) = image(B,B,A4,C5) ) ) ) ) ).

% Image_absorb_rtrancl
tff(fact_4349_wf__finite__segments,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( irrefl(B,R)
     => ( trans(B,R)
       => ( ! [X3: B] : finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),aTP_Lamp_sl(set(product_prod(B,B)),fun(B,fun(B,$o)),R),X3)))
         => wf(B,R) ) ) ) ).

% wf_finite_segments
tff(fact_4350_mult__cancel__add__mset,axiom,
    ! [B: $tType,S: set(product_prod(B,B)),Uu: B,X7: multiset(B),Y7: multiset(B)] :
      ( trans(B,S)
     => ( irrefl(B,S)
       => ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Uu),X7)),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),Uu),Y7)),mult(B,S))
        <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),X7),Y7),mult(B,S)) ) ) ) ).

% mult_cancel_add_mset
tff(fact_4351_mult__cancel,axiom,
    ! [B: $tType,S: set(product_prod(B,B)),X7: multiset(B),Z7: multiset(B),Y7: multiset(B)] :
      ( trans(B,S)
     => ( irrefl(B,S)
       => ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X7),Z7)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Y7),Z7)),mult(B,S))
        <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),X7),Y7),mult(B,S)) ) ) ) ).

% mult_cancel
tff(fact_4352_mult__cancel__max,axiom,
    ! [B: $tType,S: set(product_prod(B,B)),X7: multiset(B),Y7: multiset(B)] :
      ( trans(B,S)
     => ( irrefl(B,S)
       => ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),X7),Y7),mult(B,S))
        <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),X7),Y7)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),Y7),X7)),mult(B,S)) ) ) ) ).

% mult_cancel_max
tff(fact_4353_multeqp__code__iff__reflcl__mult,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),P: fun(B,fun(B,$o)),N5: multiset(B),M2: multiset(B)] :
      ( irrefl(B,R4)
     => ( trans(B,R4)
       => ( ! [X3: B,Y4: B] :
              ( aa(B,$o,aa(B,fun(B,$o),P,X3),Y4)
            <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R4) )
         => ( multeqp_code(B,P,N5,M2)
          <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),N5),M2),aa(set(product_prod(multiset(B),multiset(B))),set(product_prod(multiset(B),multiset(B))),aa(set(product_prod(multiset(B),multiset(B))),fun(set(product_prod(multiset(B),multiset(B))),set(product_prod(multiset(B),multiset(B)))),sup_sup(set(product_prod(multiset(B),multiset(B)))),mult(B,R4)),id2(multiset(B)))) ) ) ) ) ).

% multeqp_code_iff_reflcl_mult
tff(fact_4354_multp__code__iff__mult,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),P: fun(B,fun(B,$o)),N5: multiset(B),M2: multiset(B)] :
      ( irrefl(B,R4)
     => ( trans(B,R4)
       => ( ! [X3: B,Y4: B] :
              ( aa(B,$o,aa(B,fun(B,$o),P,X3),Y4)
            <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R4) )
         => ( multp_code(B,P,N5,M2)
          <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),N5),M2),mult(B,R4)) ) ) ) ) ).

% multp_code_iff_mult
tff(fact_4355_max__ext__eq,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : max_ext(B,R4) = aa(fun(product_prod(set(B),set(B)),$o),set(product_prod(set(B),set(B))),collect(product_prod(set(B),set(B))),aa(fun(set(B),fun(set(B),$o)),fun(product_prod(set(B),set(B)),$o),product_case_prod(set(B),set(B),$o),aTP_Lamp_sm(set(product_prod(B,B)),fun(set(B),fun(set(B),$o)),R4))) ).

% max_ext_eq
tff(fact_4356_init__seg__of__def,axiom,
    ! [B: $tType] : init_seg_of(B) = aa(fun(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),$o),set(product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),collect(product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),aa(fun(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o)),fun(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),$o),product_case_prod(set(product_prod(B,B)),set(product_prod(B,B)),$o),aTP_Lamp_sn(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o)))) ).

% init_seg_of_def
tff(fact_4357_refl__on__init__seg__of,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R),init_seg_of(B)) ).

% refl_on_init_seg_of
tff(fact_4358_antisym__init__seg__of,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),S: set(product_prod(B,B))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),S),init_seg_of(B))
     => ( member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),S),R),init_seg_of(B))
       => ( R = S ) ) ) ).

% antisym_init_seg_of
tff(fact_4359_trans__init__seg__of,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),S: set(product_prod(B,B)),T2: set(product_prod(B,B))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),S),init_seg_of(B))
     => ( member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),S),T2),init_seg_of(B))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),T2),init_seg_of(B)) ) ) ).

% trans_init_seg_of
tff(fact_4360_Image__def,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(C,B)),S: set(C)] : image(C,B,R,S) = aa(fun(B,$o),set(B),collect(B),aa(set(C),fun(B,$o),aTP_Lamp_so(set(product_prod(C,B)),fun(set(C),fun(B,$o)),R),S)) ).

% Image_def
tff(fact_4361_initial__segment__of__Diff,axiom,
    ! [B: $tType,P3: set(product_prod(B,B)),Q3: set(product_prod(B,B)),S: set(product_prod(B,B))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),P3),Q3),init_seg_of(B))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),P3),S)),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),Q3),S)),init_seg_of(B)) ) ).

% initial_segment_of_Diff
tff(fact_4362_min__ext__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : min_ext(B,R) = aa(fun(product_prod(set(B),set(B)),$o),set(product_prod(set(B),set(B))),collect(product_prod(set(B),set(B))),aTP_Lamp_sp(set(product_prod(B,B)),fun(product_prod(set(B),set(B)),$o),R)) ).

% min_ext_def
tff(fact_4363_map__project__def,axiom,
    ! [B: $tType,C: $tType,F: fun(C,option(B)),A4: set(C)] : map_project(C,B,F,A4) = aa(fun(B,$o),set(B),collect(B),aa(set(C),fun(B,$o),aTP_Lamp_sq(fun(C,option(B)),fun(set(C),fun(B,$o)),F),A4)) ).

% map_project_def
tff(fact_4364_Chains__init__seg__of__Union,axiom,
    ! [B: $tType,R4: set(set(product_prod(B,B))),R: set(product_prod(B,B))] :
      ( member(set(set(product_prod(B,B))),R4,chains(set(product_prod(B,B)),init_seg_of(B)))
     => ( member(set(product_prod(B,B)),R,R4)
       => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),aa(set(set(product_prod(B,B))),set(product_prod(B,B)),complete_Sup_Sup(set(product_prod(B,B))),R4)),init_seg_of(B)) ) ) ).

% Chains_init_seg_of_Union
tff(fact_4365_mult__cancel__max0,axiom,
    ! [B: $tType,S: set(product_prod(B,B)),X7: multiset(B),Y7: multiset(B)] :
      ( trans(B,S)
     => ( irrefl(B,S)
       => ( member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),X7),Y7),mult(B,S))
        <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),X7),inter_mset(B,X7,Y7))),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),Y7),inter_mset(B,X7,Y7))),mult(B,S)) ) ) ) ).

% mult_cancel_max0
tff(fact_4366_sum__mset_Oremove,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [X2: B,A4: multiset(B)] :
          ( member(B,X2,set_mset(B,A4))
         => ( aa(multiset(B),B,comm_m7189776963980413722m_mset(B),A4) = aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),zero_zero(multiset(B)))))) ) ) ) ).

% sum_mset.remove
tff(fact_4367_sum__mset_Oadd__mset,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [X2: B,N5: multiset(B)] : aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),X2),N5)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),N5)) ) ).

% sum_mset.add_mset
tff(fact_4368_sum__mset_Ounion,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M2: multiset(B),N5: multiset(B)] : aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),M2)),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),N5)) ) ).

% sum_mset.union
tff(fact_4369_sum__mset_Oinsert,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(C,B),X2: C,A4: multiset(C)] : aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,G),aa(multiset(C),multiset(C),aa(C,fun(multiset(C),multiset(C)),add_mset(C),X2),A4))) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(C,B,G,X2)),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,G),A4))) ) ).

% sum_mset.insert
tff(fact_4370_inter__union__distrib__right,axiom,
    ! [B: $tType,C5: multiset(B),A4: multiset(B),B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),inter_mset(B,A4,B5)) = inter_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),B5)) ).

% inter_union_distrib_right
tff(fact_4371_inter__union__distrib__left,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),inter_mset(B,A4,B5)),C5) = inter_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),C5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5)) ).

% inter_union_distrib_left
tff(fact_4372_inter__subset__eq__union,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),inter_mset(B,A4,B5)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) ).

% inter_subset_eq_union
tff(fact_4373_inter__mset__empty__distrib__left,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B)] :
      ( ( inter_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5),C5) = zero_zero(multiset(B)) )
    <=> ( ( inter_mset(B,A4,C5) = zero_zero(multiset(B)) )
        & ( inter_mset(B,B5,C5) = zero_zero(multiset(B)) ) ) ) ).

% inter_mset_empty_distrib_left
tff(fact_4374_inter__mset__empty__distrib__right,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B)] :
      ( ( inter_mset(B,A4,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5)) = zero_zero(multiset(B)) )
    <=> ( ( inter_mset(B,A4,B5) = zero_zero(multiset(B)) )
        & ( inter_mset(B,A4,C5) = zero_zero(multiset(B)) ) ) ) ).

% inter_mset_empty_distrib_right
tff(fact_4375_sum__mset_Odistrib,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [G: fun(C,B),Ha: fun(C,B),A4: multiset(C)] : aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,aa(fun(C,B),fun(C,B),aTP_Lamp_cb(fun(C,B),fun(fun(C,B),fun(C,B)),G),Ha)),A4)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,G),A4))),aa(multiset(B),B,comm_m7189776963980413722m_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,Ha),A4))) ) ).

% sum_mset.distrib
tff(fact_4376_size__eq__sum__mset,axiom,
    ! [B: $tType,M2: multiset(B)] : aa(multiset(B),nat,size_size(multiset(B)),M2) = aa(multiset(nat),nat,comm_m7189776963980413722m_mset(nat),aa(multiset(B),multiset(nat),image_mset(B,nat,aTP_Lamp_hz(B,nat)),M2)) ).

% size_eq_sum_mset
tff(fact_4377_multiset__union__diff__commute,axiom,
    ! [B: $tType,B5: multiset(B),C5: multiset(B),A4: multiset(B)] :
      ( ( inter_mset(B,B5,C5) = zero_zero(multiset(B)) )
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),C5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),A4),C5)),B5) ) ) ).

% multiset_union_diff_commute
tff(fact_4378_sum__mset_Oeq__fold,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [M2: multiset(B)] : aa(multiset(B),B,comm_m7189776963980413722m_mset(B),M2) = fold_mset(B,B,plus_plus(B),zero_zero(B),M2) ) ).

% sum_mset.eq_fold
tff(fact_4379_Chains__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : chains(B,R) = aa(fun(set(B),$o),set(set(B)),collect(set(B)),aTP_Lamp_sr(set(product_prod(B,B)),fun(set(B),$o),R)) ).

% Chains_def
tff(fact_4380_Chains__subset_H,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( refl_on(B,top_top(set(B)),R)
     => aa(set(set(B)),$o,aa(set(set(B)),fun(set(set(B)),$o),ord_less_eq(set(set(B))),aa(fun(set(B),$o),set(set(B)),collect(set(B)),pred_chain(B,top_top(set(B)),aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R)))),chains(B,R)) ) ).

% Chains_subset'
tff(fact_4381_Chains__subset,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : aa(set(set(B)),$o,aa(set(set(B)),fun(set(set(B)),$o),ord_less_eq(set(set(B))),chains(B,R)),aa(fun(set(B),$o),set(set(B)),collect(set(B)),pred_chain(B,top_top(set(B)),aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R)))) ).

% Chains_subset
tff(fact_4382_Chains__alt__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( refl_on(B,top_top(set(B)),R)
     => ( chains(B,R) = aa(fun(set(B),$o),set(set(B)),collect(set(B)),pred_chain(B,top_top(set(B)),aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R))) ) ) ).

% Chains_alt_def
tff(fact_4383_iter_H_Ocases,axiom,
    ! [B: $tType] :
      ( quickcheck_random(B)
     => ! [X2: product_prod(itself(B),product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural))))] :
          ~ ! [T3: itself(B),Nrandom: code_natural,Sz: code_natural,Seed: product_prod(code_natural,code_natural)] : X2 != aa(product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural))),product_prod(itself(B),product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural)))),aa(itself(B),fun(product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural))),product_prod(itself(B),product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural))))),product_Pair(itself(B),product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural)))),T3),aa(product_prod(code_natural,product_prod(code_natural,code_natural)),product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural))),aa(code_natural,fun(product_prod(code_natural,product_prod(code_natural,code_natural)),product_prod(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural)))),product_Pair(code_natural,product_prod(code_natural,product_prod(code_natural,code_natural))),Nrandom),aa(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),product_Pair(code_natural,product_prod(code_natural,code_natural)),Sz),Seed))) ) ).

% iter'.cases
tff(fact_4384_multp__def,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),M2: multiset(B),N5: multiset(B)] :
      ( multp(B,R,M2,N5)
    <=> member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),M2),N5),mult(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% multp_def
tff(fact_4385_AboveS__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B)] : order_AboveS(B,R,A4) = aa(fun(B,$o),set(B),collect(B),aa(set(B),fun(B,$o),aTP_Lamp_ss(set(product_prod(B,B)),fun(set(B),fun(B,$o)),R),A4)) ).

% AboveS_def
tff(fact_4386_lexordp__conv__lexord,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B),Ys: list(B)] :
          ( ord_lexordp(B,Xsa,Ys)
        <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Xsa),Ys),lexord(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),ord_less(B))))) ) ) ).

% lexordp_conv_lexord
tff(fact_4387_select__weight__cons__zero,axiom,
    ! [B: $tType,X2: B,Xsa: list(product_prod(code_natural,B))] : select_weight(B,aa(list(product_prod(code_natural,B)),list(product_prod(code_natural,B)),aa(product_prod(code_natural,B),fun(list(product_prod(code_natural,B)),list(product_prod(code_natural,B))),cons(product_prod(code_natural,B)),aa(B,product_prod(code_natural,B),aa(code_natural,fun(B,product_prod(code_natural,B)),product_Pair(code_natural,B),zero_zero(code_natural)),X2)),Xsa)) = select_weight(B,Xsa) ).

% select_weight_cons_zero
tff(fact_4388_one__step__implies__multp,axiom,
    ! [B: $tType,J4: multiset(B),K2: multiset(B),R: fun(B,fun(B,$o)),I4: multiset(B)] :
      ( ( J4 != zero_zero(multiset(B)) )
     => ( ! [X3: B] :
            ( member(B,X3,set_mset(B,K2))
           => ? [Xa3: B] :
                ( member(B,Xa3,set_mset(B,J4))
                & aa(B,$o,aa(B,fun(B,$o),R,X3),Xa3) ) )
       => multp(B,R,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I4),K2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I4),J4)) ) ) ).

% one_step_implies_multp
tff(fact_4389_select__weight__select,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( Xsa != nil(B) )
     => ( select_weight(B,aa(list(B),list(product_prod(code_natural,B)),map(B,product_prod(code_natural,B),aa(code_natural,fun(B,product_prod(code_natural,B)),product_Pair(code_natural,B),one_one(code_natural))),Xsa)) = select(B,Xsa) ) ) ).

% select_weight_select
tff(fact_4390_wo__rel_Osuc__greater,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),B5: set(B),B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),field2(B,R))
       => ( ( order_AboveS(B,R,B5) != bot_bot(set(B)) )
         => ( member(B,B2,B5)
           => ( ( bNF_Wellorder_wo_suc(B,R,B5) != B2 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),bNF_Wellorder_wo_suc(B,R,B5)),R) ) ) ) ) ) ).

% wo_rel.suc_greater
tff(fact_4391_wo__rel_Oequals__suc__AboveS,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),B5: set(B),A3: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),field2(B,R))
       => ( member(B,A3,order_AboveS(B,R,B5))
         => ( ! [A11: B] :
                ( member(B,A11,order_AboveS(B,R,B5))
               => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),A11),R) )
           => ( A3 = bNF_Wellorder_wo_suc(B,R,B5) ) ) ) ) ) ).

% wo_rel.equals_suc_AboveS
tff(fact_4392_wo__rel_Osuc__least__AboveS,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B5: set(B)] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( member(B,A3,order_AboveS(B,R,B5))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),bNF_Wellorder_wo_suc(B,R,B5)),A3),R) ) ) ).

% wo_rel.suc_least_AboveS
tff(fact_4393_wo__rel_Osuc__ofilter__in,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B),B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( order_ofilter(B,R,A4)
       => ( ( order_AboveS(B,R,A4) != bot_bot(set(B)) )
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),bNF_Wellorder_wo_suc(B,R,A4)),R)
           => ( ( B2 != bNF_Wellorder_wo_suc(B,R,A4) )
             => member(B,B2,A4) ) ) ) ) ) ).

% wo_rel.suc_ofilter_in
tff(fact_4394_slice__head,axiom,
    ! [B: $tType,From: nat,To: nat,Xsa: list(B)] :
      ( 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(B),nat,size_size(list(B)),Xsa))
       => ( hd(B,slice(B,From,To,Xsa)) = aa(nat,B,nth(B,Xsa),From) ) ) ) ).

% slice_head
tff(fact_4395_gen__length__def,axiom,
    ! [B: $tType,N: nat,Xsa: list(B)] : gen_length(B,N,Xsa) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),aa(list(B),nat,size_size(list(B)),Xsa)) ).

% gen_length_def
tff(fact_4396_subset__mset_Osum__pos2,axiom,
    ! [C: $tType,B: $tType,I4: set(B),I: B,F: fun(B,multiset(C))] :
      ( finite_finite2(B,I4)
     => ( member(B,I,I4)
       => ( subset_mset(C,zero_zero(multiset(C)),aa(B,multiset(C),F,I))
         => ( ! [I2: B] :
                ( member(B,I2,I4)
               => aa(multiset(C),$o,aa(multiset(C),fun(multiset(C),$o),subseteq_mset(C),zero_zero(multiset(C))),aa(B,multiset(C),F,I2)) )
           => subset_mset(C,zero_zero(multiset(C)),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,I4)) ) ) ) ) ).

% subset_mset.sum_pos2
tff(fact_4397_subset__mset_Oadd__less__cancel__right,axiom,
    ! [B: $tType,A3: multiset(B),C2: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2))
    <=> subset_mset(B,A3,B2) ) ).

% subset_mset.add_less_cancel_right
tff(fact_4398_subset__mset_Oadd__less__cancel__left,axiom,
    ! [B: $tType,C2: multiset(B),A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2))
    <=> subset_mset(B,A3,B2) ) ).

% subset_mset.add_less_cancel_left
tff(fact_4399_subset__mset_Oadd__less__same__cancel1,axiom,
    ! [B: $tType,B2: multiset(B),A3: multiset(B)] :
      ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),A3),B2)
    <=> subset_mset(B,A3,zero_zero(multiset(B))) ) ).

% subset_mset.add_less_same_cancel1
tff(fact_4400_subset__mset_Oadd__less__same__cancel2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2),B2)
    <=> subset_mset(B,A3,zero_zero(multiset(B))) ) ).

% subset_mset.add_less_same_cancel2
tff(fact_4401_subset__mset_Oless__add__same__cancel1,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,A3,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2))
    <=> subset_mset(B,zero_zero(multiset(B)),B2) ) ).

% subset_mset.less_add_same_cancel1
tff(fact_4402_subset__mset_Oless__add__same__cancel2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,A3,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),A3))
    <=> subset_mset(B,zero_zero(multiset(B)),B2) ) ).

% subset_mset.less_add_same_cancel2
tff(fact_4403_subset__mset_Oadd__less__imp__less__right,axiom,
    ! [B: $tType,A3: multiset(B),C2: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2))
     => subset_mset(B,A3,B2) ) ).

% subset_mset.add_less_imp_less_right
tff(fact_4404_subset__mset_Oadd__less__imp__less__left,axiom,
    ! [B: $tType,C2: multiset(B),A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2))
     => subset_mset(B,A3,B2) ) ).

% subset_mset.add_less_imp_less_left
tff(fact_4405_subset__mset_Oadd__strict__right__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( subset_mset(B,A3,B2)
     => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),C2)) ) ).

% subset_mset.add_strict_right_mono
tff(fact_4406_subset__mset_Oadd__strict__left__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( subset_mset(B,A3,B2)
     => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),A3),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C2),B2)) ) ).

% subset_mset.add_strict_left_mono
tff(fact_4407_subset__mset_Oadd__strict__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B),D3: multiset(B)] :
      ( subset_mset(B,A3,B2)
     => ( subset_mset(B,C2,D3)
       => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),D3)) ) ) ).

% subset_mset.add_strict_mono
tff(fact_4408_hd__zip,axiom,
    ! [B: $tType,C: $tType,Xsa: list(B),Ys: list(C)] :
      ( ( Xsa != nil(B) )
     => ( ( Ys != nil(C) )
       => ( hd(product_prod(B,C),zip(B,C,Xsa,Ys)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),hd(B,Xsa)),hd(C,Ys)) ) ) ) ).

% hd_zip
tff(fact_4409_subset__mset_Oadd__le__less__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B),D3: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),B2)
     => ( subset_mset(B,C2,D3)
       => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),D3)) ) ) ).

% subset_mset.add_le_less_mono
tff(fact_4410_subset__mset_Oadd__less__le__mono,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B),D3: multiset(B)] :
      ( subset_mset(B,A3,B2)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),C2),D3)
       => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B2),D3)) ) ) ).

% subset_mset.add_less_le_mono
tff(fact_4411_subset__mset_OlessE,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,A3,B2)
     => ~ ! [C3: multiset(B)] :
            ( ( B2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C3) )
           => ( C3 = zero_zero(multiset(B)) ) ) ) ).

% subset_mset.lessE
tff(fact_4412_subset__mset_Oadd__neg__neg,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,A3,zero_zero(multiset(B)))
     => ( subset_mset(B,B2,zero_zero(multiset(B)))
       => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2),zero_zero(multiset(B))) ) ) ).

% subset_mset.add_neg_neg
tff(fact_4413_subset__mset_Oadd__pos__pos,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,zero_zero(multiset(B)),A3)
     => ( subset_mset(B,zero_zero(multiset(B)),B2)
       => subset_mset(B,zero_zero(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2)) ) ) ).

% subset_mset.add_pos_pos
tff(fact_4414_subset__mset_Opos__add__strict,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( subset_mset(B,zero_zero(multiset(B)),A3)
     => ( subset_mset(B,B2,C2)
       => subset_mset(B,B2,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)) ) ) ).

% subset_mset.pos_add_strict
tff(fact_4415_subset__implies__mult,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),R: set(product_prod(B,B))] :
      ( subset_mset(B,A4,B5)
     => member(product_prod(multiset(B),multiset(B)),aa(multiset(B),product_prod(multiset(B),multiset(B)),aa(multiset(B),fun(multiset(B),product_prod(multiset(B),multiset(B))),product_Pair(multiset(B),multiset(B)),A4),B5),mult(B,R)) ) ).

% subset_implies_mult
tff(fact_4416_subset__mset_Oadd__strict__increasing2,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),A3)
     => ( subset_mset(B,B2,C2)
       => subset_mset(B,B2,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)) ) ) ).

% subset_mset.add_strict_increasing2
tff(fact_4417_subset__mset_Oadd__strict__increasing,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B),C2: multiset(B)] :
      ( subset_mset(B,zero_zero(multiset(B)),A3)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),C2)
       => subset_mset(B,B2,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),C2)) ) ) ).

% subset_mset.add_strict_increasing
tff(fact_4418_subset__mset_Oadd__pos__nonneg,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,zero_zero(multiset(B)),A3)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),B2)
       => subset_mset(B,zero_zero(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2)) ) ) ).

% subset_mset.add_pos_nonneg
tff(fact_4419_subset__mset_Oadd__nonpos__neg,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),A3),zero_zero(multiset(B)))
     => ( subset_mset(B,B2,zero_zero(multiset(B)))
       => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2),zero_zero(multiset(B))) ) ) ).

% subset_mset.add_nonpos_neg
tff(fact_4420_subset__mset_Oadd__nonneg__pos,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),zero_zero(multiset(B))),A3)
     => ( subset_mset(B,zero_zero(multiset(B)),B2)
       => subset_mset(B,zero_zero(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2)) ) ) ).

% subset_mset.add_nonneg_pos
tff(fact_4421_subset__mset_Oadd__neg__nonpos,axiom,
    ! [B: $tType,A3: multiset(B),B2: multiset(B)] :
      ( subset_mset(B,A3,zero_zero(multiset(B)))
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),B2),zero_zero(multiset(B)))
       => subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A3),B2),zero_zero(multiset(B))) ) ) ).

% subset_mset.add_neg_nonpos
tff(fact_4422_sorted__hd__min,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Xsa: list(B)] :
          ( ( Xsa != nil(B) )
         => ( sorted_wrt(B,ord_less_eq(B),Xsa)
           => ! [X: B] :
                ( member(B,X,aa(list(B),set(B),set2(B),Xsa))
               => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),hd(B,Xsa)),X) ) ) ) ) ).

% sorted_hd_min
tff(fact_4423_sorted__hd__last,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [L: list(B)] :
          ( sorted_wrt(B,ord_less_eq(B),L)
         => ( ( L != nil(B) )
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),hd(B,L)),last(B,L)) ) ) ) ).

% sorted_hd_last
tff(fact_4424_hd__last__singletonI,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( Xsa != nil(B) )
     => ( ( hd(B,Xsa) = last(B,Xsa) )
       => ( distinct(B,Xsa)
         => ( Xsa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),hd(B,Xsa)),nil(B)) ) ) ) ) ).

% hd_last_singletonI
tff(fact_4425_hd__butlast,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),one_one(nat)),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( hd(B,butlast(B,Xsa)) = hd(B,Xsa) ) ) ).

% hd_butlast
tff(fact_4426_subset__mset_Osum__pos,axiom,
    ! [C: $tType,B: $tType,I4: set(B),F: fun(B,multiset(C))] :
      ( finite_finite2(B,I4)
     => ( ( I4 != bot_bot(set(B)) )
       => ( ! [I2: B] :
              ( member(B,I2,I4)
             => subset_mset(C,zero_zero(multiset(C)),aa(B,multiset(C),F,I2)) )
         => subset_mset(C,zero_zero(multiset(C)),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,I4)) ) ) ) ).

% subset_mset.sum_pos
tff(fact_4427_subset__mset_Osum__strict__mono,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,multiset(C)),G: fun(B,multiset(C))] :
      ( finite_finite2(B,A4)
     => ( ( A4 != bot_bot(set(B)) )
       => ( ! [X3: B] :
              ( member(B,X3,A4)
             => subset_mset(C,aa(B,multiset(C),F,X3),aa(B,multiset(C),G,X3)) )
         => subset_mset(C,groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),F,A4),groups3894954378712506084id_sum(multiset(C),B,plus_plus(multiset(C)),zero_zero(multiset(C)),G,A4)) ) ) ) ).

% subset_mset.sum_strict_mono
tff(fact_4428_ofilter__ordLess,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_ofilter(B,R,A4)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),A4),field2(B,R))
        <=> member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))),R),bNF_We4044943003108391690rdLess(B,B)) ) ) ) ).

% ofilter_ordLess
tff(fact_4429_ofilter__subset__ordLess,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B),B5: set(B)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_ofilter(B,R,A4)
       => ( order_ofilter(B,R,B5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),A4),B5)
          <=> member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,B5,aTP_Lamp_ma(set(B),fun(B,set(B)),B5)))),bNF_We4044943003108391690rdLess(B,B)) ) ) ) ) ).

% ofilter_subset_ordLess
tff(fact_4430_ofilter__subset__ordLeq,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B),B5: set(B)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_ofilter(B,R,A4)
       => ( order_ofilter(B,R,B5)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
          <=> member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,B5,aTP_Lamp_ma(set(B),fun(B,set(B)),B5)))),bNF_Wellorder_ordLeq(B,B)) ) ) ) ) ).

% ofilter_subset_ordLeq
tff(fact_4431_Nitpick_Osize__list__simp_I1_J,axiom,
    ! [B: $tType,F: fun(B,nat),Xsa: list(B)] :
      size_list(B,F,Xsa) = $ite(Xsa = nil(B),zero_zero(nat),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,F,hd(B,Xsa))),size_list(B,F,tl(B,Xsa))))) ).

% Nitpick.size_list_simp(1)
tff(fact_4432_length__tl,axiom,
    ! [B: $tType,Xsa: list(B)] : aa(list(B),nat,size_size(list(B)),tl(B,Xsa)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)) ).

% length_tl
tff(fact_4433_in__hd__or__tl__conv,axiom,
    ! [B: $tType,L: list(B),X2: B] :
      ( ( L != nil(B) )
     => ( ( ( X2 = hd(B,L) )
          | member(B,X2,aa(list(B),set(B),set2(B),tl(B,L))) )
      <=> member(B,X2,aa(list(B),set(B),set2(B),L)) ) ) ).

% in_hd_or_tl_conv
tff(fact_4434_tl__replicate,axiom,
    ! [B: $tType,N: nat,X2: B] : tl(B,replicate(B,N,X2)) = replicate(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),X2) ).

% tl_replicate
tff(fact_4435_rev__split__conv,axiom,
    ! [B: $tType,L: list(B)] :
      ( ( L != nil(B) )
     => ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),rev(B,tl(B,L))),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),hd(B,L)),nil(B))) = rev(B,L) ) ) ).

% rev_split_conv
tff(fact_4436_ordLess__irreflexive,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] : ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R),bNF_We4044943003108391690rdLess(B,B)) ).

% ordLess_irreflexive
tff(fact_4437_ordLess__transitive,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => ( member(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),R8),bNF_We4044943003108391690rdLess(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_We4044943003108391690rdLess(B,D)) ) ) ).

% ordLess_transitive
tff(fact_4438_ordLeq__transitive,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => ( member(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),R8),bNF_Wellorder_ordLeq(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_Wellorder_ordLeq(B,D)) ) ) ).

% ordLeq_transitive
tff(fact_4439_not__ordLess__ordLeq,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => ~ member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordLeq(C,B)) ) ).

% not_ordLess_ordLeq
tff(fact_4440_ordLess__imp__ordLeq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C)) ) ).

% ordLess_imp_ordLeq
tff(fact_4441_ordLeq__ordLess__trans,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => ( member(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),R8),bNF_We4044943003108391690rdLess(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_We4044943003108391690rdLess(B,D)) ) ) ).

% ordLeq_ordLess_trans
tff(fact_4442_ordLess__ordLeq__trans,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => ( member(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),R8),bNF_Wellorder_ordLeq(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_We4044943003108391690rdLess(B,D)) ) ) ).

% ordLess_ordLeq_trans
tff(fact_4443_not__ordLess__iff__ordLeq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( ~ member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_We4044943003108391690rdLess(C,B))
        <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C)) ) ) ) ).

% not_ordLess_iff_ordLeq
tff(fact_4444_not__ordLeq__iff__ordLess,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( ~ member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordLeq(C,B))
        <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C)) ) ) ) ).

% not_ordLeq_iff_ordLess
tff(fact_4445_ordLess__or__ordLeq,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
          | member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordLeq(C,B)) ) ) ) ).

% ordLess_or_ordLeq
tff(fact_4446_in__set__tlD,axiom,
    ! [B: $tType,X2: B,Xsa: list(B)] :
      ( member(B,X2,aa(list(B),set(B),set2(B),tl(B,Xsa)))
     => member(B,X2,aa(list(B),set(B),set2(B),Xsa)) ) ).

% in_set_tlD
tff(fact_4447_tl__obtain__elem,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( Xsa != nil(B) )
     => ( ( tl(B,Xsa) = nil(B) )
       => ~ ! [E3: B] : Xsa != aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E3),nil(B)) ) ) ).

% tl_obtain_elem
tff(fact_4448_not__hd__in__tl,axiom,
    ! [B: $tType,X2: B,Xsa: list(B)] :
      ( ( X2 != hd(B,Xsa) )
     => ( member(B,X2,aa(list(B),set(B),set2(B),Xsa))
       => member(B,X2,aa(list(B),set(B),set2(B),tl(B,Xsa))) ) ) ).

% not_hd_in_tl
tff(fact_4449_tl__last,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( tl(B,Xsa) != nil(B) )
     => ( last(B,Xsa) = last(B,tl(B,Xsa)) ) ) ).

% tl_last
tff(fact_4450_rev__butlast__is__tl__rev,axiom,
    ! [B: $tType,L: list(B)] : rev(B,butlast(B,L)) = tl(B,rev(B,L)) ).

% rev_butlast_is_tl_rev
tff(fact_4451_tl__subset,axiom,
    ! [B: $tType,Xsa: list(B),A4: set(B)] :
      ( ( Xsa != nil(B) )
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),Xsa)),A4)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),tl(B,Xsa))),A4) ) ) ).

% tl_subset
tff(fact_4452_Misc_Onth__tl,axiom,
    ! [B: $tType,Xsa: list(B),N: nat] :
      ( ( Xsa != nil(B) )
     => ( aa(nat,B,nth(B,tl(B,Xsa)),N) = aa(nat,B,nth(B,Xsa),aa(nat,nat,suc,N)) ) ) ).

% Misc.nth_tl
tff(fact_4453_list__take__induct__tl2,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),Ys: list(C),P: fun(C,fun(B,$o))] :
      ( ( aa(list(B),nat,size_size(list(B)),Xsa) = aa(list(C),nat,size_size(list(C)),Ys) )
     => ( ! [N3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N3),aa(list(B),nat,size_size(list(B)),Xsa))
           => aa(B,$o,aa(C,fun(B,$o),P,aa(nat,C,nth(C,Ys),N3)),aa(nat,B,nth(B,Xsa),N3)) )
       => ! [N9: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N9),aa(list(B),nat,size_size(list(B)),tl(B,Xsa)))
           => aa(B,$o,aa(C,fun(B,$o),P,aa(nat,C,nth(C,tl(C,Ys)),N9)),aa(nat,B,nth(B,tl(B,Xsa)),N9)) ) ) ) ).

% list_take_induct_tl2
tff(fact_4454_exists__minim__Well__order,axiom,
    ! [B: $tType,R4: set(set(product_prod(B,B)))] :
      ( ( R4 != bot_bot(set(set(product_prod(B,B)))) )
     => ( ! [X3: set(product_prod(B,B))] :
            ( member(set(product_prod(B,B)),X3,R4)
           => order_well_order_on(B,field2(B,X3),X3) )
       => ? [X3: set(product_prod(B,B))] :
            ( member(set(product_prod(B,B)),X3,R4)
            & ! [Xa3: set(product_prod(B,B))] :
                ( member(set(product_prod(B,B)),Xa3,R4)
               => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),X3),Xa3),bNF_Wellorder_ordLeq(B,B)) ) ) ) ) ).

% exists_minim_Well_order
tff(fact_4455_ordLeq__total,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
          | member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordLeq(C,B)) ) ) ) ).

% ordLeq_total
tff(fact_4456_ordLeq__reflexive,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_well_order_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R),bNF_Wellorder_ordLeq(B,B)) ) ).

% ordLeq_reflexive
tff(fact_4457_ordLeq__Well__order__simp,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => ( order_well_order_on(B,field2(B,R),R)
        & order_well_order_on(C,field2(C,R3),R3) ) ) ).

% ordLeq_Well_order_simp
tff(fact_4458_tl__take,axiom,
    ! [B: $tType,N: nat,Xsa: list(B)] : tl(B,take(B,N,Xsa)) = take(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),tl(B,Xsa)) ).

% tl_take
tff(fact_4459_distinct__hd__tl,axiom,
    ! [B: $tType,Xsa: list(B),X2: B] :
      ( distinct(B,Xsa)
     => ( ( X2 = hd(B,Xsa) )
       => ~ member(B,X2,aa(list(B),set(B),set2(B),tl(B,Xsa))) ) ) ).

% distinct_hd_tl
tff(fact_4460_butlast__rev__tl,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( Xsa != nil(B) )
     => ( butlast(B,rev(B,Xsa)) = rev(B,tl(B,Xsa)) ) ) ).

% butlast_rev_tl
tff(fact_4461_finite__ordLess__infinite,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( finite_finite2(B,field2(B,R))
         => ( ~ finite_finite2(C,field2(C,R3))
           => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C)) ) ) ) ) ).

% finite_ordLess_infinite
tff(fact_4462_ordLeq__iff__ordLess__Restr,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
        <=> ! [X4: B] :
              ( member(B,X4,field2(B,R))
             => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,order_underS(B,R,X4),aa(B,fun(B,set(B)),aTP_Lamp_st(set(product_prod(B,B)),fun(B,fun(B,set(B))),R),X4)))),R3),bNF_We4044943003108391690rdLess(B,C)) ) ) ) ) ).

% ordLeq_iff_ordLess_Restr
tff(fact_4463_underS__Restr__ordLess,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( ( field2(B,R) != bot_bot(set(B)) )
       => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,order_underS(B,R,A3),aa(B,fun(B,set(B)),aTP_Lamp_st(set(product_prod(B,B)),fun(B,fun(B,set(B))),R),A3)))),R),bNF_We4044943003108391690rdLess(B,B)) ) ) ).

% underS_Restr_ordLess
tff(fact_4464_horner__sum__append,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_semiring_1(B)
     => ! [F: fun(C,B),A3: B,Xsa: list(C),Ys: list(C)] : aa(list(C),B,aa(B,fun(list(C),B),aa(fun(C,B),fun(B,fun(list(C),B)),groups4207007520872428315er_sum(C,B),F),A3),aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xsa),Ys)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(list(C),B,aa(B,fun(list(C),B),aa(fun(C,B),fun(B,fun(list(C),B)),groups4207007520872428315er_sum(C,B),F),A3),Xsa)),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),A3),aa(list(C),nat,size_size(list(C)),Xsa))),aa(list(C),B,aa(B,fun(list(C),B),aa(fun(C,B),fun(B,fun(list(C),B)),groups4207007520872428315er_sum(C,B),F),A3),Ys))) ) ).

% horner_sum_append
tff(fact_4465_Code__Numeral_Osub__code_I4_J,axiom,
    ! [N: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,one2),aa(num,num,bit0,N)) = code_Neg(bitM(N)) ).

% Code_Numeral.sub_code(4)
tff(fact_4466_horner__sum__simps_I2_J,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_semiring_0(B)
     => ! [F: fun(C,B),A3: B,X2: C,Xsa: list(C)] : aa(list(C),B,aa(B,fun(list(C),B),aa(fun(C,B),fun(B,fun(list(C),B)),groups4207007520872428315er_sum(C,B),F),A3),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xsa)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(C,B,F,X2)),aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(list(C),B,aa(B,fun(list(C),B),aa(fun(C,B),fun(B,fun(list(C),B)),groups4207007520872428315er_sum(C,B),F),A3),Xsa))) ) ).

% horner_sum_simps(2)
tff(fact_4467_underS__E,axiom,
    ! [B: $tType,I: B,R4: set(product_prod(B,B)),J: B] :
      ( member(B,I,order_underS(B,R4,J))
     => ( ( I != J )
        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),I),J),R4) ) ) ).

% underS_E
tff(fact_4468_underS__I,axiom,
    ! [B: $tType,I: B,J: B,R4: set(product_prod(B,B))] :
      ( ( I != J )
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),I),J),R4)
       => member(B,I,order_underS(B,R4,J)) ) ) ).

% underS_I
tff(fact_4469_underS__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] : order_underS(B,R,A3) = aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),aTP_Lamp_su(set(product_prod(B,B)),fun(B,fun(B,$o)),R),A3)) ).

% underS_def
tff(fact_4470_Code__Numeral_Odup__code_I3_J,axiom,
    ! [N: num] : aa(code_integer,code_integer,code_dup,code_Neg(N)) = code_Neg(aa(num,num,bit0,N)) ).

% Code_Numeral.dup_code(3)
tff(fact_4471_less__integer__code_I3_J,axiom,
    ! [L: num] : ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),zero_zero(code_integer)),code_Neg(L)) ).

% less_integer_code(3)
tff(fact_4472_less__integer__code_I7_J,axiom,
    ! [K: num] : aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),code_Neg(K)),zero_zero(code_integer)) ).

% less_integer_code(7)
tff(fact_4473_plus__integer__code_I6_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),code_Neg(M)),code_Neg(N)) = code_Neg(aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% plus_integer_code(6)
tff(fact_4474_less__eq__integer__code_I7_J,axiom,
    ! [K: num] : aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),code_Neg(K)),zero_zero(code_integer)) ).

% less_eq_integer_code(7)
tff(fact_4475_less__eq__integer__code_I3_J,axiom,
    ! [L: num] : ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),zero_zero(code_integer)),code_Neg(L)) ).

% less_eq_integer_code(3)
tff(fact_4476_less__integer__code_I9_J,axiom,
    ! [K: num,L: num] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),code_Neg(K)),code_Neg(L))
    <=> aa(num,$o,aa(num,fun(num,$o),ord_less(num),L),K) ) ).

% less_integer_code(9)
tff(fact_4477_less__eq__integer__code_I9_J,axiom,
    ! [K: num,L: num] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),code_Neg(K)),code_Neg(L))
    <=> aa(num,$o,aa(num,fun(num,$o),ord_less_eq(num),L),K) ) ).

% less_eq_integer_code(9)
tff(fact_4478_minus__integer__code_I6_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),code_Neg(M)),code_Neg(N)) = aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,N),M) ).

% minus_integer_code(6)
tff(fact_4479_divmod__abs__code_I2_J,axiom,
    ! [K: num,L: num] : code_divmod_abs(code_Neg(K),code_Neg(L)) = unique8689654367752047608divmod(code_integer,K,L) ).

% divmod_abs_code(2)
tff(fact_4480_horner__sum__foldr,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_semiring_0(B)
     => ! [F: fun(C,B),A3: B,Xsa: list(C)] : aa(list(C),B,aa(B,fun(list(C),B),aa(fun(C,B),fun(B,fun(list(C),B)),groups4207007520872428315er_sum(C,B),F),A3),Xsa) = aa(B,B,foldr(C,B,aa(B,fun(C,fun(B,B)),aTP_Lamp_sv(fun(C,B),fun(B,fun(C,fun(B,B))),F),A3),Xsa),zero_zero(B)) ) ).

% horner_sum_foldr
tff(fact_4481_underS__incl__iff,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( order_679001287576687338der_on(B,field2(B,R),R)
     => ( member(B,A3,field2(B,R))
       => ( member(B,B2,field2(B,R))
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),order_underS(B,R,A3)),order_underS(B,R,B2))
          <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R) ) ) ) ) ).

% underS_incl_iff
tff(fact_4482_Code__Numeral_Osub__code_I5_J,axiom,
    ! [N: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,one2),aa(num,num,bit1,N)) = code_Neg(aa(num,num,bit0,N)) ).

% Code_Numeral.sub_code(5)
tff(fact_4483_ordLess__iff__ordIso__Restr,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_We4044943003108391690rdLess(C,B))
        <=> ? [X4: B] :
              ( member(B,X4,field2(B,R))
              & member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,order_underS(B,R,X4),aa(B,fun(B,set(B)),aTP_Lamp_st(set(product_prod(B,B)),fun(B,fun(B,set(B))),R),X4)))),bNF_Wellorder_ordIso(C,B)) ) ) ) ) ).

% ordLess_iff_ordIso_Restr
tff(fact_4484_sum__list__update,axiom,
    ! [B: $tType] :
      ( ordere1170586879665033532d_diff(B)
     => ! [K: nat,Xsa: list(B),X2: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),K),aa(list(B),nat,size_size(list(B)),Xsa))
         => ( aa(list(B),B,groups8242544230860333062m_list(B),list_update(B,Xsa,K,X2)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(list(B),B,groups8242544230860333062m_list(B),Xsa)),X2)),aa(nat,B,nth(B,Xsa),K)) ) ) ) ).

% sum_list_update
tff(fact_4485_length__product__lists,axiom,
    ! [B: $tType,Xss: list(list(B))] : aa(list(list(B)),nat,size_size(list(list(B))),product_lists(B,Xss)) = aa(nat,nat,foldr(nat,nat,times_times(nat),aa(list(list(B)),list(nat),map(list(B),nat,size_size(list(B))),Xss)),one_one(nat)) ).

% length_product_lists
tff(fact_4486_horner__sum__transfer,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType] :
      ( ( comm_semiring_0(C)
        & comm_semiring_0(B) )
     => ! [A4: fun(B,fun(C,$o)),B5: fun(D,fun(E,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),A4,zero_zero(B)),zero_zero(C))
         => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),A4,bNF_rel_fun(B,C,B,C,A4,A4)),plus_plus(B)),plus_plus(C))
           => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),A4,bNF_rel_fun(B,C,B,C,A4,A4)),times_times(B)),times_times(C))
             => aa(fun(fun(E,C),fun(C,fun(list(E),C))),$o,aa(fun(fun(D,B),fun(B,fun(list(D),B))),fun(fun(fun(E,C),fun(C,fun(list(E),C))),$o),bNF_rel_fun(fun(D,B),fun(E,C),fun(B,fun(list(D),B)),fun(C,fun(list(E),C)),bNF_rel_fun(D,E,B,C,B5,A4),bNF_rel_fun(B,C,fun(list(D),B),fun(list(E),C),A4,bNF_rel_fun(list(D),list(E),B,C,list_all2(D,E,B5),A4))),groups4207007520872428315er_sum(D,B)),groups4207007520872428315er_sum(E,C)) ) ) ) ) ).

% horner_sum_transfer
tff(fact_4487_sum__list_OCons,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ! [X2: B,Xsa: list(B)] : aa(list(B),B,groups8242544230860333062m_list(B),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X2),Xsa)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),X2),aa(list(B),B,groups8242544230860333062m_list(B),Xsa)) ) ).

% sum_list.Cons
tff(fact_4488_sum__list__append,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ! [Xsa: list(B),Ys: list(B)] : aa(list(B),B,groups8242544230860333062m_list(B),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xsa),Ys)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(list(B),B,groups8242544230860333062m_list(B),Xsa)),aa(list(B),B,groups8242544230860333062m_list(B),Ys)) ) ).

% sum_list_append
tff(fact_4489_ordIso__transitive,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => ( member(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),R8),bNF_Wellorder_ordIso(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_Wellorder_ordIso(B,D)) ) ) ).

% ordIso_transitive
tff(fact_4490_ordIso__symmetric,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordIso(C,B)) ) ).

% ordIso_symmetric
tff(fact_4491_sum__list__transfer,axiom,
    ! [B: $tType,C: $tType] :
      ( ( monoid_add(C)
        & monoid_add(B) )
     => ! [A4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),A4,zero_zero(B)),zero_zero(C))
         => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),A4,bNF_rel_fun(B,C,B,C,A4,A4)),plus_plus(B)),plus_plus(C))
           => aa(fun(list(C),C),$o,aa(fun(list(B),B),fun(fun(list(C),C),$o),bNF_rel_fun(list(B),list(C),B,C,list_all2(B,C,A4),A4),groups8242544230860333062m_list(B)),groups8242544230860333062m_list(C)) ) ) ) ).

% sum_list_transfer
tff(fact_4492_Misc_Olist__all2__induct,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),L: list(B),L4: list(C),Q: fun(list(B),fun(list(C),$o))] :
      ( aa(list(C),$o,aa(list(B),fun(list(C),$o),list_all2(B,C,P),L),L4)
     => ( aa(list(C),$o,aa(list(B),fun(list(C),$o),Q,nil(B)),nil(C))
       => ( ! [X3: B,X5: C,Ls2: list(B),Ls3: list(C)] :
              ( aa(C,$o,aa(B,fun(C,$o),P,X3),X5)
             => ( aa(list(C),$o,aa(list(B),fun(list(C),$o),list_all2(B,C,P),Ls2),Ls3)
               => ( aa(list(C),$o,aa(list(B),fun(list(C),$o),Q,Ls2),Ls3)
                 => aa(list(C),$o,aa(list(B),fun(list(C),$o),Q,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Ls2)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X5),Ls3)) ) ) )
         => aa(list(C),$o,aa(list(B),fun(list(C),$o),Q,L),L4) ) ) ) ).

% Misc.list_all2_induct
tff(fact_4493_ordIso__iff__ordLeq,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
    <=> ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
        & member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordLeq(C,B)) ) ) ).

% ordIso_iff_ordLeq
tff(fact_4494_ordIso__imp__ordLeq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C)) ) ).

% ordIso_imp_ordLeq
tff(fact_4495_ordIso__ordLeq__trans,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => ( member(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),R8),bNF_Wellorder_ordLeq(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_Wellorder_ordLeq(B,D)) ) ) ).

% ordIso_ordLeq_trans
tff(fact_4496_ordLeq__ordIso__trans,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => ( member(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),R8),bNF_Wellorder_ordIso(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_Wellorder_ordLeq(B,D)) ) ) ).

% ordLeq_ordIso_trans
tff(fact_4497_not__ordLess__ordIso,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => ~ member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C)) ) ).

% not_ordLess_ordIso
tff(fact_4498_ordIso__ordLess__trans,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => ( member(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),R8),bNF_We4044943003108391690rdLess(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_We4044943003108391690rdLess(B,D)) ) ) ).

% ordIso_ordLess_trans
tff(fact_4499_ordLess__ordIso__trans,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),R8: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => ( member(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),R8),bNF_Wellorder_ordIso(C,D))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D))),aa(set(product_prod(B,B)),fun(set(product_prod(D,D)),product_prod(set(product_prod(B,B)),set(product_prod(D,D)))),product_Pair(set(product_prod(B,B)),set(product_prod(D,D))),R),R8),bNF_We4044943003108391690rdLess(B,D)) ) ) ).

% ordLess_ordIso_trans
tff(fact_4500_sum__list__addf,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [F: fun(C,B),G: fun(C,B),Xsa: list(C)] : aa(list(B),B,groups8242544230860333062m_list(B),aa(list(C),list(B),map(C,B,aa(fun(C,B),fun(C,B),aTP_Lamp_cb(fun(C,B),fun(fun(C,B),fun(C,B)),F),G)),Xsa)) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(list(B),B,groups8242544230860333062m_list(B),aa(list(C),list(B),map(C,B,F),Xsa))),aa(list(B),B,groups8242544230860333062m_list(B),aa(list(C),list(B),map(C,B,G),Xsa))) ) ).

% sum_list_addf
tff(fact_4501_finite__well__order__on__ordIso,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),R3: set(product_prod(B,B))] :
      ( finite_finite2(B,A4)
     => ( order_well_order_on(B,A4,R)
       => ( order_well_order_on(B,A4,R3)
         => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R3),bNF_Wellorder_ordIso(B,B)) ) ) ) ).

% finite_well_order_on_ordIso
tff(fact_4502_ordIso__reflexive,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_well_order_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R),bNF_Wellorder_ordIso(B,B)) ) ).

% ordIso_reflexive
tff(fact_4503_uminus__sum__list__map,axiom,
    ! [B: $tType,C: $tType] :
      ( ab_group_add(B)
     => ! [F: fun(C,B),Xsa: list(C)] : aa(B,B,uminus_uminus(B),aa(list(B),B,groups8242544230860333062m_list(B),aa(list(C),list(B),map(C,B,F),Xsa))) = aa(list(B),B,groups8242544230860333062m_list(B),aa(list(C),list(B),map(C,B,aa(fun(C,B),fun(C,B),aa(fun(B,B),fun(fun(C,B),fun(C,B)),comp(B,B,C),uminus_uminus(B)),F)),Xsa)) ) ).

% uminus_sum_list_map
tff(fact_4504_ordLeq__iff__ordLess__or__ordIso,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
    <=> ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
        | member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C)) ) ) ).

% ordLeq_iff_ordLess_or_ordIso
tff(fact_4505_sum__list_Oeq__foldr,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ! [Xsa: list(B)] : aa(list(B),B,groups8242544230860333062m_list(B),Xsa) = aa(B,B,foldr(B,B,plus_plus(B),Xsa),zero_zero(B)) ) ).

% sum_list.eq_foldr
tff(fact_4506_internalize__ordLeq,axiom,
    ! [B: $tType,C: $tType,R3: set(product_prod(B,B)),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R3),R),bNF_Wellorder_ordLeq(B,C))
    <=> ? [P6: set(product_prod(C,C))] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),field2(C,P6)),field2(C,R))
          & member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R3),P6),bNF_Wellorder_ordIso(B,C))
          & member(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))),P6),R),bNF_Wellorder_ordLeq(C,C)) ) ) ).

% internalize_ordLeq
tff(fact_4507_internalize__ordLess,axiom,
    ! [B: $tType,C: $tType,R3: set(product_prod(B,B)),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R3),R),bNF_We4044943003108391690rdLess(B,C))
    <=> ? [P6: set(product_prod(C,C))] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less(set(C)),field2(C,P6)),field2(C,R))
          & member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R3),P6),bNF_Wellorder_ordIso(B,C))
          & member(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))),P6),R),bNF_We4044943003108391690rdLess(C,C)) ) ) ).

% internalize_ordLess
tff(fact_4508_card__length__sum__list__rec,axiom,
    ! [M: nat,N5: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),M)
     => ( finite_card(list(nat),aa(fun(list(nat),$o),set(list(nat)),collect(list(nat)),aa(nat,fun(list(nat),$o),aTP_Lamp_sw(nat,fun(nat,fun(list(nat),$o)),M),N5))) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(list(nat),aa(fun(list(nat),$o),set(list(nat)),collect(list(nat)),aa(nat,fun(list(nat),$o),aTP_Lamp_sx(nat,fun(nat,fun(list(nat),$o)),M),N5)))),finite_card(list(nat),aa(fun(list(nat),$o),set(list(nat)),collect(list(nat)),aa(nat,fun(list(nat),$o),aTP_Lamp_sy(nat,fun(nat,fun(list(nat),$o)),M),N5)))) ) ) ).

% card_length_sum_list_rec
tff(fact_4509_size__list__conv__sum__list,axiom,
    ! [B: $tType,F: fun(B,nat),Xsa: list(B)] : size_list(B,F,Xsa) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(nat),nat,groups8242544230860333062m_list(nat),aa(list(B),list(nat),map(B,nat,F),Xsa))),aa(list(B),nat,size_size(list(B)),Xsa)) ).

% size_list_conv_sum_list
tff(fact_4510_card__length__sum__list,axiom,
    ! [M: nat,N5: nat] : finite_card(list(nat),aa(fun(list(nat),$o),set(list(nat)),collect(list(nat)),aa(nat,fun(list(nat),$o),aTP_Lamp_sw(nat,fun(nat,fun(list(nat),$o)),M),N5))) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N5),M)),one_one(nat))),N5) ).

% card_length_sum_list
tff(fact_4511_sum__list__Suc,axiom,
    ! [B: $tType,F: fun(B,nat),Xsa: list(B)] : aa(list(nat),nat,groups8242544230860333062m_list(nat),aa(list(B),list(nat),map(B,nat,aTP_Lamp_id(fun(B,nat),fun(B,nat),F)),Xsa)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(nat),nat,groups8242544230860333062m_list(nat),aa(list(B),list(nat),map(B,nat,F),Xsa))),aa(list(B),nat,size_size(list(B)),Xsa)) ).

% sum_list_Suc
tff(fact_4512_select__weight__def,axiom,
    ! [B: $tType,Xsa: list(product_prod(code_natural,B))] : select_weight(B,Xsa) = product_scomp(product_prod(code_natural,code_natural),code_natural,product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural)),range(aa(list(code_natural),code_natural,groups8242544230860333062m_list(code_natural),aa(list(product_prod(code_natural,B)),list(code_natural),map(product_prod(code_natural,B),code_natural,product_fst(code_natural,B)),Xsa))),aTP_Lamp_sz(list(product_prod(code_natural,B)),fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural)))),Xsa)) ).

% select_weight_def
tff(fact_4513_prod__list__transfer,axiom,
    ! [B: $tType,C: $tType] :
      ( ( monoid_mult(C)
        & monoid_mult(B) )
     => ! [A4: fun(B,fun(C,$o))] :
          ( aa(C,$o,aa(B,fun(C,$o),A4,one_one(B)),one_one(C))
         => ( aa(fun(C,fun(C,C)),$o,aa(fun(B,fun(B,B)),fun(fun(C,fun(C,C)),$o),bNF_rel_fun(B,C,fun(B,B),fun(C,C),A4,bNF_rel_fun(B,C,B,C,A4,A4)),times_times(B)),times_times(C))
           => aa(fun(list(C),C),$o,aa(fun(list(B),B),fun(fun(list(C),C),$o),bNF_rel_fun(list(B),list(C),B,C,list_all2(B,C,A4),A4),groups5270119922927024881d_list(B)),groups5270119922927024881d_list(C)) ) ) ) ).

% prod_list_transfer
tff(fact_4514_dir__image__ordIso,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),F: fun(B,C)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( inj_on(B,C,F,field2(B,R))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_We2720479622203943262_image(B,C,R,F)),bNF_Wellorder_ordIso(B,C)) ) ) ).

% dir_image_ordIso
tff(fact_4515_underS__incr,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( trans(B,R)
     => ( antisym(B,R)
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
         => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),order_underS(B,R,A3)),order_underS(B,R,B2)) ) ) ) ).

% underS_incr
tff(fact_4516_prod__list_ONil,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ( aa(list(B),B,groups5270119922927024881d_list(B),nil(B)) = one_one(B) ) ) ).

% prod_list.Nil
tff(fact_4517_antisymD,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( antisym(B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),R)
         => ( A3 = B2 ) ) ) ) ).

% antisymD
tff(fact_4518_antisymI,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ! [X3: B,Y4: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R)
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),X3),R)
           => ( X3 = Y4 ) ) )
     => antisym(B,R) ) ).

% antisymI
tff(fact_4519_antisym__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( antisym(B,R)
    <=> ! [X4: B,Y3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Y3),R)
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y3),X4),R)
           => ( X4 = Y3 ) ) ) ) ).

% antisym_def
tff(fact_4520_dir__image__def,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(C,C)),F: fun(C,B)] : bNF_We2720479622203943262_image(C,B,R,F) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(C,B),fun(product_prod(B,B),$o),aTP_Lamp_oa(set(product_prod(C,C)),fun(fun(C,B),fun(product_prod(B,B),$o)),R),F)) ).

% dir_image_def
tff(fact_4521_prod__list_Oeq__foldr,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [Xsa: list(B)] : aa(list(B),B,groups5270119922927024881d_list(B),Xsa) = aa(B,B,foldr(B,B,times_times(B),Xsa),one_one(B)) ) ).

% prod_list.eq_foldr
tff(fact_4522_pick__same,axiom,
    ! [B: $tType,L: nat,Xsa: list(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),L),aa(list(B),nat,size_size(list(B)),Xsa))
     => ( pick(B,aa(list(B),list(product_prod(code_natural,B)),map(B,product_prod(code_natural,B),aa(code_natural,fun(B,product_prod(code_natural,B)),product_Pair(code_natural,B),one_one(code_natural))),Xsa),aa(nat,code_natural,code_natural_of_nat,L)) = aa(nat,B,nth(B,Xsa),L) ) ) ).

% pick_same
tff(fact_4523_flip__pred,axiom,
    ! [B: $tType,C: $tType,A4: set(product_prod(B,C)),R4: fun(C,fun(B,$o))] :
      ( aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),A4),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),conversep(C,B,R4))))
     => aa(set(product_prod(C,B)),$o,aa(set(product_prod(C,B)),fun(set(product_prod(C,B)),$o),ord_less_eq(set(product_prod(C,B))),aa(set(product_prod(B,C)),set(product_prod(C,B)),image2(product_prod(B,C),product_prod(C,B),aa(fun(B,fun(C,product_prod(C,B))),fun(product_prod(B,C),product_prod(C,B)),product_case_prod(B,C,product_prod(C,B)),aTP_Lamp_it(B,fun(C,product_prod(C,B))))),A4)),aa(fun(product_prod(C,B),$o),set(product_prod(C,B)),collect(product_prod(C,B)),aa(fun(C,fun(B,$o)),fun(product_prod(C,B),$o),product_case_prod(C,B,$o),R4))) ) ).

% flip_pred
tff(fact_4524_prod__set__simps_I1_J,axiom,
    ! [C: $tType,B: $tType,X2: B,Y: C] : aa(product_prod(B,C),set(B),basic_fsts(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y)) = aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))) ).

% prod_set_simps(1)
tff(fact_4525_prod__set__simps_I2_J,axiom,
    ! [C: $tType,B: $tType,X2: C,Y: B] : basic_snds(C,B,aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X2),Y)) = aa(set(B),set(B),insert2(B,Y),bot_bot(set(B))) ).

% prod_set_simps(2)
tff(fact_4526_natural__of__nat__of__nat,axiom,
    code_natural_of_nat = semiring_1_of_nat(code_natural) ).

% natural_of_nat_of_nat
tff(fact_4527_division__segment__natural_Oabs__eq,axiom,
    ! [X2: nat] : aa(code_natural,code_natural,euclid7384307370059645450egment(code_natural),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,euclid7384307370059645450egment(nat),X2)) ).

% division_segment_natural.abs_eq
tff(fact_4528_set__bit__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se5668285175392031749et_bit(code_natural),Xa),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se5668285175392031749et_bit(nat),Xa),X2)) ).

% set_bit_natural.abs_eq
tff(fact_4529_flip__bit__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se8732182000553998342ip_bit(code_natural),Xa),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se8732182000553998342ip_bit(nat),Xa),X2)) ).

% flip_bit_natural.abs_eq
tff(fact_4530_unset__bit__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se2638667681897837118et_bit(code_natural),Xa),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se2638667681897837118et_bit(nat),Xa),X2)) ).

% unset_bit_natural.abs_eq
tff(fact_4531_euclidean__size__natural_Oabs__eq,axiom,
    ! [X2: nat] : aa(code_natural,nat,euclid6346220572633701492n_size(code_natural),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,nat,euclid6346220572633701492n_size(nat),X2) ).

% euclidean_size_natural.abs_eq
tff(fact_4532_bit__natural_Oabs__eq,axiom,
    ! [X2: nat] : aa(code_natural,fun(nat,$o),bit_se5641148757651400278ts_bit(code_natural),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,fun(nat,$o),bit_se5641148757651400278ts_bit(nat),X2) ).

% bit_natural.abs_eq
tff(fact_4533_natural__of__nat__cases,axiom,
    ! [X2: code_natural] :
      ~ ! [Y4: nat] :
          ( ( X2 = aa(nat,code_natural,code_natural_of_nat,Y4) )
         => ~ member(nat,Y4,top_top(set(nat))) ) ).

% natural_of_nat_cases
tff(fact_4534_natural__of__nat__induct,axiom,
    ! [P: fun(code_natural,$o),X2: code_natural] :
      ( ! [Y4: nat] :
          ( member(nat,Y4,top_top(set(nat)))
         => aa(code_natural,$o,P,aa(nat,code_natural,code_natural_of_nat,Y4)) )
     => aa(code_natural,$o,P,X2) ) ).

% natural_of_nat_induct
tff(fact_4535_natural__of__nat__inject,axiom,
    ! [X2: nat,Y: nat] :
      ( member(nat,X2,top_top(set(nat)))
     => ( member(nat,Y,top_top(set(nat)))
       => ( ( aa(nat,code_natural,code_natural_of_nat,X2) = aa(nat,code_natural,code_natural_of_nat,Y) )
        <=> ( X2 = Y ) ) ) ) ).

% natural_of_nat_inject
tff(fact_4536_take__bit__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se2584673776208193580ke_bit(code_natural),Xa),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se2584673776208193580ke_bit(nat),Xa),X2)) ).

% take_bit_natural.abs_eq
tff(fact_4537_and__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),bit_se5824344872417868541ns_and(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),Xa),X2)) ).

% and_natural.abs_eq
tff(fact_4538_xor__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),bit_se5824344971392196577ns_xor(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),Xa),X2)) ).

% xor_natural.abs_eq
tff(fact_4539_or__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),bit_se1065995026697491101ons_or(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),Xa),X2)) ).

% or_natural.abs_eq
tff(fact_4540_mask__natural_Oabs__eq,axiom,
    ! [X2: nat] : aa(nat,code_natural,bit_se2239418461657761734s_mask(code_natural),X2) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,bit_se2239418461657761734s_mask(nat),X2)) ).

% mask_natural.abs_eq
tff(fact_4541_push__bit__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se4730199178511100633sh_bit(code_natural),Xa),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se4730199178511100633sh_bit(nat),Xa),X2)) ).

% push_bit_natural.abs_eq
tff(fact_4542_drop__bit__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se4197421643247451524op_bit(code_natural),Xa),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),bit_se4197421643247451524op_bit(nat),Xa),X2)) ).

% drop_bit_natural.abs_eq
tff(fact_4543_zero__natural__def,axiom,
    zero_zero(code_natural) = aa(nat,code_natural,code_natural_of_nat,zero_zero(nat)) ).

% zero_natural_def
tff(fact_4544_one__natural__def,axiom,
    one_one(code_natural) = aa(nat,code_natural,code_natural_of_nat,one_one(nat)) ).

% one_natural_def
tff(fact_4545_less__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] :
      ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Xa),X2) ) ).

% less_natural.abs_eq
tff(fact_4546_plus__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Xa),X2)) ).

% plus_natural.abs_eq
tff(fact_4547_minus__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Xa),X2)) ).

% minus_natural.abs_eq
tff(fact_4548_less__eq__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] :
      ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less_eq(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2))
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Xa),X2) ) ).

% less_eq_natural.abs_eq
tff(fact_4549_times__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Xa),X2)) ).

% times_natural.abs_eq
tff(fact_4550_divide__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),Xa),X2)) ).

% divide_natural.abs_eq
tff(fact_4551_mask__natural__def,axiom,
    bit_se2239418461657761734s_mask(code_natural) = aa(fun(nat,nat),fun(nat,code_natural),map_fun(nat,nat,nat,code_natural,id(nat),code_natural_of_nat),bit_se2239418461657761734s_mask(nat)) ).

% mask_natural_def
tff(fact_4552_modulo__natural_Oabs__eq,axiom,
    ! [Xa: nat,X2: nat] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),modulo_modulo(code_natural),aa(nat,code_natural,code_natural_of_nat,Xa)),aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),Xa),X2)) ).

% modulo_natural.abs_eq
tff(fact_4553_select__def,axiom,
    ! [B: $tType,Xsa: list(B)] : select(B,Xsa) = product_scomp(product_prod(code_natural,code_natural),code_natural,product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural)),range(aa(nat,code_natural,code_natural_of_nat,aa(list(B),nat,size_size(list(B)),Xsa))),aTP_Lamp_ta(list(B),fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural)))),Xsa)) ).

% select_def
tff(fact_4554_Nat_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_natural,code_Nat,aa(int,code_integer,code_integer_of_int,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(int,nat,nat2,X2)) ).

% Nat.abs_eq
tff(fact_4555_Nat__def,axiom,
    code_Nat = aa(fun(int,nat),fun(code_integer,code_natural),map_fun(code_integer,int,nat,code_natural,code_int_of_integer,code_natural_of_nat),nat2) ).

% Nat_def
tff(fact_4556_natural__of__integer_Oabs__eq,axiom,
    ! [X2: int] : aa(code_integer,code_natural,code_n4118661773612635043nteger,aa(int,code_integer,code_integer_of_int,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(int,nat,nat2,X2)) ).

% natural_of_integer.abs_eq
tff(fact_4557_natural__of__nat__of__natural__inverse,axiom,
    ! [N: code_natural] : aa(nat,code_natural,code_natural_of_nat,aa(code_natural,nat,code_nat_of_natural,N)) = N ).

% natural_of_nat_of_natural_inverse
tff(fact_4558_nat__of__natural__of__nat__inverse,axiom,
    ! [N: nat] : aa(code_natural,nat,code_nat_of_natural,aa(nat,code_natural,code_natural_of_nat,N)) = N ).

% nat_of_natural_of_nat_inverse
tff(fact_4559_nat__of__natural__inverse,axiom,
    ! [X2: code_natural] : aa(nat,code_natural,code_natural_of_nat,aa(code_natural,nat,code_nat_of_natural,X2)) = X2 ).

% nat_of_natural_inverse
tff(fact_4560_nat__of__natural__min,axiom,
    ! [K: code_natural,L: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,ord_min(code_natural,K),L)) = aa(nat,nat,ord_min(nat,aa(code_natural,nat,code_nat_of_natural,K)),aa(code_natural,nat,code_nat_of_natural,L)) ).

% nat_of_natural_min
tff(fact_4561_nat__of__natural__max,axiom,
    ! [K: code_natural,L: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,ord_max(code_natural,K),L)) = aa(nat,nat,ord_max(nat,aa(code_natural,nat,code_nat_of_natural,K)),aa(code_natural,nat,code_nat_of_natural,L)) ).

% nat_of_natural_max
tff(fact_4562_of__nat__of__natural,axiom,
    ! [N: code_natural] : aa(nat,code_natural,semiring_1_of_nat(code_natural),aa(code_natural,nat,code_nat_of_natural,N)) = N ).

% of_nat_of_natural
tff(fact_4563_nat__of__natural__of__nat,axiom,
    ! [N: nat] : aa(code_natural,nat,code_nat_of_natural,aa(nat,code_natural,semiring_1_of_nat(code_natural),N)) = N ).

% nat_of_natural_of_nat
tff(fact_4564_zero__natural_Orep__eq,axiom,
    aa(code_natural,nat,code_nat_of_natural,zero_zero(code_natural)) = zero_zero(nat) ).

% zero_natural.rep_eq
tff(fact_4565_one__natural_Orep__eq,axiom,
    aa(code_natural,nat,code_nat_of_natural,one_one(code_natural)) = one_one(nat) ).

% one_natural.rep_eq
tff(fact_4566_plus__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% plus_natural.rep_eq
tff(fact_4567_minus__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% minus_natural.rep_eq
tff(fact_4568_nat__of__natural__numeral,axiom,
    ! [K: num] : aa(code_natural,nat,code_nat_of_natural,aa(num,code_natural,numeral_numeral(code_natural),K)) = aa(num,nat,numeral_numeral(nat),K) ).

% nat_of_natural_numeral
tff(fact_4569_times__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% times_natural.rep_eq
tff(fact_4570_divide__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),divide_divide(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),divide_divide(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% divide_natural.rep_eq
tff(fact_4571_modulo__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),modulo_modulo(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% modulo_natural.rep_eq
tff(fact_4572_division__segment__natural_Orep__eq,axiom,
    ! [X2: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,euclid7384307370059645450egment(code_natural),X2)) = aa(nat,nat,euclid7384307370059645450egment(nat),aa(code_natural,nat,code_nat_of_natural,X2)) ).

% division_segment_natural.rep_eq
tff(fact_4573_euclidean__size__natural_Orep__eq,axiom,
    ! [X2: code_natural] : aa(code_natural,nat,euclid6346220572633701492n_size(code_natural),X2) = aa(nat,nat,euclid6346220572633701492n_size(nat),aa(code_natural,nat,code_nat_of_natural,X2)) ).

% euclidean_size_natural.rep_eq
tff(fact_4574_unset__bit__natural_Orep__eq,axiom,
    ! [X2: nat,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se2638667681897837118et_bit(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se2638667681897837118et_bit(nat),X2),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% unset_bit_natural.rep_eq
tff(fact_4575_flip__bit__natural_Orep__eq,axiom,
    ! [X2: nat,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se8732182000553998342ip_bit(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se8732182000553998342ip_bit(nat),X2),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% flip_bit_natural.rep_eq
tff(fact_4576_set__bit__natural_Orep__eq,axiom,
    ! [X2: nat,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se5668285175392031749et_bit(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se5668285175392031749et_bit(nat),X2),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% set_bit_natural.rep_eq
tff(fact_4577_Nat_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_natural,nat,code_nat_of_natural,aa(code_integer,code_natural,code_Nat,X2)) = aa(int,nat,nat2,aa(code_integer,int,code_int_of_integer,X2)) ).

% Nat.rep_eq
tff(fact_4578_push__bit__natural_Orep__eq,axiom,
    ! [X2: nat,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se4730199178511100633sh_bit(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se4730199178511100633sh_bit(nat),X2),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% push_bit_natural.rep_eq
tff(fact_4579_mask__natural_Orep__eq,axiom,
    ! [X2: nat] : aa(code_natural,nat,code_nat_of_natural,aa(nat,code_natural,bit_se2239418461657761734s_mask(code_natural),X2)) = aa(nat,nat,bit_se2239418461657761734s_mask(nat),X2) ).

% mask_natural.rep_eq
tff(fact_4580_and__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),bit_se5824344872417868541ns_and(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344872417868541ns_and(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% and_natural.rep_eq
tff(fact_4581_bit__natural_Orep__eq,axiom,
    ! [X2: code_natural] : aa(code_natural,fun(nat,$o),bit_se5641148757651400278ts_bit(code_natural),X2) = aa(nat,fun(nat,$o),bit_se5641148757651400278ts_bit(nat),aa(code_natural,nat,code_nat_of_natural,X2)) ).

% bit_natural.rep_eq
tff(fact_4582_nat__of__natural__inject,axiom,
    ! [X2: code_natural,Y: code_natural] :
      ( ( aa(code_natural,nat,code_nat_of_natural,X2) = aa(code_natural,nat,code_nat_of_natural,Y) )
    <=> ( X2 = Y ) ) ).

% nat_of_natural_inject
tff(fact_4583_natural__eqI,axiom,
    ! [M: code_natural,N: code_natural] :
      ( ( aa(code_natural,nat,code_nat_of_natural,M) = aa(code_natural,nat,code_nat_of_natural,N) )
     => ( M = N ) ) ).

% natural_eqI
tff(fact_4584_natural__eq__iff,axiom,
    ! [M: code_natural,N: code_natural] :
      ( ( M = N )
    <=> ( aa(code_natural,nat,code_nat_of_natural,M) = aa(code_natural,nat,code_nat_of_natural,N) ) ) ).

% natural_eq_iff
tff(fact_4585_natural__cases,axiom,
    ! [M: code_natural] :
      ~ ! [N3: nat] : M != aa(nat,code_natural,semiring_1_of_nat(code_natural),N3) ).

% natural_cases
tff(fact_4586_nat__of__natural,axiom,
    ! [X2: code_natural] : member(nat,aa(code_natural,nat,code_nat_of_natural,X2),top_top(set(nat))) ).

% nat_of_natural
tff(fact_4587_nat__of__natural__cases,axiom,
    ! [Y: nat] :
      ( member(nat,Y,top_top(set(nat)))
     => ~ ! [X3: code_natural] : Y != aa(code_natural,nat,code_nat_of_natural,X3) ) ).

% nat_of_natural_cases
tff(fact_4588_nat__of__natural__induct,axiom,
    ! [Y: nat,P: fun(nat,$o)] :
      ( member(nat,Y,top_top(set(nat)))
     => ( ! [X3: code_natural] : aa(nat,$o,P,aa(code_natural,nat,code_nat_of_natural,X3))
       => aa(nat,$o,P,Y) ) ) ).

% nat_of_natural_induct
tff(fact_4589_take__bit__natural_Orep__eq,axiom,
    ! [X2: nat,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se2584673776208193580ke_bit(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se2584673776208193580ke_bit(nat),X2),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% take_bit_natural.rep_eq
tff(fact_4590_or__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),bit_se1065995026697491101ons_or(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se1065995026697491101ons_or(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% or_natural.rep_eq
tff(fact_4591_xor__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),bit_se5824344971392196577ns_xor(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se5824344971392196577ns_xor(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% xor_natural.rep_eq
tff(fact_4592_drop__bit__natural_Orep__eq,axiom,
    ! [X2: nat,Xa: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,aa(nat,fun(code_natural,code_natural),bit_se4197421643247451524op_bit(code_natural),X2),Xa)) = aa(nat,nat,aa(nat,fun(nat,nat),bit_se4197421643247451524op_bit(nat),X2),aa(code_natural,nat,code_nat_of_natural,Xa)) ).

% drop_bit_natural.rep_eq
tff(fact_4593_natural__of__integer_Orep__eq,axiom,
    ! [X2: code_integer] : aa(code_natural,nat,code_nat_of_natural,aa(code_integer,code_natural,code_n4118661773612635043nteger,X2)) = aa(int,nat,nat2,aa(code_integer,int,code_int_of_integer,X2)) ).

% natural_of_integer.rep_eq
tff(fact_4594_less__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] :
      ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),X2),Xa)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ) ).

% less_natural.rep_eq
tff(fact_4595_natural__of__nat__inverse,axiom,
    ! [Y: nat] :
      ( member(nat,Y,top_top(set(nat)))
     => ( aa(code_natural,nat,code_nat_of_natural,aa(nat,code_natural,code_natural_of_nat,Y)) = Y ) ) ).

% natural_of_nat_inverse
tff(fact_4596_type__definition__natural,axiom,
    type_definition(code_natural,nat,code_nat_of_natural,code_natural_of_nat,top_top(set(nat))) ).

% type_definition_natural
tff(fact_4597_or__natural__def,axiom,
    bit_se1065995026697491101ons_or(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se1065995026697491101ons_or(nat)) ).

% or_natural_def
tff(fact_4598_xor__natural__def,axiom,
    bit_se5824344971392196577ns_xor(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se5824344971392196577ns_xor(nat)) ).

% xor_natural_def
tff(fact_4599_and__natural__def,axiom,
    bit_se5824344872417868541ns_and(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se5824344872417868541ns_and(nat)) ).

% and_natural_def
tff(fact_4600_less__eq__natural_Orep__eq,axiom,
    ! [X2: code_natural,Xa: code_natural] :
      ( aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less_eq(code_natural),X2),Xa)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(code_natural,nat,code_nat_of_natural,X2)),aa(code_natural,nat,code_nat_of_natural,Xa)) ) ).

% less_eq_natural.rep_eq
tff(fact_4601_division__segment__natural__def,axiom,
    euclid7384307370059645450egment(code_natural) = aa(fun(nat,nat),fun(code_natural,code_natural),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat),euclid7384307370059645450egment(nat)) ).

% division_segment_natural_def
tff(fact_4602_euclidean__size__natural__def,axiom,
    euclid6346220572633701492n_size(code_natural) = aa(fun(nat,nat),fun(code_natural,nat),map_fun(code_natural,nat,nat,nat,code_nat_of_natural,id(nat)),euclid6346220572633701492n_size(nat)) ).

% euclidean_size_natural_def
tff(fact_4603_plus__natural__def,axiom,
    plus_plus(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),plus_plus(nat)) ).

% plus_natural_def
tff(fact_4604_minus__natural__def,axiom,
    minus_minus(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),minus_minus(nat)) ).

% minus_natural_def
tff(fact_4605_bit__natural__def,axiom,
    bit_se5641148757651400278ts_bit(code_natural) = aa(fun(nat,fun(nat,$o)),fun(code_natural,fun(nat,$o)),map_fun(code_natural,nat,fun(nat,$o),fun(nat,$o),code_nat_of_natural,id(fun(nat,$o))),bit_se5641148757651400278ts_bit(nat)) ).

% bit_natural_def
tff(fact_4606_less__natural__def,axiom,
    ord_less(code_natural) = aa(fun(nat,fun(nat,$o)),fun(code_natural,fun(code_natural,$o)),map_fun(code_natural,nat,fun(nat,$o),fun(code_natural,$o),code_nat_of_natural,map_fun(code_natural,nat,$o,$o,code_nat_of_natural,id($o))),ord_less(nat)) ).

% less_natural_def
tff(fact_4607_times__natural__def,axiom,
    times_times(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),times_times(nat)) ).

% times_natural_def
tff(fact_4608_divide__natural__def,axiom,
    divide_divide(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),divide_divide(nat)) ).

% divide_natural_def
tff(fact_4609_take__bit__natural__def,axiom,
    bit_se2584673776208193580ke_bit(code_natural) = aa(fun(nat,fun(nat,nat)),fun(nat,fun(code_natural,code_natural)),map_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),id(nat),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se2584673776208193580ke_bit(nat)) ).

% take_bit_natural_def
tff(fact_4610_push__bit__natural__def,axiom,
    bit_se4730199178511100633sh_bit(code_natural) = aa(fun(nat,fun(nat,nat)),fun(nat,fun(code_natural,code_natural)),map_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),id(nat),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se4730199178511100633sh_bit(nat)) ).

% push_bit_natural_def
tff(fact_4611_less__eq__natural__def,axiom,
    ord_less_eq(code_natural) = aa(fun(nat,fun(nat,$o)),fun(code_natural,fun(code_natural,$o)),map_fun(code_natural,nat,fun(nat,$o),fun(code_natural,$o),code_nat_of_natural,map_fun(code_natural,nat,$o,$o,code_nat_of_natural,id($o))),ord_less_eq(nat)) ).

% less_eq_natural_def
tff(fact_4612_modulo__natural__def,axiom,
    modulo_modulo(code_natural) = aa(fun(nat,fun(nat,nat)),fun(code_natural,fun(code_natural,code_natural)),map_fun(code_natural,nat,fun(nat,nat),fun(code_natural,code_natural),code_nat_of_natural,map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),modulo_modulo(nat)) ).

% modulo_natural_def
tff(fact_4613_drop__bit__natural__def,axiom,
    bit_se4197421643247451524op_bit(code_natural) = aa(fun(nat,fun(nat,nat)),fun(nat,fun(code_natural,code_natural)),map_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),id(nat),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se4197421643247451524op_bit(nat)) ).

% drop_bit_natural_def
tff(fact_4614_unset__bit__natural__def,axiom,
    bit_se2638667681897837118et_bit(code_natural) = aa(fun(nat,fun(nat,nat)),fun(nat,fun(code_natural,code_natural)),map_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),id(nat),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se2638667681897837118et_bit(nat)) ).

% unset_bit_natural_def
tff(fact_4615_flip__bit__natural__def,axiom,
    bit_se8732182000553998342ip_bit(code_natural) = aa(fun(nat,fun(nat,nat)),fun(nat,fun(code_natural,code_natural)),map_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),id(nat),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se8732182000553998342ip_bit(nat)) ).

% flip_bit_natural_def
tff(fact_4616_set__bit__natural__def,axiom,
    bit_se5668285175392031749et_bit(code_natural) = aa(fun(nat,fun(nat,nat)),fun(nat,fun(code_natural,code_natural)),map_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),id(nat),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat)),bit_se5668285175392031749et_bit(nat)) ).

% set_bit_natural_def
tff(fact_4617_natural__decr,axiom,
    ! [N: code_natural] :
      ( ( N != zero_zero(code_natural) )
     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(code_natural,nat,code_nat_of_natural,N)),aa(nat,nat,suc,zero_zero(nat)))),aa(code_natural,nat,code_nat_of_natural,N)) ) ).

% natural_decr
tff(fact_4618_natural__of__integer__def,axiom,
    code_n4118661773612635043nteger = aa(fun(int,nat),fun(code_integer,code_natural),map_fun(code_integer,int,nat,code_natural,code_int_of_integer,code_natural_of_nat),nat2) ).

% natural_of_integer_def
tff(fact_4619_integer__of__natural__of__integer,axiom,
    ! [K: code_integer] : aa(code_natural,code_integer,code_i5400310926305786745atural,aa(code_integer,code_natural,code_n4118661773612635043nteger,K)) = aa(code_integer,code_integer,ord_max(code_integer,zero_zero(code_integer)),K) ).

% integer_of_natural_of_integer
tff(fact_4620_integer__of__natural_Orep__eq,axiom,
    ! [X2: code_natural] : aa(code_integer,int,code_int_of_integer,aa(code_natural,code_integer,code_i5400310926305786745atural,X2)) = aa(nat,int,semiring_1_of_nat(int),aa(code_natural,nat,code_nat_of_natural,X2)) ).

% integer_of_natural.rep_eq
tff(fact_4621_int__of__integer__of__natural,axiom,
    ! [N: code_natural] : aa(code_integer,int,code_int_of_integer,aa(code_natural,code_integer,code_i5400310926305786745atural,N)) = aa(nat,int,semiring_1_of_nat(int),aa(code_natural,nat,code_nat_of_natural,N)) ).

% int_of_integer_of_natural
tff(fact_4622_integer__of__natural__of__nat,axiom,
    ! [N: nat] : aa(code_natural,code_integer,code_i5400310926305786745atural,aa(nat,code_natural,semiring_1_of_nat(code_natural),N)) = aa(nat,code_integer,semiring_1_of_nat(code_integer),N) ).

% integer_of_natural_of_nat
tff(fact_4623_natural__of__integer__of__natural,axiom,
    ! [N: code_natural] : aa(code_integer,code_natural,code_n4118661773612635043nteger,aa(code_natural,code_integer,code_i5400310926305786745atural,N)) = N ).

% natural_of_integer_of_natural
tff(fact_4624_integer__of__natural__def,axiom,
    code_i5400310926305786745atural = aa(fun(nat,int),fun(code_natural,code_integer),map_fun(code_natural,nat,int,code_integer,code_nat_of_natural,code_integer_of_int),semiring_1_of_nat(int)) ).

% integer_of_natural_def
tff(fact_4625_integer__of__natural_Oabs__eq,axiom,
    ! [X2: nat] : aa(code_natural,code_integer,code_i5400310926305786745atural,aa(nat,code_natural,code_natural_of_nat,X2)) = aa(int,code_integer,code_integer_of_int,aa(nat,int,semiring_1_of_nat(int),X2)) ).

% integer_of_natural.abs_eq
tff(fact_4626_Code__Numeral_Osize__nat__def,axiom,
    code_size_nat = code_nat_of_natural ).

% Code_Numeral.size_nat_def
tff(fact_4627_Code__Numeral_OSuc__def,axiom,
    code_Suc = aa(fun(nat,nat),fun(code_natural,code_natural),map_fun(code_natural,nat,nat,code_natural,code_nat_of_natural,code_natural_of_nat),suc) ).

% Code_Numeral.Suc_def
tff(fact_4628_sum__mset_Ounion__disjoint,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [A4: multiset(B),B5: multiset(B),G: fun(B,C)] :
          ( ( inter_mset(B,A4,B5) = zero_zero(multiset(B)) )
         => ( aa(multiset(C),C,comm_m7189776963980413722m_mset(C),aa(multiset(B),multiset(C),image_mset(B,C,G),union_mset(B,A4,B5))) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(multiset(C),C,comm_m7189776963980413722m_mset(C),aa(multiset(B),multiset(C),image_mset(B,C,G),A4))),aa(multiset(C),C,comm_m7189776963980413722m_mset(C),aa(multiset(B),multiset(C),image_mset(B,C,G),B5))) ) ) ) ).

% sum_mset.union_disjoint
tff(fact_4629_natural_Oinject,axiom,
    ! [Natural: code_natural,Natural2: code_natural] :
      ( ( aa(code_natural,code_natural,code_Suc,Natural) = aa(code_natural,code_natural,code_Suc,Natural2) )
    <=> ( Natural = Natural2 ) ) ).

% natural.inject
tff(fact_4630_natural_Osimps_I7_J,axiom,
    ! [B: $tType,F1: B,F22: fun(code_natural,fun(B,B)),Natural: code_natural] : aa(code_natural,B,code_rec_natural(B,F1,F22),aa(code_natural,code_natural,code_Suc,Natural)) = aa(B,B,aa(code_natural,fun(B,B),F22,Natural),aa(code_natural,B,code_rec_natural(B,F1,F22),Natural)) ).

% natural.simps(7)
tff(fact_4631_natural_Osimps_I5_J,axiom,
    ! [B: $tType,F1: B,F22: fun(code_natural,B),Natural: code_natural] : aa(code_natural,B,code_case_natural(B,F1,F22),aa(code_natural,code_natural,code_Suc,Natural)) = aa(code_natural,B,F22,Natural) ).

% natural.simps(5)
tff(fact_4632_Suc_Orep__eq,axiom,
    ! [X2: code_natural] : aa(code_natural,nat,code_nat_of_natural,aa(code_natural,code_natural,code_Suc,X2)) = aa(nat,nat,suc,aa(code_natural,nat,code_nat_of_natural,X2)) ).

% Suc.rep_eq
tff(fact_4633_union__sup__distrib__right,axiom,
    ! [B: $tType,C5: multiset(B),A4: multiset(B),B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),union_mset(B,A4,B5)) = union_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),C5),B5)) ).

% union_sup_distrib_right
tff(fact_4634_sup__union__distrib__left,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B),C5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),union_mset(B,A4,B5)),C5) = union_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),C5),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),B5),C5)) ).

% sup_union_distrib_left
tff(fact_4635_natural_Oexhaust,axiom,
    ! [Y: code_natural] :
      ( ( Y != zero_zero(code_natural) )
     => ~ ! [Natural3: code_natural] : Y != aa(code_natural,code_natural,code_Suc,Natural3) ) ).

% natural.exhaust
tff(fact_4636_natural_Odistinct_I1_J,axiom,
    ! [Natural2: code_natural] : zero_zero(code_natural) != aa(code_natural,code_natural,code_Suc,Natural2) ).

% natural.distinct(1)
tff(fact_4637_natural_Odistinct_I2_J,axiom,
    ! [Natural2: code_natural] : aa(code_natural,code_natural,code_Suc,Natural2) != zero_zero(code_natural) ).

% natural.distinct(2)
tff(fact_4638_union__mset__def,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : union_mset(B,A4,B5) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),B5),A4)) ).

% union_mset_def
tff(fact_4639_union__diff__inter__eq__sup,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),inter_mset(B,A4,B5)) = union_mset(B,A4,B5) ).

% union_diff_inter_eq_sup
tff(fact_4640_union__diff__sup__eq__inter,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)),union_mset(B,A4,B5)) = inter_mset(B,A4,B5) ).

% union_diff_sup_eq_inter
tff(fact_4641_size__Un__Int,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] : aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(multiset(B),nat,size_size(multiset(B)),A4)),aa(multiset(B),nat,size_size(multiset(B)),B5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(multiset(B),nat,size_size(multiset(B)),union_mset(B,A4,B5))),aa(multiset(B),nat,size_size(multiset(B)),inter_mset(B,A4,B5))) ).

% size_Un_Int
tff(fact_4642_Suc_Oabs__eq,axiom,
    ! [X2: nat] : aa(code_natural,code_natural,code_Suc,aa(nat,code_natural,code_natural_of_nat,X2)) = aa(nat,code_natural,code_natural_of_nat,aa(nat,nat,suc,X2)) ).

% Suc.abs_eq
tff(fact_4643_Suc__natural__minus__one,axiom,
    ! [N: code_natural] : aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),minus_minus(code_natural),aa(code_natural,code_natural,code_Suc,N)),one_one(code_natural)) = N ).

% Suc_natural_minus_one
tff(fact_4644_size__Un__disjoint,axiom,
    ! [B: $tType,A4: multiset(B),B5: multiset(B)] :
      ( ( inter_mset(B,A4,B5) = zero_zero(multiset(B)) )
     => ( aa(multiset(B),nat,size_size(multiset(B)),union_mset(B,A4,B5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(multiset(B),nat,size_size(multiset(B)),A4)),aa(multiset(B),nat,size_size(multiset(B)),B5)) ) ) ).

% size_Un_disjoint
tff(fact_4645_random__aux__set_Ocases,axiom,
    ! [X2: product_prod(code_natural,code_natural)] :
      ( ! [J3: code_natural] : X2 != aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),zero_zero(code_natural)),J3)
     => ~ ! [I2: code_natural,J3: code_natural] : X2 != aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),aa(code_natural,code_natural,code_Suc,I2)),J3) ) ).

% random_aux_set.cases
tff(fact_4646_Eps__Opt__def,axiom,
    ! [B: $tType,P: fun(B,$o)] :
      eps_Opt(B,P) = $ite(
        ? [X9: B] : aa(B,$o,P,X9),
        aa(B,option(B),some(B),fChoice(B,P)),
        none(B) ) ).

% Eps_Opt_def
tff(fact_4647_acyclic__insert,axiom,
    ! [B: $tType,Y: B,X2: B,R: set(product_prod(B,B))] :
      ( transitive_acyclic(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2)),R))
    <=> ( transitive_acyclic(B,R)
        & ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R)) ) ) ).

% acyclic_insert
tff(fact_4648_acyclic__empty,axiom,
    ! [B: $tType] : transitive_acyclic(B,bot_bot(set(product_prod(B,B)))) ).

% acyclic_empty
tff(fact_4649_Eps__case__prod__eq,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: C] : fChoice(product_prod(B,C),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(C,fun(B,fun(C,$o)),aTP_Lamp_ne(B,fun(C,fun(B,fun(C,$o))),X2),Y))) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y) ).

% Eps_case_prod_eq
tff(fact_4650_some__insert__self,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( S2 != bot_bot(set(B)) )
     => ( aa(set(B),set(B),insert2(B,fChoice(B,aTP_Lamp_a(set(B),fun(B,$o),S2))),S2) = S2 ) ) ).

% some_insert_self
tff(fact_4651_some__elem,axiom,
    ! [B: $tType,S2: set(B)] :
      ( ( S2 != bot_bot(set(B)) )
     => member(B,fChoice(B,aTP_Lamp_a(set(B),fun(B,$o),S2)),S2) ) ).

% some_elem
tff(fact_4652_cyclic__subset,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),S2: set(product_prod(B,B))] :
      ( ~ transitive_acyclic(B,R4)
     => ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),S2)
       => ~ transitive_acyclic(B,S2) ) ) ).

% cyclic_subset
tff(fact_4653_acyclic__union_I1_J,axiom,
    ! [B: $tType,A4: set(product_prod(B,B)),B5: set(product_prod(B,B))] :
      ( transitive_acyclic(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),A4),B5))
     => transitive_acyclic(B,A4) ) ).

% acyclic_union(1)
tff(fact_4654_acyclic__union_I2_J,axiom,
    ! [B: $tType,A4: set(product_prod(B,B)),B5: set(product_prod(B,B))] :
      ( transitive_acyclic(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),sup_sup(set(product_prod(B,B))),A4),B5))
     => transitive_acyclic(B,B5) ) ).

% acyclic_union(2)
tff(fact_4655_inv__on__def,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),X2: C] : aa(C,B,inv_on(B,C,F,A4),X2) = fChoice(B,aa(C,fun(B,$o),aa(set(B),fun(C,fun(B,$o)),aTP_Lamp_nd(fun(B,C),fun(set(B),fun(C,fun(B,$o))),F),A4),X2)) ).

% inv_on_def
tff(fact_4656_split__paired__Eps,axiom,
    ! [C: $tType,B: $tType,P: fun(product_prod(B,C),$o)] : fChoice(product_prod(B,C),P) = fChoice(product_prod(B,C),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_tb(fun(product_prod(B,C),$o),fun(B,fun(C,$o)),P))) ).

% split_paired_Eps
tff(fact_4657_acyclicI__order,axiom,
    ! [C: $tType,B: $tType] :
      ( preorder(C)
     => ! [R: set(product_prod(B,B)),F: fun(B,C)] :
          ( ! [A5: B,B3: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),B3),R)
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(B,C,F,B3)),aa(B,C,F,A5)) )
         => transitive_acyclic(B,R) ) ) ).

% acyclicI_order
tff(fact_4658_subset__mset_OacyclicI__order,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),F: fun(B,multiset(C))] :
      ( ! [A5: B,B3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),B3),R)
         => subset_mset(C,aa(B,multiset(C),F,B3),aa(B,multiset(C),F,A5)) )
     => transitive_acyclic(B,R) ) ).

% subset_mset.acyclicI_order
tff(fact_4659_acyclicI,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),transitive_trancl(B,R))
     => transitive_acyclic(B,R) ) ).

% acyclicI
tff(fact_4660_acyclic__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( transitive_acyclic(B,R)
    <=> ! [X4: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),X4),transitive_trancl(B,R)) ) ).

% acyclic_def
tff(fact_4661_cyclicE,axiom,
    ! [B: $tType,G: set(product_prod(B,B))] :
      ( ~ transitive_acyclic(B,G)
     => ~ ! [X3: B] : ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),X3),transitive_trancl(B,G)) ) ).

% cyclicE
tff(fact_4662_some__theI,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o))] :
      ( ? [A14: B,X_12: C] : aa(C,$o,aa(B,fun(C,$o),P,A14),X_12)
     => ( ! [B12: C,B23: C] :
            ( ? [A5: B] : aa(C,$o,aa(B,fun(C,$o),P,A5),B12)
           => ( ? [A5: B] : aa(C,$o,aa(B,fun(C,$o),P,A5),B23)
             => ( B12 = B23 ) ) )
       => aa(C,$o,aa(B,fun(C,$o),P,fChoice(B,aTP_Lamp_tc(fun(B,fun(C,$o)),fun(B,$o),P))),the(C,aTP_Lamp_td(fun(B,fun(C,$o)),fun(C,$o),P))) ) ) ).

% some_theI
tff(fact_4663_acyclic__insert__cyclic,axiom,
    ! [B: $tType,G: set(product_prod(B,B)),X2: B,Y: B] :
      ( transitive_acyclic(B,G)
     => ( ~ transitive_acyclic(B,aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y)),G))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2),transitive_rtrancl(B,G)) ) ) ).

% acyclic_insert_cyclic
tff(fact_4664_fun__of__rel__def,axiom,
    ! [B: $tType,C: $tType,R4: set(product_prod(C,B)),X2: C] : fun_of_rel(C,B,R4,X2) = fChoice(B,aa(C,fun(B,$o),aTP_Lamp_au(set(product_prod(C,B)),fun(C,fun(B,$o)),R4),X2)) ).

% fun_of_rel_def
tff(fact_4665_irrefl__tranclI,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: B] :
      ( ( aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),converse(B,B,R)),transitive_rtrancl(B,R)) = bot_bot(set(product_prod(B,B))) )
     => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),X2),transitive_trancl(B,R)) ) ).

% irrefl_tranclI
tff(fact_4666_quicksort_Opelims,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [X2: list(B),Y: list(B)] :
          ( ( linorder_quicksort(B,X2) = Y )
         => ( aa(list(B),$o,accp(list(B),linord6200660962353139674rt_rel(B)),X2)
           => ( ( ( X2 = nil(B) )
               => ( ( Y = nil(B) )
                 => ~ aa(list(B),$o,accp(list(B),linord6200660962353139674rt_rel(B)),nil(B)) ) )
             => ~ ! [X3: B,Xs: list(B)] :
                    ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs) )
                   => ( ( Y = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),linorder_quicksort(B,filter(B,aTP_Lamp_te(B,fun(B,$o),X3),Xs))),aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B))),linorder_quicksort(B,filter(B,aa(B,fun(B,$o),ord_less_eq(B),X3),Xs)))) )
                     => ~ aa(list(B),$o,accp(list(B),linord6200660962353139674rt_rel(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)) ) ) ) ) ) ) ).

% quicksort.pelims
tff(fact_4667_converse__iff,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,R: set(product_prod(C,B))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),converse(C,B,R))
    <=> member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),B2),A3),R) ) ).

% converse_iff
tff(fact_4668_pair__set__inverse,axiom,
    ! [B: $tType,C: $tType,P: fun(C,fun(B,$o))] : converse(C,B,aa(fun(product_prod(C,B),$o),set(product_prod(C,B)),collect(product_prod(C,B)),aa(fun(C,fun(B,$o)),fun(product_prod(C,B),$o),product_case_prod(C,B,$o),P))) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_tf(fun(C,fun(B,$o)),fun(B,fun(C,$o)),P))) ).

% pair_set_inverse
tff(fact_4669_below__Id__inv,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),converse(B,B,R4)),id2(B))
    <=> aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),id2(B)) ) ).

% below_Id_inv
tff(fact_4670_converseI,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,R: set(product_prod(B,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R)
     => member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),B2),A3),converse(B,C,R)) ) ).

% converseI
tff(fact_4671_converseE,axiom,
    ! [B: $tType,C: $tType,Yx: product_prod(B,C),R: set(product_prod(C,B))] :
      ( member(product_prod(B,C),Yx,converse(C,B,R))
     => ~ ! [X3: C,Y4: B] :
            ( ( Yx = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Y4),X3) )
           => ~ member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X3),Y4),R) ) ) ).

% converseE
tff(fact_4672_converseD,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,R: set(product_prod(C,B))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),converse(C,B,R))
     => member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),B2),A3),R) ) ).

% converseD
tff(fact_4673_converse_Osimps,axiom,
    ! [B: $tType,C: $tType,A1: B,A22: C,R: set(product_prod(C,B))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A1),A22),converse(C,B,R))
    <=> ? [A7: C,B7: B] :
          ( ( A1 = B7 )
          & ( A22 = A7 )
          & member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A7),B7),R) ) ) ).

% converse.simps
tff(fact_4674_converse_Ocases,axiom,
    ! [B: $tType,C: $tType,A1: B,A22: C,R: set(product_prod(C,B))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A1),A22),converse(C,B,R))
     => member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A22),A1),R) ) ).

% converse.cases
tff(fact_4675_in__listrel1__converse,axiom,
    ! [B: $tType,X2: list(B),Y: list(B),R: set(product_prod(B,B))] :
      ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),listrel1(B,converse(B,B,R)))
    <=> member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),X2),Y),converse(list(B),list(B),listrel1(B,R))) ) ).

% in_listrel1_converse
tff(fact_4676_rtrancl__converseI,axiom,
    ! [B: $tType,Y: B,X2: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2),transitive_rtrancl(B,R))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,converse(B,B,R))) ) ).

% rtrancl_converseI
tff(fact_4677_rtrancl__converseD,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,converse(B,B,R)))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2),transitive_rtrancl(B,R)) ) ).

% rtrancl_converseD
tff(fact_4678_trancl__converseI,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),converse(B,B,transitive_trancl(B,R)))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,converse(B,B,R))) ) ).

% trancl_converseI
tff(fact_4679_trancl__converseD,axiom,
    ! [B: $tType,X2: B,Y: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_trancl(B,converse(B,B,R)))
     => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),converse(B,B,transitive_trancl(B,R))) ) ).

% trancl_converseD
tff(fact_4680_finite__wf__eq__wf__converse,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( finite_finite2(product_prod(B,B),R4)
     => ( wf(B,converse(B,B,R4))
      <=> wf(B,R4) ) ) ).

% finite_wf_eq_wf_converse
tff(fact_4681_converse__unfold,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(C,B))] : converse(C,B,R) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aTP_Lamp_tg(set(product_prod(C,B)),fun(B,fun(C,$o)),R))) ).

% converse_unfold
tff(fact_4682_conversep__converse__eq,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(C,B)),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),conversep(C,B,aTP_Lamp_au(set(product_prod(C,B)),fun(C,fun(B,$o)),R)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),converse(C,B,R)) ) ).

% conversep_converse_eq
tff(fact_4683_converse__def,axiom,
    ! [C: $tType,B: $tType,X: set(product_prod(B,C))] : converse(B,C,X) = aa(fun(product_prod(C,B),$o),set(product_prod(C,B)),collect(product_prod(C,B)),aa(fun(C,fun(B,$o)),fun(product_prod(C,B),$o),product_case_prod(C,B,$o),conversep(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),X)))) ).

% converse_def
tff(fact_4684_is__singleton__altdef,axiom,
    ! [B: $tType,A4: set(B)] :
      ( is_singleton(B,A4)
    <=> ( finite_card(B,A4) = one_one(nat) ) ) ).

% is_singleton_altdef
tff(fact_4685_Code__Numeral_Osub__code_I2_J,axiom,
    ! [M: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,aa(num,num,bit0,M)),one2) = aa(num,code_integer,code_Pos,bitM(M)) ).

% Code_Numeral.sub_code(2)
tff(fact_4686_su__rel__fun__def,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C)] :
      ( su_rel_fun(B,C,F5,F)
    <=> ( ! [A8: B,B9: C,B10: C] :
            ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A8),B9),F5)
           => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A8),B10),F5)
             => ( B9 = B10 ) ) )
        & ! [A8: B,P5: $o] :
            ( ! [B9: C] :
                ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A8),B9),F5)
               => (P5) )
           => (P5) )
        & ! [A8: B] : aa(B,C,F,A8) = the(C,aa(B,fun(C,$o),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),F5),A8)) ) ) ).

% su_rel_fun_def
tff(fact_4687_Code__Numeral_OPos__def,axiom,
    code_Pos = numeral_numeral(code_integer) ).

% Code_Numeral.Pos_def
tff(fact_4688_su__rel__fun_Osurjective,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C),A4: B] :
      ( su_rel_fun(B,C,F5,F)
     => ~ ! [B8: C] : ~ member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A4),B8),F5) ) ).

% su_rel_fun.surjective
tff(fact_4689_su__rel__fun_Ounique,axiom,
    ! [B: $tType,C: $tType,F5: set(product_prod(B,C)),F: fun(B,C),A4: B,B5: C,B11: C] :
      ( su_rel_fun(B,C,F5,F)
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A4),B5),F5)
       => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A4),B11),F5)
         => ( B5 = B11 ) ) ) ) ).

% su_rel_fun.unique
tff(fact_4690_su__rel__fun_Orepr2,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C),A4: B,B5: C] :
      ( su_rel_fun(B,C,F5,F)
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A4),B5),F5)
       => ( B5 = aa(B,C,F,A4) ) ) ) ).

% su_rel_fun.repr2
tff(fact_4691_su__rel__fun_Orepr1,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C),A4: B] :
      ( su_rel_fun(B,C,F5,F)
     => member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A4),aa(B,C,F,A4)),F5) ) ).

% su_rel_fun.repr1
tff(fact_4692_su__rel__fun_Orepr,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C),A4: B,B5: C] :
      ( su_rel_fun(B,C,F5,F)
     => ( ( aa(B,C,F,A4) = B5 )
      <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A4),B5),F5) ) ) ).

% su_rel_fun.repr
tff(fact_4693_Pos__fold_I2_J,axiom,
    ! [K: num] : aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,K)) = aa(num,code_integer,code_Pos,aa(num,num,bit0,K)) ).

% Pos_fold(2)
tff(fact_4694_Pos__fold_I1_J,axiom,
    aa(num,code_integer,numeral_numeral(code_integer),one2) = aa(num,code_integer,code_Pos,one2) ).

% Pos_fold(1)
tff(fact_4695_Pos__fold_I3_J,axiom,
    ! [K: num] : aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit1,K)) = aa(num,code_integer,code_Pos,aa(num,num,bit1,K)) ).

% Pos_fold(3)
tff(fact_4696_one__integer__code,axiom,
    one_one(code_integer) = aa(num,code_integer,code_Pos,one2) ).

% one_integer_code
tff(fact_4697_Code__Numeral_Odup__code_I2_J,axiom,
    ! [N: num] : aa(code_integer,code_integer,code_dup,aa(num,code_integer,code_Pos,N)) = aa(num,code_integer,code_Pos,aa(num,num,bit0,N)) ).

% Code_Numeral.dup_code(2)
tff(fact_4698_less__integer__code_I4_J,axiom,
    ! [K: num] : ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),aa(num,code_integer,code_Pos,K)),zero_zero(code_integer)) ).

% less_integer_code(4)
tff(fact_4699_less__integer__code_I2_J,axiom,
    ! [L: num] : aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),zero_zero(code_integer)),aa(num,code_integer,code_Pos,L)) ).

% less_integer_code(2)
tff(fact_4700_plus__integer__code_I3_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(num,code_integer,code_Pos,M)),aa(num,code_integer,code_Pos,N)) = aa(num,code_integer,code_Pos,aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% plus_integer_code(3)
tff(fact_4701_less__eq__integer__code_I2_J,axiom,
    ! [L: num] : aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),zero_zero(code_integer)),aa(num,code_integer,code_Pos,L)) ).

% less_eq_integer_code(2)
tff(fact_4702_less__eq__integer__code_I4_J,axiom,
    ! [K: num] : ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),aa(num,code_integer,code_Pos,K)),zero_zero(code_integer)) ).

% less_eq_integer_code(4)
tff(fact_4703_less__integer__code_I8_J,axiom,
    ! [K: num,L: num] : aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),code_Neg(K)),aa(num,code_integer,code_Pos,L)) ).

% less_integer_code(8)
tff(fact_4704_less__integer__code_I6_J,axiom,
    ! [K: num,L: num] : ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),aa(num,code_integer,code_Pos,K)),code_Neg(L)) ).

% less_integer_code(6)
tff(fact_4705_uminus__integer__code_I3_J,axiom,
    ! [M: num] : aa(code_integer,code_integer,uminus_uminus(code_integer),code_Neg(M)) = aa(num,code_integer,code_Pos,M) ).

% uminus_integer_code(3)
tff(fact_4706_uminus__integer__code_I2_J,axiom,
    ! [M: num] : aa(code_integer,code_integer,uminus_uminus(code_integer),aa(num,code_integer,code_Pos,M)) = code_Neg(M) ).

% uminus_integer_code(2)
tff(fact_4707_Code__Numeral_ONeg__def,axiom,
    ! [N: num] : code_Neg(N) = aa(code_integer,code_integer,uminus_uminus(code_integer),aa(num,code_integer,code_Pos,N)) ).

% Code_Numeral.Neg_def
tff(fact_4708_less__eq__integer__code_I8_J,axiom,
    ! [K: num,L: num] : aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),code_Neg(K)),aa(num,code_integer,code_Pos,L)) ).

% less_eq_integer_code(8)
tff(fact_4709_less__eq__integer__code_I6_J,axiom,
    ! [K: num,L: num] : ~ aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),aa(num,code_integer,code_Pos,K)),code_Neg(L)) ).

% less_eq_integer_code(6)
tff(fact_4710_times__integer__code_I3_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(num,code_integer,code_Pos,M)),aa(num,code_integer,code_Pos,N)) = aa(num,code_integer,code_Pos,aa(num,num,aa(num,fun(num,num),times_times(num),M),N)) ).

% times_integer_code(3)
tff(fact_4711_less__integer__code_I5_J,axiom,
    ! [K: num,L: num] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),aa(num,code_integer,code_Pos,K)),aa(num,code_integer,code_Pos,L))
    <=> aa(num,$o,aa(num,fun(num,$o),ord_less(num),K),L) ) ).

% less_integer_code(5)
tff(fact_4712_less__eq__integer__code_I5_J,axiom,
    ! [K: num,L: num] :
      ( aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),aa(num,code_integer,code_Pos,K)),aa(num,code_integer,code_Pos,L))
    <=> aa(num,$o,aa(num,fun(num,$o),ord_less_eq(num),K),L) ) ).

% less_eq_integer_code(5)
tff(fact_4713_minus__integer__code_I3_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(num,code_integer,code_Pos,M)),aa(num,code_integer,code_Pos,N)) = aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,M),N) ).

% minus_integer_code(3)
tff(fact_4714_divmod__abs__code_I1_J,axiom,
    ! [K: num,L: num] : code_divmod_abs(aa(num,code_integer,code_Pos,K),aa(num,code_integer,code_Pos,L)) = unique8689654367752047608divmod(code_integer,K,L) ).

% divmod_abs_code(1)
tff(fact_4715_minus__integer__code_I4_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(num,code_integer,code_Pos,M)),code_Neg(N)) = aa(num,code_integer,code_Pos,aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% minus_integer_code(4)
tff(fact_4716_minus__integer__code_I5_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),code_Neg(M)),aa(num,code_integer,code_Pos,N)) = code_Neg(aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% minus_integer_code(5)
tff(fact_4717_times__integer__code_I4_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(num,code_integer,code_Pos,M)),code_Neg(N)) = code_Neg(aa(num,num,aa(num,fun(num,num),times_times(num),M),N)) ).

% times_integer_code(4)
tff(fact_4718_times__integer__code_I5_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),code_Neg(M)),aa(num,code_integer,code_Pos,N)) = code_Neg(aa(num,num,aa(num,fun(num,num),times_times(num),M),N)) ).

% times_integer_code(5)
tff(fact_4719_times__integer__code_I6_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),code_Neg(M)),code_Neg(N)) = aa(num,code_integer,code_Pos,aa(num,num,aa(num,fun(num,num),times_times(num),M),N)) ).

% times_integer_code(6)
tff(fact_4720_plus__integer__code_I4_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(num,code_integer,code_Pos,M)),code_Neg(N)) = aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,M),N) ).

% plus_integer_code(4)
tff(fact_4721_plus__integer__code_I5_J,axiom,
    ! [M: num,N: num] : aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),code_Neg(M)),aa(num,code_integer,code_Pos,N)) = aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,N),M) ).

% plus_integer_code(5)
tff(fact_4722_divmod__abs__code_I3_J,axiom,
    ! [K: num,L: num] : code_divmod_abs(code_Neg(K),aa(num,code_integer,code_Pos,L)) = unique8689654367752047608divmod(code_integer,K,L) ).

% divmod_abs_code(3)
tff(fact_4723_divmod__abs__code_I4_J,axiom,
    ! [K: num,L: num] : code_divmod_abs(aa(num,code_integer,code_Pos,K),code_Neg(L)) = unique8689654367752047608divmod(code_integer,K,L) ).

% divmod_abs_code(4)
tff(fact_4724_Code__Numeral_Osub__code_I3_J,axiom,
    ! [M: num] : aa(num,code_integer,aa(num,fun(num,code_integer),code_sub,aa(num,num,bit1,M)),one2) = aa(num,code_integer,code_Pos,aa(num,num,bit0,M)) ).

% Code_Numeral.sub_code(3)
tff(fact_4725_su__rel__fun_Of__def,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C),A4: B] :
      ( su_rel_fun(B,C,F5,F)
     => ( aa(B,C,F,A4) = the(C,aa(B,fun(C,$o),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),F5),A4)) ) ) ).

% su_rel_fun.f_def
tff(fact_4726_su__rel__fun_Ointro,axiom,
    ! [C: $tType,B: $tType,F5: set(product_prod(B,C)),F: fun(B,C)] :
      ( ! [A10: B,B8: C,B13: C] :
          ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A10),B8),F5)
         => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A10),B13),F5)
           => ( B8 = B13 ) ) )
     => ( ! [A10: B,P4: $o] :
            ( ! [B14: C] :
                ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A10),B14),F5)
               => (P4) )
           => (P4) )
       => ( ! [A10: B] : aa(B,C,F,A10) = the(C,aa(B,fun(C,$o),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),F5),A10))
         => su_rel_fun(B,C,F5,F) ) ) ) ).

% su_rel_fun.intro
tff(fact_4727_aboveS__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] : order_aboveS(B,R,A3) = aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),aTP_Lamp_th(set(product_prod(B,B)),fun(B,fun(B,$o)),R),A3)) ).

% aboveS_def
tff(fact_4728_relInvImage__def,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R4: set(product_prod(C,C)),F: fun(B,C)] : bNF_Gr7122648621184425601vImage(B,C,A4,R4,F) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,C),fun(product_prod(B,B),$o),aa(set(product_prod(C,C)),fun(fun(B,C),fun(product_prod(B,B),$o)),aTP_Lamp_ti(set(B),fun(set(product_prod(C,C)),fun(fun(B,C),fun(product_prod(B,B),$o))),A4),R4),F)) ).

% relInvImage_def
tff(fact_4729_prod__list__def,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ( groups5270119922927024881d_list(B) = groups_monoid_F(B,times_times(B),one_one(B)) ) ) ).

% prod_list_def
tff(fact_4730_sum__list__def,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ( groups8242544230860333062m_list(B) = groups_monoid_F(B,plus_plus(B),zero_zero(B)) ) ) ).

% sum_list_def
tff(fact_4731_sum__list__map__remove1,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [X2: B,Xsa: list(B),F: fun(B,C)] :
          ( member(B,X2,aa(list(B),set(B),set2(B),Xsa))
         => ( aa(list(C),C,groups8242544230860333062m_list(C),aa(list(B),list(C),map(B,C,F),Xsa)) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,F,X2)),aa(list(C),C,groups8242544230860333062m_list(C),aa(list(B),list(C),map(B,C,F),remove1(B,X2,Xsa)))) ) ) ) ).

% sum_list_map_remove1
tff(fact_4732_normalize__stable,axiom,
    ! [Q3: int,P3: int] :
      ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),Q3)
     => ( algebr8660921524188924756oprime(int,P3,Q3)
       => ( normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3)) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) ) ) ) ).

% normalize_stable
tff(fact_4733_distinct__count__atmost__1,axiom,
    ! [B: $tType,X2: list(B)] :
      ( distinct(B,X2)
    <=> ! [A7: B] :
          aa(B,nat,aa(multiset(B),fun(B,nat),count(B),mset(B,X2)),A7) = $ite(member(B,A7,aa(list(B),set(B),set2(B),X2)),one_one(nat),zero_zero(nat)) ) ).

% distinct_count_atmost_1
tff(fact_4734_coprime__self,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] :
          ( algebr8660921524188924756oprime(B,A3,A3)
        <=> dvd_dvd(B,A3,one_one(B)) ) ) ).

% coprime_self
tff(fact_4735_mset__empty__count,axiom,
    ! [B: $tType,M2: multiset(B)] :
      ( ! [P6: B] : aa(B,nat,aa(multiset(B),fun(B,nat),count(B),M2),P6) = zero_zero(nat)
    <=> ( M2 = zero_zero(multiset(B)) ) ) ).

% mset_empty_count
tff(fact_4736_coprime__imp__gcd__eq__1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          ( algebr8660921524188924756oprime(B,A3,B2)
         => ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2) = one_one(B) ) ) ) ).

% coprime_imp_gcd_eq_1
tff(fact_4737_count__union,axiom,
    ! [B: $tType,M2: multiset(B),N5: multiset(B),A3: B] : aa(B,nat,aa(multiset(B),fun(B,nat),count(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)),A3) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),M2),A3)),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),N5),A3)) ).

% count_union
tff(fact_4738_coprime__0__right__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] :
          ( algebr8660921524188924756oprime(B,A3,zero_zero(B))
        <=> dvd_dvd(B,A3,one_one(B)) ) ) ).

% coprime_0_right_iff
tff(fact_4739_coprime__0__left__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] :
          ( algebr8660921524188924756oprime(B,zero_zero(B),A3)
        <=> dvd_dvd(B,A3,one_one(B)) ) ) ).

% coprime_0_left_iff
tff(fact_4740_coprime__mult__self__right__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,C2: B,B2: B] :
          ( algebr8660921524188924756oprime(B,aa(B,B,aa(B,fun(B,B),times_times(B),A3),C2),aa(B,B,aa(B,fun(B,B),times_times(B),B2),C2))
        <=> ( dvd_dvd(B,C2,one_one(B))
            & algebr8660921524188924756oprime(B,A3,B2) ) ) ) ).

% coprime_mult_self_right_iff
tff(fact_4741_coprime__mult__self__left__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [C2: B,A3: B,B2: B] :
          ( algebr8660921524188924756oprime(B,aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3),aa(B,B,aa(B,fun(B,B),times_times(B),C2),B2))
        <=> ( dvd_dvd(B,C2,one_one(B))
            & algebr8660921524188924756oprime(B,A3,B2) ) ) ) ).

% coprime_mult_self_left_iff
tff(fact_4742_is__unit__gcd,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2),one_one(B))
        <=> algebr8660921524188924756oprime(B,A3,B2) ) ) ).

% is_unit_gcd
tff(fact_4743_count__greater__eq__one__iff,axiom,
    ! [B: $tType,M2: multiset(B),X2: B] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),one_one(nat)),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),M2),X2))
    <=> member(B,X2,set_mset(B,M2)) ) ).

% count_greater_eq_one_iff
tff(fact_4744_count__mset__set_I1_J,axiom,
    ! [B: $tType,A4: set(B),X2: B] :
      ( finite_finite2(B,A4)
     => ( member(B,X2,A4)
       => ( aa(B,nat,aa(multiset(B),fun(B,nat),count(B),mset_set(B,A4)),X2) = one_one(nat) ) ) ) ).

% count_mset_set(1)
tff(fact_4745_coprime__1__left,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] : algebr8660921524188924756oprime(B,one_one(B),A3) ) ).

% coprime_1_left
tff(fact_4746_coprime__1__right,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B] : algebr8660921524188924756oprime(B,A3,one_one(B)) ) ).

% coprime_1_right
tff(fact_4747_coprime__add__one__left,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B] : algebr8660921524188924756oprime(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B)),A3) ) ).

% coprime_add_one_left
tff(fact_4748_coprime__add__one__right,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B] : algebr8660921524188924756oprime(B,A3,aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),one_one(B))) ) ).

% coprime_add_one_right
tff(fact_4749_coprime__doff__one__right,axiom,
    ! [B: $tType] :
      ( ring_gcd(B)
     => ! [A3: B] : algebr8660921524188924756oprime(B,A3,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))) ) ).

% coprime_doff_one_right
tff(fact_4750_coprime__diff__one__left,axiom,
    ! [B: $tType] :
      ( ring_gcd(B)
     => ! [A3: B] : algebr8660921524188924756oprime(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B)),A3) ) ).

% coprime_diff_one_left
tff(fact_4751_is__unit__right__imp__coprime,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [B2: B,A3: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => algebr8660921524188924756oprime(B,A3,B2) ) ) ).

% is_unit_right_imp_coprime
tff(fact_4752_is__unit__left__imp__coprime,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => algebr8660921524188924756oprime(B,A3,B2) ) ) ).

% is_unit_left_imp_coprime
tff(fact_4753_coprime__common__divisor,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B,C2: B] :
          ( algebr8660921524188924756oprime(B,A3,B2)
         => ( dvd_dvd(B,C2,A3)
           => ( dvd_dvd(B,C2,B2)
             => dvd_dvd(B,C2,one_one(B)) ) ) ) ) ).

% coprime_common_divisor
tff(fact_4754_coprime__absorb__right,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [Y: B,X2: B] :
          ( dvd_dvd(B,Y,X2)
         => ( algebr8660921524188924756oprime(B,X2,Y)
          <=> dvd_dvd(B,Y,one_one(B)) ) ) ) ).

% coprime_absorb_right
tff(fact_4755_coprime__imp__coprime,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [C2: B,D3: B,A3: B,B2: B] :
          ( algebr8660921524188924756oprime(B,C2,D3)
         => ( ! [E3: B] :
                ( ~ dvd_dvd(B,E3,one_one(B))
               => ( dvd_dvd(B,E3,A3)
                 => ( dvd_dvd(B,E3,B2)
                   => dvd_dvd(B,E3,C2) ) ) )
           => ( ! [E3: B] :
                  ( ~ dvd_dvd(B,E3,one_one(B))
                 => ( dvd_dvd(B,E3,A3)
                   => ( dvd_dvd(B,E3,B2)
                     => dvd_dvd(B,E3,D3) ) ) )
             => algebr8660921524188924756oprime(B,A3,B2) ) ) ) ) ).

% coprime_imp_coprime
tff(fact_4756_coprime__absorb__left,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [X2: B,Y: B] :
          ( dvd_dvd(B,X2,Y)
         => ( algebr8660921524188924756oprime(B,X2,Y)
          <=> dvd_dvd(B,X2,one_one(B)) ) ) ) ).

% coprime_absorb_left
tff(fact_4757_not__coprimeI,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [C2: B,A3: B,B2: B] :
          ( dvd_dvd(B,C2,A3)
         => ( dvd_dvd(B,C2,B2)
           => ( ~ dvd_dvd(B,C2,one_one(B))
             => ~ algebr8660921524188924756oprime(B,A3,B2) ) ) ) ) ).

% not_coprimeI
tff(fact_4758_not__coprimeE,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( ~ algebr8660921524188924756oprime(B,A3,B2)
         => ~ ! [C3: B] :
                ( dvd_dvd(B,C3,A3)
               => ( dvd_dvd(B,C3,B2)
                 => dvd_dvd(B,C3,one_one(B)) ) ) ) ) ).

% not_coprimeE
tff(fact_4759_coprime__def,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( algebr8660921524188924756oprime(B,A3,B2)
        <=> ! [C4: B] :
              ( dvd_dvd(B,C4,A3)
             => ( dvd_dvd(B,C4,B2)
               => dvd_dvd(B,C4,one_one(B)) ) ) ) ) ).

% coprime_def
tff(fact_4760_coprimeI,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A3: B,B2: B] :
          ( ! [C3: B] :
              ( dvd_dvd(B,C3,A3)
             => ( dvd_dvd(B,C3,B2)
               => dvd_dvd(B,C3,one_one(B)) ) )
         => algebr8660921524188924756oprime(B,A3,B2) ) ) ).

% coprimeI
tff(fact_4761_plus__multiset_Orep__eq,axiom,
    ! [B: $tType,X2: multiset(B),Xa: multiset(B),X: B] : aa(B,nat,aa(multiset(B),fun(B,nat),count(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Xa)),X) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),X2),X)),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),Xa),X)) ).

% plus_multiset.rep_eq
tff(fact_4762_coprime__iff__gcd__eq__1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          ( algebr8660921524188924756oprime(B,A3,B2)
        <=> ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2) = one_one(B) ) ) ) ).

% coprime_iff_gcd_eq_1
tff(fact_4763_gcd__eq__1__imp__coprime,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2) = one_one(B) )
         => algebr8660921524188924756oprime(B,A3,B2) ) ) ).

% gcd_eq_1_imp_coprime
tff(fact_4764_quotient__of__coprime,axiom,
    ! [R: rat,P3: int,Q3: int] :
      ( ( quotient_of(R) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) )
     => algebr8660921524188924756oprime(int,P3,Q3) ) ).

% quotient_of_coprime
tff(fact_4765_normalize__coprime,axiom,
    ! [R: product_prod(int,int),P3: int,Q3: int] :
      ( ( normalize(R) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),P3),Q3) )
     => algebr8660921524188924756oprime(int,P3,Q3) ) ).

% normalize_coprime
tff(fact_4766_invertible__coprime,axiom,
    ! [B: $tType] :
      ( euclid8851590272496341667cancel(B)
     => ! [A3: B,B2: B,C2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),modulo_modulo(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)),C2) = one_one(B) )
         => algebr8660921524188924756oprime(B,A3,C2) ) ) ).

% invertible_coprime
tff(fact_4767_count__ne__remove,axiom,
    ! [B: $tType,X2: B,T2: B,S2: multiset(B)] :
      ( ( X2 != T2 )
     => ( aa(B,nat,aa(multiset(B),fun(B,nat),count(B),S2),X2) = aa(B,nat,aa(multiset(B),fun(B,nat),count(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),S2),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),T2),zero_zero(multiset(B))))),X2) ) ) ).

% count_ne_remove
tff(fact_4768_count__in__diffI,axiom,
    ! [B: $tType,N5: multiset(B),X2: B,M2: multiset(B)] :
      ( ! [N3: nat] : aa(B,nat,aa(multiset(B),fun(B,nat),count(B),N5),X2) != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N3),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),M2),X2))
     => member(B,X2,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),N5))) ) ).

% count_in_diffI
tff(fact_4769_count__single,axiom,
    ! [B: $tType,B2: B,A3: B] :
      aa(B,nat,aa(multiset(B),fun(B,nat),count(B),aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),B2),zero_zero(multiset(B)))),A3) = $ite(B2 = A3,one_one(nat),zero_zero(nat)) ).

% count_single
tff(fact_4770_in__diff__countE,axiom,
    ! [B: $tType,X2: B,M2: multiset(B),N5: multiset(B)] :
      ( member(B,X2,set_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),minus_minus(multiset(B)),M2),N5)))
     => ~ ! [N3: nat] : aa(B,nat,aa(multiset(B),fun(B,nat),count(B),M2),X2) != aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,suc,N3)),aa(B,nat,aa(multiset(B),fun(B,nat),count(B),N5),X2)) ) ).

% in_diff_countE
tff(fact_4771_remove1__tl,axiom,
    ! [B: $tType,Xsa: list(B)] :
      ( ( Xsa != nil(B) )
     => ( remove1(B,hd(B,Xsa),Xsa) = tl(B,Xsa) ) ) ).

% remove1_tl
tff(fact_4772_count__mset__set__finite__iff,axiom,
    ! [B: $tType,S2: set(B),A3: B] :
      ( finite_finite2(B,S2)
     => ( aa(B,nat,aa(multiset(B),fun(B,nat),count(B),mset_set(B,S2)),A3) = $ite(member(B,A3,S2),one_one(nat),zero_zero(nat)) ) ) ).

% count_mset_set_finite_iff
tff(fact_4773_count__mset__set_H,axiom,
    ! [B: $tType,A4: set(B),X2: B] :
      aa(B,nat,aa(multiset(B),fun(B,nat),count(B),mset_set(B,A4)),X2) = $ite(
        ( finite_finite2(B,A4)
        & member(B,X2,A4) ),
        one_one(nat),
        zero_zero(nat) ) ).

% count_mset_set'
tff(fact_4774_length__remove1,axiom,
    ! [B: $tType,X2: B,Xsa: list(B)] :
      aa(list(B),nat,size_size(list(B)),remove1(B,X2,Xsa)) = $ite(member(B,X2,aa(list(B),set(B),set2(B),Xsa)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(list(B),nat,size_size(list(B)),Xsa)),one_one(nat)),aa(list(B),nat,size_size(list(B)),Xsa)) ).

% length_remove1
tff(fact_4775_prod__mset__delta_H,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(B)
     => ! [Y: C,C2: B,A4: multiset(C)] : aa(multiset(B),B,comm_m9189036328036947845d_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,aa(B,fun(C,B),aTP_Lamp_tj(C,fun(B,fun(C,B)),Y),C2)),A4)) = aa(nat,B,aa(B,fun(nat,B),power_power(B),C2),aa(C,nat,aa(multiset(C),fun(C,nat),count(C),A4),Y)) ) ).

% prod_mset_delta'
tff(fact_4776_prod__mset__delta,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(B)
     => ! [Y: C,C2: B,A4: multiset(C)] : aa(multiset(B),B,comm_m9189036328036947845d_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,aa(B,fun(C,B),aTP_Lamp_tk(C,fun(B,fun(C,B)),Y),C2)),A4)) = aa(nat,B,aa(B,fun(nat,B),power_power(B),C2),aa(C,nat,aa(multiset(C),fun(C,nat),count(C),A4),Y)) ) ).

% prod_mset_delta
tff(fact_4777_prod_OatLeastLessThan__reindex,axiom,
    ! [B: $tType,C: $tType] :
      ( ( comm_monoid_mult(C)
        & ord(B) )
     => ! [Ha: fun(nat,B),M: nat,N: nat,G: fun(B,C)] :
          ( bij_betw(nat,B,Ha,set_or7035219750837199246ssThan(nat,M,N),set_or7035219750837199246ssThan(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N)))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),set_or7035219750837199246ssThan(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aa(fun(nat,B),fun(nat,C),aa(fun(B,C),fun(fun(nat,B),fun(nat,C)),comp(B,C,nat),G),Ha)),set_or7035219750837199246ssThan(nat,M,N)) ) ) ) ).

% prod.atLeastLessThan_reindex
tff(fact_4778_bij__betw__id,axiom,
    ! [B: $tType,A4: set(B)] : bij_betw(B,B,id(B),A4,A4) ).

% bij_betw_id
tff(fact_4779_bij__betw__add,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [A3: B,A4: set(B),B5: set(B)] :
          ( bij_betw(B,B,aa(B,fun(B,B),plus_plus(B),A3),A4,B5)
        <=> ( aa(set(B),set(B),image2(B,B,aa(B,fun(B,B),plus_plus(B),A3)),A4) = B5 ) ) ) ).

% bij_betw_add
tff(fact_4780_prod__mset__empty,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ( aa(multiset(B),B,comm_m9189036328036947845d_mset(B),zero_zero(multiset(B))) = one_one(B) ) ) ).

% prod_mset_empty
tff(fact_4781_prod__mset_Ounion,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M2: multiset(B),N5: multiset(B)] : aa(multiset(B),B,comm_m9189036328036947845d_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(multiset(B),B,comm_m9189036328036947845d_mset(B),M2)),aa(multiset(B),B,comm_m9189036328036947845d_mset(B),N5)) ) ).

% prod_mset.union
tff(fact_4782_prod__mset__Un,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A4: multiset(B),B5: multiset(B)] : aa(multiset(B),B,comm_m9189036328036947845d_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(multiset(B),B,comm_m9189036328036947845d_mset(B),A4)),aa(multiset(B),B,comm_m9189036328036947845d_mset(B),B5)) ) ).

% prod_mset_Un
tff(fact_4783_bij__betw__of__nat,axiom,
    ! [B: $tType] :
      ( semiring_char_0(B)
     => ! [N5: set(nat),A4: set(B)] :
          ( bij_betw(nat,B,semiring_1_of_nat(B),N5,A4)
        <=> ( aa(set(nat),set(B),image2(nat,B,semiring_1_of_nat(B)),N5) = A4 ) ) ) ).

% bij_betw_of_nat
tff(fact_4784_prod__mset_Oneutral__const,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A4: multiset(C)] : aa(multiset(B),B,comm_m9189036328036947845d_mset(B),aa(multiset(C),multiset(B),image_mset(C,B,aTP_Lamp_fl(C,B)),A4)) = one_one(B) ) ).

% prod_mset.neutral_const
tff(fact_4785_bij__betw__imp__surj__on,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => ( aa(set(B),set(C),image2(B,C,F),A4) = B5 ) ) ).

% bij_betw_imp_surj_on
tff(fact_4786_f__the__inv__into__f__bij__betw,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C),X2: C] :
      ( bij_betw(B,C,F,A4,B5)
     => ( ( bij_betw(B,C,F,A4,B5)
         => member(C,X2,B5) )
       => ( aa(B,C,F,aa(C,B,the_inv_into(B,C,A4,F),X2)) = X2 ) ) ) ).

% f_the_inv_into_f_bij_betw
tff(fact_4787_bij__betw__the__inv__into,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => bij_betw(C,B,the_inv_into(B,C,A4,F),B5,A4) ) ).

% bij_betw_the_inv_into
tff(fact_4788_bij__betw__id__iff,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( bij_betw(B,B,id(B),A4,B5)
    <=> ( A4 = B5 ) ) ).

% bij_betw_id_iff
tff(fact_4789_bij__betwE,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => ! [X: B] :
          ( member(B,X,A4)
         => member(C,aa(B,C,F,X),B5) ) ) ).

% bij_betwE
tff(fact_4790_bij__betw__inv,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => ? [G3: fun(C,B)] : bij_betw(C,B,G3,B5,A4) ) ).

% bij_betw_inv
tff(fact_4791_bij__betw__cong,axiom,
    ! [B: $tType,C: $tType,A4: set(B),F: fun(B,C),G: fun(B,C),A15: set(C)] :
      ( ! [A5: B] :
          ( member(B,A5,A4)
         => ( aa(B,C,F,A5) = aa(B,C,G,A5) ) )
     => ( bij_betw(B,C,F,A4,A15)
      <=> bij_betw(B,C,G,A4,A15) ) ) ).

% bij_betw_cong
tff(fact_4792_bij__betw__apply,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C),A3: B] :
      ( bij_betw(B,C,F,A4,B5)
     => ( member(B,A3,A4)
       => member(C,aa(B,C,F,A3),B5) ) ) ).

% bij_betw_apply
tff(fact_4793_bij__betw__iff__bijections,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
    <=> ? [G5: fun(C,B)] :
          ( ! [X4: B] :
              ( member(B,X4,A4)
             => ( member(C,aa(B,C,F,X4),B5)
                & ( aa(C,B,G5,aa(B,C,F,X4)) = X4 ) ) )
          & ! [X4: C] :
              ( member(C,X4,B5)
             => ( member(B,aa(C,B,G5,X4),A4)
                & ( aa(B,C,F,aa(C,B,G5,X4)) = X4 ) ) ) ) ) ).

% bij_betw_iff_bijections
tff(fact_4794_involuntory__imp__bij,axiom,
    ! [B: $tType,F: fun(B,B)] :
      ( ! [X3: B] : aa(B,B,F,aa(B,B,F,X3)) = X3
     => bij_betw(B,B,F,top_top(set(B)),top_top(set(B))) ) ).

% involuntory_imp_bij
tff(fact_4795_bij__pointE,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),Y: C] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => ~ ! [X3: B] :
            ( ( Y = aa(B,C,F,X3) )
           => ~ ! [X11: B] :
                  ( ( Y = aa(B,C,F,X11) )
                 => ( X11 = X3 ) ) ) ) ).

% bij_pointE
tff(fact_4796_bij__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
    <=> ! [X4: C] :
        ? [Xa2: B] :
          ( ( aa(B,C,F,Xa2) = X4 )
          & ! [Y3: B] :
              ( ( aa(B,C,F,Y3) = X4 )
             => ( Y3 = Xa2 ) ) ) ) ).

% bij_iff
tff(fact_4797_bij__betw__imp__inj__on,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => inj_on(B,C,F,A4) ) ).

% bij_betw_imp_inj_on
tff(fact_4798_bij__betw__trans,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),A4: set(B),B5: set(C),G: fun(C,D),C5: set(D)] :
      ( bij_betw(B,C,F,A4,B5)
     => ( bij_betw(C,D,G,B5,C5)
       => bij_betw(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),F),A4,C5) ) ) ).

% bij_betw_trans
tff(fact_4799_bij__betw__comp__iff,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),A4: set(B),A15: set(C),F2: fun(C,D),A16: set(D)] :
      ( bij_betw(B,C,F,A4,A15)
     => ( bij_betw(C,D,F2,A15,A16)
      <=> bij_betw(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F),A4,A16) ) ) ).

% bij_betw_comp_iff
tff(fact_4800_bij__betw__empty2,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( bij_betw(B,C,F,A4,bot_bot(set(C)))
     => ( A4 = bot_bot(set(B)) ) ) ).

% bij_betw_empty2
tff(fact_4801_bij__betw__empty1,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(C)] :
      ( bij_betw(B,C,F,bot_bot(set(B)),A4)
     => ( A4 = bot_bot(set(C)) ) ) ).

% bij_betw_empty1
tff(fact_4802_bij__betw__byWitness,axiom,
    ! [B: $tType,C: $tType,A4: set(B),F2: fun(C,B),F: fun(B,C),A15: set(C)] :
      ( ! [X3: B] :
          ( member(B,X3,A4)
         => ( aa(C,B,F2,aa(B,C,F,X3)) = X3 ) )
     => ( ! [X3: C] :
            ( member(C,X3,A15)
           => ( aa(B,C,F,aa(C,B,F2,X3)) = X3 ) )
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),image2(B,C,F),A4)),A15)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(C),set(B),image2(C,B,F2),A15)),A4)
           => bij_betw(B,C,F,A4,A15) ) ) ) ) ).

% bij_betw_byWitness
tff(fact_4803_bij__betw__subset,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),A15: set(C),B5: set(B),B11: set(C)] :
      ( bij_betw(B,C,F,A4,A15)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),A4)
       => ( ( aa(set(B),set(C),image2(B,C,F),B5) = B11 )
         => bij_betw(B,C,F,B5,B11) ) ) ) ).

% bij_betw_subset
tff(fact_4804_bij__betw__imp__surj,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B)] :
      ( bij_betw(B,C,F,A4,top_top(set(C)))
     => ( aa(set(B),set(C),image2(B,C,F),top_top(set(B))) = top_top(set(C)) ) ) ).

% bij_betw_imp_surj
tff(fact_4805_bij__is__surj,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => ( aa(set(B),set(C),image2(B,C,F),top_top(set(B))) = top_top(set(C)) ) ) ).

% bij_is_surj
tff(fact_4806_bij__uminus,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => bij_betw(B,B,uminus_uminus(B),top_top(set(B)),top_top(set(B))) ) ).

% bij_uminus
tff(fact_4807_bij__comp,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(B,C),G: fun(C,D)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => ( bij_betw(C,D,G,top_top(set(C)),top_top(set(D)))
       => bij_betw(B,D,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),F),top_top(set(B)),top_top(set(D))) ) ) ).

% bij_comp
tff(fact_4808_inj__on__imp__bij__betw,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,A4)
     => bij_betw(B,C,F,A4,aa(set(B),set(C),image2(B,C,F),A4)) ) ).

% inj_on_imp_bij_betw
tff(fact_4809_bij__betw__imageI,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( inj_on(B,C,F,A4)
     => ( ( aa(set(B),set(C),image2(B,C,F),A4) = B5 )
       => bij_betw(B,C,F,A4,B5) ) ) ).

% bij_betw_imageI
tff(fact_4810_bij__betw__def,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
    <=> ( inj_on(B,C,F,A4)
        & ( aa(set(B),set(C),image2(B,C,F),A4) = B5 ) ) ) ).

% bij_betw_def
tff(fact_4811_bij__betw__iff__card,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(C,B5)
       => ( ? [F6: fun(B,C)] : bij_betw(B,C,F6,A4,B5)
        <=> ( finite_card(B,A4) = finite_card(C,B5) ) ) ) ) ).

% bij_betw_iff_card
tff(fact_4812_finite__same__card__bij,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(C,B5)
       => ( ( finite_card(B,A4) = finite_card(C,B5) )
         => ? [H: fun(B,C)] : bij_betw(B,C,H,A4,B5) ) ) ) ).

% finite_same_card_bij
tff(fact_4813_bij__is__inj,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => inj_on(B,C,F,top_top(set(B))) ) ).

% bij_is_inj
tff(fact_4814_bij__id,axiom,
    ! [B: $tType] : bij_betw(B,B,id(B),top_top(set(B)),top_top(set(B))) ).

% bij_id
tff(fact_4815_coprime__common__divisor__nat,axiom,
    ! [A3: nat,B2: nat,X2: nat] :
      ( algebr8660921524188924756oprime(nat,A3,B2)
     => ( dvd_dvd(nat,X2,A3)
       => ( dvd_dvd(nat,X2,B2)
         => ( X2 = one_one(nat) ) ) ) ) ).

% coprime_common_divisor_nat
tff(fact_4816_prod__mset_Oneutral,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [A4: multiset(B)] :
          ( ! [X3: B] :
              ( member(B,X3,set_mset(B,A4))
             => ( X3 = one_one(B) ) )
         => ( aa(multiset(B),B,comm_m9189036328036947845d_mset(B),A4) = one_one(B) ) ) ) ).

% prod_mset.neutral
tff(fact_4817_bij__betw__comp__iff2,axiom,
    ! [D: $tType,B: $tType,C: $tType,F2: fun(B,C),A15: set(B),A16: set(C),F: fun(D,B),A4: set(D)] :
      ( bij_betw(B,C,F2,A15,A16)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(D),set(B),image2(D,B,F),A4)),A15)
       => ( bij_betw(D,B,F,A4,A15)
        <=> bij_betw(D,C,aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),F2),F),A4,A16) ) ) ) ).

% bij_betw_comp_iff2
tff(fact_4818_notIn__Un__bij__betw,axiom,
    ! [B: $tType,C: $tType,B2: B,A4: set(B),F: fun(B,C),A15: set(C)] :
      ( ~ member(B,B2,A4)
     => ( ~ member(C,aa(B,C,F,B2),A15)
       => ( bij_betw(B,C,F,A4,A15)
         => bij_betw(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A15),aa(set(C),set(C),insert2(C,aa(B,C,F,B2)),bot_bot(set(C))))) ) ) ) ).

% notIn_Un_bij_betw
tff(fact_4819_notIn__Un__bij__betw3,axiom,
    ! [B: $tType,C: $tType,B2: B,A4: set(B),F: fun(B,C),A15: set(C)] :
      ( ~ member(B,B2,A4)
     => ( ~ member(C,aa(B,C,F,B2),A15)
       => ( bij_betw(B,C,F,A4,A15)
        <=> bij_betw(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A15),aa(set(C),set(C),insert2(C,aa(B,C,F,B2)),bot_bot(set(C))))) ) ) ) ).

% notIn_Un_bij_betw3
tff(fact_4820_bijI,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( ( aa(set(B),set(C),image2(B,C,F),top_top(set(B))) = top_top(set(C)) )
       => bij_betw(B,C,F,top_top(set(B)),top_top(set(C))) ) ) ).

% bijI
tff(fact_4821_bij__def,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
    <=> ( inj_on(B,C,F,top_top(set(B)))
        & ( aa(set(B),set(C),image2(B,C,F),top_top(set(B))) = top_top(set(C)) ) ) ) ).

% bij_def
tff(fact_4822_bij__betw__partition,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),C5: set(B),B5: set(C),D4: set(C)] :
      ( bij_betw(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),C5),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B5),D4))
     => ( bij_betw(B,C,F,C5,D4)
       => ( ( aa(set(B),set(B),inf_inf(set(B),A4),C5) = bot_bot(set(B)) )
         => ( ( aa(set(C),set(C),inf_inf(set(C),B5),D4) = bot_bot(set(C)) )
           => bij_betw(B,C,F,A4,B5) ) ) ) ) ).

% bij_betw_partition
tff(fact_4823_bij__betw__combine,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),B5: set(C),C5: set(B),D4: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => ( bij_betw(B,C,F,C5,D4)
       => ( ( aa(set(C),set(C),inf_inf(set(C),B5),D4) = bot_bot(set(C)) )
         => bij_betw(B,C,F,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),C5),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),B5),D4)) ) ) ) ).

% bij_betw_combine
tff(fact_4824_o__bij,axiom,
    ! [B: $tType,C: $tType,G: fun(C,B),F: fun(B,C)] :
      ( ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),G),F) = id(B) )
     => ( ( aa(fun(C,B),fun(C,C),aa(fun(B,C),fun(fun(C,B),fun(C,C)),comp(B,C,C),F),G) = id(C) )
       => bij_betw(B,C,F,top_top(set(B)),top_top(set(C))) ) ) ).

% o_bij
tff(fact_4825_bij__image__Compl__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => ( aa(set(B),set(C),image2(B,C,F),aa(set(B),set(B),uminus_uminus(set(B)),A4)) = aa(set(C),set(C),uminus_uminus(set(C)),aa(set(B),set(C),image2(B,C,F),A4)) ) ) ).

% bij_image_Compl_eq
tff(fact_4826_Well__order__iso__copy,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(B,B)),F: fun(B,C),A15: set(C)] :
      ( order_well_order_on(B,A4,R)
     => ( bij_betw(B,C,F,A4,A15)
       => ? [R9: set(product_prod(C,C))] :
            ( order_well_order_on(C,A15,R9)
            & member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R9),bNF_Wellorder_ordIso(B,C)) ) ) ) ).

% Well_order_iso_copy
tff(fact_4827_bij__betw__disjoint__Un,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),A4: set(B),C5: set(C),G: fun(B,C),B5: set(B),D4: set(C)] :
      ( bij_betw(B,C,F,A4,C5)
     => ( bij_betw(B,C,G,B5,D4)
       => ( ( aa(set(B),set(B),inf_inf(set(B),A4),B5) = bot_bot(set(B)) )
         => ( ( aa(set(C),set(C),inf_inf(set(C),C5),D4) = bot_bot(set(C)) )
           => bij_betw(B,C,aa(fun(B,C),fun(B,C),aa(set(B),fun(fun(B,C),fun(B,C)),aTP_Lamp_nn(fun(B,C),fun(set(B),fun(fun(B,C),fun(B,C))),F),A4),G),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),C5),D4)) ) ) ) ) ).

% bij_betw_disjoint_Un
tff(fact_4828_is__unit__prod__mset__iff,axiom,
    ! [B: $tType] :
      ( algebraic_semidom(B)
     => ! [A4: multiset(B)] :
          ( dvd_dvd(B,aa(multiset(B),B,comm_m9189036328036947845d_mset(B),A4),one_one(B))
        <=> ! [X4: B] :
              ( member(B,X4,set_mset(B,A4))
             => dvd_dvd(B,X4,one_one(B)) ) ) ) ).

% is_unit_prod_mset_iff
tff(fact_4829_prod__mset_Oeq__fold,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [M2: multiset(B)] : aa(multiset(B),B,comm_m9189036328036947845d_mset(B),M2) = fold_mset(B,B,times_times(B),one_one(B),M2) ) ).

% prod_mset.eq_fold
tff(fact_4830_vimage__subset__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),B5: set(C),A4: set(B)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(C),set(B),vimage(B,C,F),B5)),A4)
      <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(B),set(C),image2(B,C,F),A4)) ) ) ).

% vimage_subset_eq
tff(fact_4831_ex__bij__betw__nat__finite,axiom,
    ! [B: $tType,M2: set(B)] :
      ( finite_finite2(B,M2)
     => ? [H: fun(nat,B)] : bij_betw(nat,B,H,set_or7035219750837199246ssThan(nat,zero_zero(nat),finite_card(B,M2)),M2) ) ).

% ex_bij_betw_nat_finite
tff(fact_4832_ex__bij__betw__nat__finite__1,axiom,
    ! [B: $tType,M2: set(B)] :
      ( finite_finite2(B,M2)
     => ? [H: fun(nat,B)] : bij_betw(nat,B,H,set_or1337092689740270186AtMost(nat,one_one(nat),finite_card(B,M2)),M2) ) ).

% ex_bij_betw_nat_finite_1
tff(fact_4833_coprime__diff__one__right__nat,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => algebr8660921524188924756oprime(nat,N,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat))) ) ).

% coprime_diff_one_right_nat
tff(fact_4834_coprime__diff__one__left__nat,axiom,
    ! [N: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),N)
     => algebr8660921524188924756oprime(nat,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)),N) ) ).

% coprime_diff_one_left_nat
tff(fact_4835_prod_Oreindex__bij__betw__not__neutral,axiom,
    ! [B: $tType,D: $tType,C: $tType] :
      ( comm_monoid_mult(D)
     => ! [S5: set(B),T4: set(C),Ha: fun(B,C),S2: set(B),T5: set(C),G: fun(C,D)] :
          ( finite_finite2(B,S5)
         => ( finite_finite2(C,T4)
           => ( bij_betw(B,C,Ha,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),S2),S5),aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),T5),T4))
             => ( ! [A5: B] :
                    ( member(B,A5,S5)
                   => ( aa(C,D,G,aa(B,C,Ha,A5)) = one_one(D) ) )
               => ( ! [B3: C] :
                      ( member(C,B3,T4)
                     => ( aa(C,D,G,B3) = one_one(D) ) )
                 => ( aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7121269368397514597t_prod(B,D),aa(fun(C,D),fun(B,D),aTP_Lamp_tl(fun(B,C),fun(fun(C,D),fun(B,D)),Ha),G)),S2) = aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7121269368397514597t_prod(C,D),G),T5) ) ) ) ) ) ) ) ).

% prod.reindex_bij_betw_not_neutral
tff(fact_4836_sum_OatLeastAtMost__reindex,axiom,
    ! [B: $tType,C: $tType] :
      ( ( comm_monoid_add(C)
        & ord(B) )
     => ! [Ha: fun(nat,B),M: nat,N: nat,G: fun(B,C)] :
          ( bij_betw(nat,B,Ha,set_or1337092689740270186AtMost(nat,M,N),set_or1337092689740270186AtMost(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N)))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),set_or1337092689740270186AtMost(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(fun(nat,B),fun(nat,C),aa(fun(B,C),fun(fun(nat,B),fun(nat,C)),comp(B,C,nat),G),Ha)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ) ).

% sum.atLeastAtMost_reindex
tff(fact_4837_sum_OatLeastLessThan__reindex,axiom,
    ! [B: $tType,C: $tType] :
      ( ( comm_monoid_add(C)
        & ord(B) )
     => ! [Ha: fun(nat,B),M: nat,N: nat,G: fun(B,C)] :
          ( bij_betw(nat,B,Ha,set_or7035219750837199246ssThan(nat,M,N),set_or7035219750837199246ssThan(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N)))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7311177749621191930dd_sum(B,C),G),set_or7035219750837199246ssThan(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7311177749621191930dd_sum(nat,C),aa(fun(nat,B),fun(nat,C),aa(fun(B,C),fun(fun(nat,B),fun(nat,C)),comp(B,C,nat),G),Ha)),set_or7035219750837199246ssThan(nat,M,N)) ) ) ) ).

% sum.atLeastLessThan_reindex
tff(fact_4838_prod_OatLeastAtMost__reindex,axiom,
    ! [B: $tType,C: $tType] :
      ( ( comm_monoid_mult(C)
        & ord(B) )
     => ! [Ha: fun(nat,B),M: nat,N: nat,G: fun(B,C)] :
          ( bij_betw(nat,B,Ha,set_or1337092689740270186AtMost(nat,M,N),set_or1337092689740270186AtMost(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N)))
         => ( aa(set(B),C,aa(fun(B,C),fun(set(B),C),groups7121269368397514597t_prod(B,C),G),set_or1337092689740270186AtMost(B,aa(nat,B,Ha,M),aa(nat,B,Ha,N))) = aa(set(nat),C,aa(fun(nat,C),fun(set(nat),C),groups7121269368397514597t_prod(nat,C),aa(fun(nat,B),fun(nat,C),aa(fun(B,C),fun(fun(nat,B),fun(nat,C)),comp(B,C,nat),G),Ha)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ) ).

% prod.atLeastAtMost_reindex
tff(fact_4839_antisymp__antisym__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( antisymp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R))
    <=> antisym(B,R) ) ).

% antisymp_antisym_eq
tff(fact_4840_convol__expand__snd_H,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,product_prod(C,D)),G: fun(B,C),Ha: fun(B,D)] :
      ( ( aa(fun(B,product_prod(C,D)),fun(B,C),aa(fun(product_prod(C,D),C),fun(fun(B,product_prod(C,D)),fun(B,C)),comp(product_prod(C,D),C,B),product_fst(C,D)),F) = G )
     => ( ( Ha = aa(fun(B,product_prod(C,D)),fun(B,D),aa(fun(product_prod(C,D),D),fun(fun(B,product_prod(C,D)),fun(B,D)),comp(product_prod(C,D),D,B),product_snd(C,D)),F) )
      <=> ( bNF_convol(B,C,D,G,Ha) = F ) ) ) ).

% convol_expand_snd'
tff(fact_4841_convol__expand__snd,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,product_prod(C,D)),G: fun(B,C)] :
      ( ( aa(fun(B,product_prod(C,D)),fun(B,C),aa(fun(product_prod(C,D),C),fun(fun(B,product_prod(C,D)),fun(B,C)),comp(product_prod(C,D),C,B),product_fst(C,D)),F) = G )
     => ( bNF_convol(B,C,D,G,aa(fun(B,product_prod(C,D)),fun(B,D),aa(fun(product_prod(C,D),D),fun(fun(B,product_prod(C,D)),fun(B,D)),comp(product_prod(C,D),D,B),product_snd(C,D)),F)) = F ) ) ).

% convol_expand_snd
tff(fact_4842_convol__def,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,C),G: fun(B,D),X: B] : aa(B,product_prod(C,D),bNF_convol(B,C,D,F,G),X) = aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(B,C,F,X)),aa(B,D,G,X)) ).

% convol_def
tff(fact_4843_bij__swap,axiom,
    ! [B: $tType,C: $tType] : bij_betw(product_prod(B,C),product_prod(C,B),product_swap(B,C),top_top(set(product_prod(B,C))),top_top(set(product_prod(C,B)))) ).

% bij_swap
tff(fact_4844_fst__convol,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,C),G: fun(B,D)] : aa(fun(B,product_prod(C,D)),fun(B,C),aa(fun(product_prod(C,D),C),fun(fun(B,product_prod(C,D)),fun(B,C)),comp(product_prod(C,D),C,B),product_fst(C,D)),bNF_convol(B,C,D,F,G)) = F ).

% fst_convol
tff(fact_4845_snd__convol,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,D),G: fun(B,C)] : aa(fun(B,product_prod(D,C)),fun(B,C),aa(fun(product_prod(D,C),C),fun(fun(B,product_prod(D,C)),fun(B,C)),comp(product_prod(D,C),C,B),product_snd(D,C)),bNF_convol(B,D,C,F,G)) = G ).

% snd_convol
tff(fact_4846_convol__o,axiom,
    ! [C: $tType,D: $tType,E: $tType,B: $tType,F: fun(E,C),G: fun(E,D),Ha: fun(B,E)] : aa(fun(B,E),fun(B,product_prod(C,D)),aa(fun(E,product_prod(C,D)),fun(fun(B,E),fun(B,product_prod(C,D))),comp(E,product_prod(C,D),B),bNF_convol(E,C,D,F,G)),Ha) = bNF_convol(B,C,D,aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),F),Ha),aa(fun(B,E),fun(B,D),aa(fun(E,D),fun(fun(B,E),fun(B,D)),comp(E,D,B),G),Ha)) ).

% convol_o
tff(fact_4847_ex__bij__betw__finite__nat,axiom,
    ! [B: $tType,M2: set(B)] :
      ( finite_finite2(B,M2)
     => ? [H: fun(B,nat)] : bij_betw(B,nat,H,M2,set_or7035219750837199246ssThan(nat,zero_zero(nat),finite_card(B,M2))) ) ).

% ex_bij_betw_finite_nat
tff(fact_4848_map__prod__o__convol__id,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(D,B),G: fun(D,C),X2: D] : aa(D,product_prod(B,C),aa(fun(D,product_prod(D,C)),fun(D,product_prod(B,C)),aa(fun(product_prod(D,C),product_prod(B,C)),fun(fun(D,product_prod(D,C)),fun(D,product_prod(B,C))),comp(product_prod(D,C),product_prod(B,C),D),product_map_prod(D,B,C,C,F,id(C))),bNF_convol(D,D,C,id(D),G)),X2) = aa(D,product_prod(B,C),bNF_convol(D,B,C,aa(fun(D,B),fun(D,B),aa(fun(B,B),fun(fun(D,B),fun(D,B)),comp(B,B,D),id(B)),F),G),X2) ).

% map_prod_o_convol_id
tff(fact_4849_Heap__lub__empty,axiom,
    ! [B: $tType] : aa(set(heap_Time_Heap(B)),heap_Time_Heap(B),heap_Time_Heap_lub(B),bot_bot(set(heap_Time_Heap(B)))) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aTP_Lamp_ao(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))) ).

% Heap_lub_empty
tff(fact_4850_and_Osemilattice__neutr__axioms,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => semilattice_neutr(B,bit_se5824344872417868541ns_and(B),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% and.semilattice_neutr_axioms
tff(fact_4851_map__prod__ident,axiom,
    ! [C: $tType,B: $tType,X: product_prod(B,C)] : aa(product_prod(B,C),product_prod(B,C),product_map_prod(B,B,C,C,aTP_Lamp_ay(B,B),aTP_Lamp_ae(C,C)),X) = X ).

% map_prod_ident
tff(fact_4852_map__prod__simp,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,F: fun(D,B),G: fun(E,C),A3: D,B2: E] : aa(product_prod(D,E),product_prod(B,C),product_map_prod(D,B,E,C,F,G),aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),A3),B2)) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,F,A3)),aa(E,C,G,B2)) ).

% map_prod_simp
tff(fact_4853_fst__map__prod,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,F: fun(D,B),G: fun(E,C),X2: product_prod(D,E)] : aa(product_prod(B,C),B,product_fst(B,C),aa(product_prod(D,E),product_prod(B,C),product_map_prod(D,B,E,C,F,G),X2)) = aa(D,B,F,aa(product_prod(D,E),D,product_fst(D,E),X2)) ).

% fst_map_prod
tff(fact_4854_snd__map__prod,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,F: fun(D,C),G: fun(E,B),X2: product_prod(D,E)] : aa(product_prod(C,B),B,product_snd(C,B),aa(product_prod(D,E),product_prod(C,B),product_map_prod(D,C,E,B,F,G),X2)) = aa(E,B,G,aa(product_prod(D,E),E,product_snd(D,E),X2)) ).

% snd_map_prod
tff(fact_4855_map__prod__imageI,axiom,
    ! [E: $tType,D: $tType,C: $tType,B: $tType,A3: B,B2: C,R4: set(product_prod(B,C)),F: fun(B,D),G: fun(C,E)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R4)
     => member(product_prod(D,E),aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),aa(B,D,F,A3)),aa(C,E,G,B2)),aa(set(product_prod(B,C)),set(product_prod(D,E)),image2(product_prod(B,C),product_prod(D,E),product_map_prod(B,D,C,E,F,G)),R4)) ) ).

% map_prod_imageI
tff(fact_4856_fst__comp__map__prod,axiom,
    ! [E: $tType,D: $tType,C: $tType,B: $tType,F: fun(B,D),G: fun(C,E)] : aa(fun(product_prod(B,C),product_prod(D,E)),fun(product_prod(B,C),D),aa(fun(product_prod(D,E),D),fun(fun(product_prod(B,C),product_prod(D,E)),fun(product_prod(B,C),D)),comp(product_prod(D,E),D,product_prod(B,C)),product_fst(D,E)),product_map_prod(B,D,C,E,F,G)) = aa(fun(product_prod(B,C),B),fun(product_prod(B,C),D),aa(fun(B,D),fun(fun(product_prod(B,C),B),fun(product_prod(B,C),D)),comp(B,D,product_prod(B,C)),F),product_fst(B,C)) ).

% fst_comp_map_prod
tff(fact_4857_snd__comp__map__prod,axiom,
    ! [E: $tType,D: $tType,C: $tType,B: $tType,F: fun(B,E),G: fun(C,D)] : aa(fun(product_prod(B,C),product_prod(E,D)),fun(product_prod(B,C),D),aa(fun(product_prod(E,D),D),fun(fun(product_prod(B,C),product_prod(E,D)),fun(product_prod(B,C),D)),comp(product_prod(E,D),D,product_prod(B,C)),product_snd(E,D)),product_map_prod(B,E,C,D,F,G)) = aa(fun(product_prod(B,C),C),fun(product_prod(B,C),D),aa(fun(C,D),fun(fun(product_prod(B,C),C),fun(product_prod(B,C),D)),comp(C,D,product_prod(B,C)),G),product_snd(B,C)) ).

% snd_comp_map_prod
tff(fact_4858_prod_Omap__comp,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,G2: $tType,F4: $tType,G1: fun(D,B),G22: fun(E,C),F1: fun(F4,D),F22: fun(G2,E),V: product_prod(F4,G2)] : aa(product_prod(D,E),product_prod(B,C),product_map_prod(D,B,E,C,G1,G22),aa(product_prod(F4,G2),product_prod(D,E),product_map_prod(F4,D,G2,E,F1,F22),V)) = aa(product_prod(F4,G2),product_prod(B,C),product_map_prod(F4,B,G2,C,aa(fun(F4,D),fun(F4,B),aa(fun(D,B),fun(fun(F4,D),fun(F4,B)),comp(D,B,F4),G1),F1),aa(fun(G2,E),fun(G2,C),aa(fun(E,C),fun(fun(G2,E),fun(G2,C)),comp(E,C,G2),G22),F22)),V) ).

% prod.map_comp
tff(fact_4859_map__prod_Ocompositionality,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,G2: $tType,F4: $tType,F: fun(D,B),G: fun(E,C),Ha: fun(F4,D),I: fun(G2,E),Prod: product_prod(F4,G2)] : aa(product_prod(D,E),product_prod(B,C),product_map_prod(D,B,E,C,F,G),aa(product_prod(F4,G2),product_prod(D,E),product_map_prod(F4,D,G2,E,Ha,I),Prod)) = aa(product_prod(F4,G2),product_prod(B,C),product_map_prod(F4,B,G2,C,aa(fun(F4,D),fun(F4,B),aa(fun(D,B),fun(fun(F4,D),fun(F4,B)),comp(D,B,F4),F),Ha),aa(fun(G2,E),fun(G2,C),aa(fun(E,C),fun(fun(G2,E),fun(G2,C)),comp(E,C,G2),G),I)),Prod) ).

% map_prod.compositionality
tff(fact_4860_map__prod_Oidentity,axiom,
    ! [C: $tType,B: $tType] : product_map_prod(B,B,C,C,aTP_Lamp_ay(B,B),aTP_Lamp_ae(C,C)) = id(product_prod(B,C)) ).

% map_prod.identity
tff(fact_4861_prod__fun__imageE,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,C2: product_prod(B,C),F: fun(D,B),G: fun(E,C),R4: set(product_prod(D,E))] :
      ( member(product_prod(B,C),C2,aa(set(product_prod(D,E)),set(product_prod(B,C)),image2(product_prod(D,E),product_prod(B,C),product_map_prod(D,B,E,C,F,G)),R4))
     => ~ ! [X3: D,Y4: E] :
            ( ( C2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,F,X3)),aa(E,C,G,Y4)) )
           => ~ member(product_prod(D,E),aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),X3),Y4),R4) ) ) ).

% prod_fun_imageE
tff(fact_4862_apfst__def,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(B,D)] : product_apfst(B,D,C,F) = product_map_prod(B,D,C,C,F,id(C)) ).

% apfst_def
tff(fact_4863_apsnd__def,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,D)] : aa(fun(C,D),fun(product_prod(B,C),product_prod(B,D)),product_apsnd(C,D,B),F) = product_map_prod(B,B,C,D,id(B),F) ).

% apsnd_def
tff(fact_4864_map__prod__def,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,F: fun(B,D),G: fun(C,E)] : product_map_prod(B,D,C,E,F,G) = aa(fun(B,fun(C,product_prod(D,E))),fun(product_prod(B,C),product_prod(D,E)),product_case_prod(B,C,product_prod(D,E)),aa(fun(C,E),fun(B,fun(C,product_prod(D,E))),aTP_Lamp_tm(fun(B,D),fun(fun(C,E),fun(B,fun(C,product_prod(D,E)))),F),G)) ).

% map_prod_def
tff(fact_4865_map__prod__compose,axiom,
    ! [E: $tType,D: $tType,B: $tType,F4: $tType,G2: $tType,C: $tType,F1: fun(F4,D),F22: fun(B,F4),G1: fun(G2,E),G22: fun(C,G2)] : product_map_prod(B,D,C,E,aa(fun(B,F4),fun(B,D),aa(fun(F4,D),fun(fun(B,F4),fun(B,D)),comp(F4,D,B),F1),F22),aa(fun(C,G2),fun(C,E),aa(fun(G2,E),fun(fun(C,G2),fun(C,E)),comp(G2,E,C),G1),G22)) = aa(fun(product_prod(B,C),product_prod(F4,G2)),fun(product_prod(B,C),product_prod(D,E)),aa(fun(product_prod(F4,G2),product_prod(D,E)),fun(fun(product_prod(B,C),product_prod(F4,G2)),fun(product_prod(B,C),product_prod(D,E))),comp(product_prod(F4,G2),product_prod(D,E),product_prod(B,C)),product_map_prod(F4,D,G2,E,F1,G1)),product_map_prod(B,F4,C,G2,F22,G22)) ).

% map_prod_compose
tff(fact_4866_map__prod_Ocomp,axiom,
    ! [B: $tType,F4: $tType,D: $tType,E: $tType,G2: $tType,C: $tType,F: fun(F4,D),G: fun(G2,E),Ha: fun(B,F4),I: fun(C,G2)] : aa(fun(product_prod(B,C),product_prod(F4,G2)),fun(product_prod(B,C),product_prod(D,E)),aa(fun(product_prod(F4,G2),product_prod(D,E)),fun(fun(product_prod(B,C),product_prod(F4,G2)),fun(product_prod(B,C),product_prod(D,E))),comp(product_prod(F4,G2),product_prod(D,E),product_prod(B,C)),product_map_prod(F4,D,G2,E,F,G)),product_map_prod(B,F4,C,G2,Ha,I)) = product_map_prod(B,D,C,E,aa(fun(B,F4),fun(B,D),aa(fun(F4,D),fun(fun(B,F4),fun(B,D)),comp(F4,D,B),F),Ha),aa(fun(C,G2),fun(C,E),aa(fun(G2,E),fun(fun(C,G2),fun(C,E)),comp(G2,E,C),G),I)) ).

% map_prod.comp
tff(fact_4867_map__prod__surj__on,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,F: fun(C,B),A4: set(C),A15: set(B),G: fun(E,D),B5: set(E),B11: set(D)] :
      ( ( aa(set(C),set(B),image2(C,B,F),A4) = A15 )
     => ( ( aa(set(E),set(D),image2(E,D,G),B5) = B11 )
       => ( aa(set(product_prod(C,E)),set(product_prod(B,D)),image2(product_prod(C,E),product_prod(B,D),product_map_prod(C,B,E,D,F,G)),product_Sigma(C,E,A4,aTP_Lamp_tn(set(E),fun(C,set(E)),B5))) = product_Sigma(B,D,A15,aTP_Lamp_to(set(D),fun(B,set(D)),B11)) ) ) ) ).

% map_prod_surj_on
tff(fact_4868_map__prod__o__convol,axiom,
    ! [E: $tType,C: $tType,D: $tType,F4: $tType,B: $tType,H1: fun(E,C),H22: fun(F4,D),F: fun(B,E),G: fun(B,F4)] : aa(fun(B,product_prod(E,F4)),fun(B,product_prod(C,D)),aa(fun(product_prod(E,F4),product_prod(C,D)),fun(fun(B,product_prod(E,F4)),fun(B,product_prod(C,D))),comp(product_prod(E,F4),product_prod(C,D),B),product_map_prod(E,C,F4,D,H1,H22)),bNF_convol(B,E,F4,F,G)) = bNF_convol(B,C,D,aa(fun(B,E),fun(B,C),aa(fun(E,C),fun(fun(B,E),fun(B,C)),comp(E,C,B),H1),F),aa(fun(B,F4),fun(B,D),aa(fun(F4,D),fun(fun(B,F4),fun(B,D)),comp(F4,D,B),H22),G)) ).

% map_prod_o_convol
tff(fact_4869_map__prod__inj__on,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,F: fun(B,C),A4: set(B),G: fun(D,E),B5: set(D)] :
      ( inj_on(B,C,F,A4)
     => ( inj_on(D,E,G,B5)
       => inj_on(product_prod(B,D),product_prod(C,E),product_map_prod(B,C,D,E,F,G),product_Sigma(B,D,A4,aTP_Lamp_to(set(D),fun(B,set(D)),B5))) ) ) ).

% map_prod_inj_on
tff(fact_4870_map__prod__surj,axiom,
    ! [C: $tType,E: $tType,D: $tType,B: $tType,F: fun(C,B),G: fun(E,D)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
     => ( ( aa(set(E),set(D),image2(E,D,G),top_top(set(E))) = top_top(set(D)) )
       => ( aa(set(product_prod(C,E)),set(product_prod(B,D)),image2(product_prod(C,E),product_prod(B,D),product_map_prod(C,B,E,D,F,G)),top_top(set(product_prod(C,E)))) = top_top(set(product_prod(B,D))) ) ) ) ).

% map_prod_surj
tff(fact_4871_Zorns__po__lemma,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_7125193373082350890der_on(B,field2(B,R),R)
     => ( ! [C8: set(B)] :
            ( member(set(B),C8,chains(B,R))
           => ? [X: B] :
                ( member(B,X,field2(B,R))
                & ! [Xa4: B] :
                    ( member(B,Xa4,C8)
                   => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa4),X),R) ) ) )
       => ? [X3: B] :
            ( member(B,X3,field2(B,R))
            & ! [Xa3: B] :
                ( member(B,Xa3,field2(B,R))
               => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Xa3),R)
                 => ( Xa3 = X3 ) ) ) ) ) ) ).

% Zorns_po_lemma
tff(fact_4872_assert__def,axiom,
    ! [B: $tType,P: fun(B,$o),X2: B] :
      heap_Time_assert(B,P,X2) = $ite(aa(B,$o,P,X2),aa(B,heap_Time_Heap(B),heap_Time_return(B),X2),heap_Time_raise(B,aa(list(char),list(char),aa(char,fun(list(char),list(char)),cons(char),char2($true,$false,$false,$false,$false,$true,$true,$false)),aa(list(char),list(char),aa(char,fun(list(char),list(char)),cons(char),char2($true,$true,$false,$false,$true,$true,$true,$false)),aa(list(char),list(char),aa(char,fun(list(char),list(char)),cons(char),char2($true,$true,$false,$false,$true,$true,$true,$false)),aa(list(char),list(char),aa(char,fun(list(char),list(char)),cons(char),char2($true,$false,$true,$false,$false,$true,$true,$false)),aa(list(char),list(char),aa(char,fun(list(char),list(char)),cons(char),char2($false,$true,$false,$false,$true,$true,$true,$false)),aa(list(char),list(char),aa(char,fun(list(char),list(char)),cons(char),char2($false,$false,$true,$false,$true,$true,$true,$false)),nil(char))))))))) ).

% assert_def
tff(fact_4873_power__int__add__1,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [X2: B,M: int] :
          ( ( ( X2 != zero_zero(B) )
            | ( M != aa(int,int,uminus_uminus(int),one_one(int)) ) )
         => ( power_int(B,X2,aa(int,int,aa(int,fun(int,int),plus_plus(int),M),one_one(int))) = aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,X2,M)),X2) ) ) ) ).

% power_int_add_1
tff(fact_4874_power__int__1__left,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [N: int] : power_int(B,one_one(B),N) = one_one(B) ) ).

% power_int_1_left
tff(fact_4875_power__int__0__right,axiom,
    ! [B: $tType] :
      ( ( inverse(B)
        & power(B) )
     => ! [X2: B] : power_int(B,X2,zero_zero(int)) = one_one(B) ) ).

% power_int_0_right
tff(fact_4876_power__int__minus__one__mult__self,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [M: int] : aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),M)),power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),M)) = one_one(B) ) ).

% power_int_minus_one_mult_self
tff(fact_4877_power__int__minus__one__mult__self_H,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [M: int,B2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),M)),aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),M)),B2)) = B2 ) ).

% power_int_minus_one_mult_self'
tff(fact_4878_power__int__add__numeral,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [X2: B,M: num,N: num] : aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,X2,aa(num,int,numeral_numeral(int),M))),power_int(B,X2,aa(num,int,numeral_numeral(int),N))) = power_int(B,X2,aa(num,int,numeral_numeral(int),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N))) ) ).

% power_int_add_numeral
tff(fact_4879_power__int__add__numeral2,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [X2: B,M: num,N: num,B2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,X2,aa(num,int,numeral_numeral(int),M))),aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,X2,aa(num,int,numeral_numeral(int),N))),B2)) = aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,X2,aa(num,int,numeral_numeral(int),aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)))),B2) ) ).

% power_int_add_numeral2
tff(fact_4880_power__int__one__over,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [X2: B,N: int] : power_int(B,aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),X2),N) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),power_int(B,X2,N)) ) ).

% power_int_one_over
tff(fact_4881_power__int__0__left__If,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [M: int] :
          power_int(B,zero_zero(B),M) = $ite(M = zero_zero(int),one_one(B),zero_zero(B)) ) ).

% power_int_0_left_If
tff(fact_4882_power__int__increasing,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [N: int,N5: int,A3: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),A3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),power_int(B,A3,N)),power_int(B,A3,N5)) ) ) ) ).

% power_int_increasing
tff(fact_4883_power__int__strict__increasing,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [N: int,N5: int,A3: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),power_int(B,A3,N)),power_int(B,A3,N5)) ) ) ) ).

% power_int_strict_increasing
tff(fact_4884_power__int__minus__one__minus,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [N: int] : power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),aa(int,int,uminus_uminus(int),N)) = power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),N) ) ).

% power_int_minus_one_minus
tff(fact_4885_power__int__minus__one__diff__commute,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [A3: int,B2: int] : power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),aa(int,int,aa(int,fun(int,int),minus_minus(int),A3),B2)) = power_int(B,aa(B,B,uminus_uminus(B),one_one(B)),aa(int,int,aa(int,fun(int,int),minus_minus(int),B2),A3)) ) ).

% power_int_minus_one_diff_commute
tff(fact_4886_power__int__strict__decreasing,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [N: int,N5: int,A3: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),zero_zero(B)),A3)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),A3),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less(B),power_int(B,A3,N5)),power_int(B,A3,N)) ) ) ) ) ).

% power_int_strict_decreasing
tff(fact_4887_one__le__power__int,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B,N: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),X2)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),N)
           => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),one_one(B)),power_int(B,X2,N)) ) ) ) ).

% one_le_power_int
tff(fact_4888_one__less__power__int,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [A3: B,N: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),A3)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less(int),zero_zero(int)),N)
           => aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),power_int(B,A3,N)) ) ) ) ).

% one_less_power_int
tff(fact_4889_power__int__add,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [X2: B,M: int,N: int] :
          ( ( ( X2 != zero_zero(B) )
            | ( aa(int,int,aa(int,fun(int,int),plus_plus(int),M),N) != zero_zero(int) ) )
         => ( power_int(B,X2,aa(int,int,aa(int,fun(int,int),plus_plus(int),M),N)) = aa(B,B,aa(B,fun(B,B),times_times(B),power_int(B,X2,M)),power_int(B,X2,N)) ) ) ) ).

% power_int_add
tff(fact_4890_power__int__minus__left__distrib,axiom,
    ! [C: $tType,B: $tType,D: $tType] :
      ( ( division_ring(D)
        & one(B)
        & uminus(B) )
     => ! [X2: C,A3: D,N: int] :
          ( nO_MATCH(B,C,aa(B,B,uminus_uminus(B),one_one(B)),X2)
         => ( power_int(D,aa(D,D,uminus_uminus(D),A3),N) = aa(D,D,aa(D,fun(D,D),times_times(D),power_int(D,aa(D,D,uminus_uminus(D),one_one(D)),N)),power_int(D,A3,N)) ) ) ) ).

% power_int_minus_left_distrib
tff(fact_4891_power__int__decreasing,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [N: int,N5: int,A3: B] :
          ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),N),N5)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),A3)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),A3),one_one(B))
             => ( ( ( A3 != zero_zero(B) )
                  | ( N5 != zero_zero(int) )
                  | ( N = zero_zero(int) ) )
               => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),power_int(B,A3,N5)),power_int(B,A3,N)) ) ) ) ) ) ).

% power_int_decreasing
tff(fact_4892_power__int__le__one,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B,N: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),zero_zero(B)),X2)
         => ( aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),zero_zero(int)),N)
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),one_one(B))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),power_int(B,X2,N)),one_one(B)) ) ) ) ) ).

% power_int_le_one
tff(fact_4893_power__int__le__imp__le__exp,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B,M: int,N: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),power_int(B,X2,M)),power_int(B,X2,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),M),N) ) ) ) ) ).

% power_int_le_imp_le_exp
tff(fact_4894_power__int__le__imp__less__exp,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [X2: B,M: int,N: int] :
          ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),one_one(B)),X2)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),power_int(B,X2,M)),power_int(B,X2,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),M),N) ) ) ) ) ).

% power_int_le_imp_less_exp
tff(fact_4895_power__int__add__1_H,axiom,
    ! [B: $tType] :
      ( division_ring(B)
     => ! [X2: B,M: int] :
          ( ( ( X2 != zero_zero(B) )
            | ( M != aa(int,int,uminus_uminus(int),one_one(int)) ) )
         => ( power_int(B,X2,aa(int,int,aa(int,fun(int,int),plus_plus(int),M),one_one(int))) = aa(B,B,aa(B,fun(B,B),times_times(B),X2),power_int(B,X2,M)) ) ) ) ).

% power_int_add_1'
tff(fact_4896_integer__of__char__code,axiom,
    ! [B0: $o,B1: $o,B22: $o,B32: $o,B42: $o,B52: $o,B62: $o,B72: $o] : integer_of_char(char2((B0),(B1),(B22),(B32),(B42),(B52),(B62),(B72))) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B72))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B62)))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B52)))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B42)))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B32)))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B22)))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B1)))),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2)))),aa($o,code_integer,zero_neq_one_of_bool(code_integer),(B0))) ).

% integer_of_char_code
tff(fact_4897_char__of__def,axiom,
    ! [B: $tType] :
      ( bit_un5681908812861735899ations(B)
     => ! [N: B] : unique5772411509450598832har_of(B,N) = char2(~ dvd_dvd(B,aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)),N),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),one_one(nat)),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,one2))),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,aa(num,num,bit0,one2)))),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,aa(num,num,bit0,one2)))),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,aa(num,num,bit1,one2)))),aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),N),aa(num,nat,numeral_numeral(nat),aa(num,num,bit1,aa(num,num,bit1,one2))))) ) ).

% char_of_def
tff(fact_4898_numeral__unfold__funpow,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [K: num] : aa(num,B,numeral_numeral(B),K) = aa(B,B,compow(fun(B,B),aa(num,nat,numeral_numeral(nat),K),aa(B,fun(B,B),plus_plus(B),one_one(B))),zero_zero(B)) ) ).

% numeral_unfold_funpow
tff(fact_4899_relpowp__1,axiom,
    ! [B: $tType,P: fun(B,fun(B,$o))] : compow(fun(B,fun(B,$o)),one_one(nat),P) = P ).

% relpowp_1
tff(fact_4900_Suc__funpow,axiom,
    ! [N: nat] : compow(fun(nat,nat),N,suc) = aa(nat,fun(nat,nat),plus_plus(nat),N) ).

% Suc_funpow
tff(fact_4901_comp__funpow,axiom,
    ! [B: $tType,C: $tType,N: nat,F: fun(C,C)] : compow(fun(fun(B,C),fun(B,C)),N,aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),F)) = aa(fun(C,C),fun(fun(B,C),fun(B,C)),comp(C,C,B),compow(fun(C,C),N,F)) ).

% comp_funpow
tff(fact_4902_funpow_Osimps_I2_J,axiom,
    ! [B: $tType,N: nat,F: fun(B,B)] : compow(fun(B,B),aa(nat,nat,suc,N),F) = aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),F),compow(fun(B,B),N,F)) ).

% funpow.simps(2)
tff(fact_4903_funpow__Suc__right,axiom,
    ! [B: $tType,N: nat,F: fun(B,B)] : compow(fun(B,B),aa(nat,nat,suc,N),F) = aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),compow(fun(B,B),N,F)),F) ).

% funpow_Suc_right
tff(fact_4904_funpow__add,axiom,
    ! [B: $tType,M: nat,N: nat,F: fun(B,B)] : compow(fun(B,B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),F) = aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),compow(fun(B,B),M,F)),compow(fun(B,B),N,F)) ).

% funpow_add
tff(fact_4905_of__nat__def,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [N: nat] : aa(nat,B,semiring_1_of_nat(B),N) = aa(B,B,compow(fun(B,B),N,aa(B,fun(B,B),plus_plus(B),one_one(B))),zero_zero(B)) ) ).

% of_nat_def
tff(fact_4906_numeral__add__unfold__funpow,axiom,
    ! [B: $tType] :
      ( semiring_numeral(B)
     => ! [K: num,A3: B] : aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(num,B,numeral_numeral(B),K)),A3) = aa(B,B,compow(fun(B,B),aa(num,nat,numeral_numeral(nat),K),aa(B,fun(B,B),plus_plus(B),one_one(B))),A3) ) ).

% numeral_add_unfold_funpow
tff(fact_4907_inj__on__funpow__least,axiom,
    ! [B: $tType,N: nat,F: fun(B,B),S: B] :
      ( ( aa(B,B,compow(fun(B,B),N,F),S) = S )
     => ( ! [M4: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),M4)
           => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M4),N)
             => ( aa(B,B,compow(fun(B,B),M4,F),S) != S ) ) )
       => inj_on(nat,B,aa(B,fun(nat,B),aTP_Lamp_tp(fun(B,B),fun(B,fun(nat,B)),F),S),set_or7035219750837199246ssThan(nat,zero_zero(nat),N)) ) ) ).

% inj_on_funpow_least
tff(fact_4908_card__Un__disjnt,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(B,B5)
       => ( disjnt(B,A4,B5)
         => ( finite_card(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,A4)),finite_card(B,B5)) ) ) ) ) ).

% card_Un_disjnt
tff(fact_4909_plus__multiset__def,axiom,
    ! [B: $tType] : plus_plus(multiset(B)) = aa(fun(fun(B,nat),fun(fun(B,nat),fun(B,nat))),fun(multiset(B),fun(multiset(B),multiset(B))),map_fun(multiset(B),fun(B,nat),fun(fun(B,nat),fun(B,nat)),fun(multiset(B),multiset(B)),count(B),map_fun(multiset(B),fun(B,nat),fun(B,nat),multiset(B),count(B),abs_multiset(B))),aTP_Lamp_tq(fun(B,nat),fun(fun(B,nat),fun(B,nat)))) ).

% plus_multiset_def
tff(fact_4910_mset__subset__add__iff2,axiom,
    ! [B: $tType,I: nat,J: nat,U: multiset(B),M: multiset(B),N: multiset(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,I,U)),M),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,J,U)),N))
      <=> subset_mset(B,M,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),N)) ) ) ).

% mset_subset_add_iff2
tff(fact_4911_repeat__mset__distrib2,axiom,
    ! [B: $tType,N: nat,A4: multiset(B),B5: multiset(B)] : repeat_mset(B,N,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),A4),B5)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,N,A4)),repeat_mset(B,N,B5)) ).

% repeat_mset_distrib2
tff(fact_4912_repeat__mset__Suc,axiom,
    ! [B: $tType,N: nat,M2: multiset(B)] : repeat_mset(B,aa(nat,nat,suc,N),M2) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),repeat_mset(B,N,M2)) ).

% repeat_mset_Suc
tff(fact_4913_disjnt__Times1__iff,axiom,
    ! [B: $tType,C: $tType,C5: set(B),A4: set(C),B5: set(C)] :
      ( disjnt(product_prod(B,C),product_Sigma(B,C,C5,aTP_Lamp_jm(set(C),fun(B,set(C)),A4)),product_Sigma(B,C,C5,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))
    <=> ( ( C5 = bot_bot(set(B)) )
        | disjnt(C,A4,B5) ) ) ).

% disjnt_Times1_iff
tff(fact_4914_disjnt__Times2__iff,axiom,
    ! [C: $tType,B: $tType,A4: set(B),C5: set(C),B5: set(B)] :
      ( disjnt(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),C5)),product_Sigma(B,C,B5,aTP_Lamp_jm(set(C),fun(B,set(C)),C5)))
    <=> ( ( C5 = bot_bot(set(C)) )
        | disjnt(B,A4,B5) ) ) ).

% disjnt_Times2_iff
tff(fact_4915_disjnt__Sigma__iff,axiom,
    ! [C: $tType,B: $tType,A4: set(B),C5: fun(B,set(C)),B5: set(B)] :
      ( disjnt(product_prod(B,C),product_Sigma(B,C,A4,C5),product_Sigma(B,C,B5,C5))
    <=> ( ! [X4: B] :
            ( member(B,X4,aa(set(B),set(B),inf_inf(set(B),A4),B5))
           => ( aa(B,set(C),C5,X4) = bot_bot(set(C)) ) )
        | disjnt(B,A4,B5) ) ) ).

% disjnt_Sigma_iff
tff(fact_4916_left__add__mult__distrib__mset,axiom,
    ! [B: $tType,I: nat,U: multiset(B),J: nat,K: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,I,U)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,J,U)),K)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I),J),U)),K) ).

% left_add_mult_distrib_mset
tff(fact_4917_repeat__mset__distrib,axiom,
    ! [B: $tType,M: nat,N: nat,A4: multiset(B)] : repeat_mset(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),A4) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,M,A4)),repeat_mset(B,N,A4)) ).

% repeat_mset_distrib
tff(fact_4918_mset__subseteq__add__iff1,axiom,
    ! [B: $tType,J: nat,I: nat,U: multiset(B),M: multiset(B),N: multiset(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,I,U)),M)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,J,U)),N))
      <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J),U)),M)),N) ) ) ).

% mset_subseteq_add_iff1
tff(fact_4919_mset__subseteq__add__iff2,axiom,
    ! [B: $tType,I: nat,J: nat,U: multiset(B),M: multiset(B),N: multiset(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
     => ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,I,U)),M)),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,J,U)),N))
      <=> aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),M),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),N)) ) ) ).

% mset_subseteq_add_iff2
tff(fact_4920_mset__subset__add__iff1,axiom,
    ! [B: $tType,J: nat,I: nat,U: multiset(B),M: multiset(B),N: multiset(B)] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
     => ( subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,I,U)),M),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,J,U)),N))
      <=> subset_mset(B,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),repeat_mset(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J),U)),M),N) ) ) ).

% mset_subset_add_iff1
tff(fact_4921_plus__multiset_Oabs__eq,axiom,
    ! [B: $tType,Xa: fun(B,nat),X2: fun(B,nat)] :
      ( aa(fun(B,nat),$o,aa(fun(B,nat),fun(fun(B,nat),$o),bNF_eq_onp(fun(B,nat),aTP_Lamp_ts(fun(B,nat),$o)),Xa),Xa)
     => ( aa(fun(B,nat),$o,aa(fun(B,nat),fun(fun(B,nat),$o),bNF_eq_onp(fun(B,nat),aTP_Lamp_ts(fun(B,nat),$o)),X2),X2)
       => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(fun(B,nat),multiset(B),abs_multiset(B),Xa)),aa(fun(B,nat),multiset(B),abs_multiset(B),X2)) = aa(fun(B,nat),multiset(B),abs_multiset(B),aa(fun(B,nat),fun(B,nat),aa(fun(B,nat),fun(fun(B,nat),fun(B,nat)),aTP_Lamp_tq(fun(B,nat),fun(fun(B,nat),fun(B,nat))),Xa),X2)) ) ) ) ).

% plus_multiset.abs_eq
tff(fact_4922_repeat__mset__distrib__add__mset,axiom,
    ! [B: $tType,N: nat,A3: B,A4: multiset(B)] : repeat_mset(B,N,aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A3),A4)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),replicate_mset(B,N,A3)),repeat_mset(B,N,A4)) ).

% repeat_mset_distrib_add_mset
tff(fact_4923_o__prs_I2_J,axiom,
    ! [G2: $tType,F4: $tType,D: $tType,E: $tType,B: $tType,C: $tType,I8: $tType,H5: $tType,R12: fun(B,fun(B,$o)),Abs1: fun(B,C),Rep1: fun(C,B),R23: fun(D,fun(D,$o)),Abs22: fun(D,E),Rep22: fun(E,D),R32: fun(F4,fun(F4,$o)),Abs32: fun(F4,G2),Rep32: fun(G2,F4)] :
      ( quotient3(B,C,R12,Abs1,Rep1)
     => ( quotient3(D,E,R23,Abs22,Rep22)
       => ( quotient3(F4,G2,R32,Abs32,Rep32)
         => ( aa(fun(fun(H5,I8),fun(fun(B,H5),fun(B,I8))),fun(fun(H5,I8),fun(fun(C,H5),fun(C,I8))),map_fun(fun(H5,I8),fun(H5,I8),fun(fun(B,H5),fun(B,I8)),fun(fun(C,H5),fun(C,I8)),id(fun(H5,I8)),map_fun(fun(C,H5),fun(B,H5),fun(B,I8),fun(C,I8),map_fun(B,C,H5,H5,Abs1,id(H5)),map_fun(C,B,I8,I8,Rep1,id(I8)))),comp(H5,I8,B)) = comp(H5,I8,C) ) ) ) ) ).

% o_prs(2)
tff(fact_4924_abs__o__rep,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(B,$o)),Abs: fun(B,C),Rep: fun(C,B)] :
      ( quotient3(B,C,R4,Abs,Rep)
     => ( aa(fun(C,B),fun(C,C),aa(fun(B,C),fun(fun(C,B),fun(C,C)),comp(B,C,C),Abs),Rep) = id(C) ) ) ).

% abs_o_rep
tff(fact_4925_o__prs_I1_J,axiom,
    ! [D: $tType,F4: $tType,B: $tType,C: $tType,G2: $tType,E: $tType,R12: fun(B,fun(B,$o)),Abs1: fun(B,C),Rep1: fun(C,B),R23: fun(D,fun(D,$o)),Abs22: fun(D,E),Rep22: fun(E,D),R32: fun(F4,fun(F4,$o)),Abs32: fun(F4,G2),Rep32: fun(G2,F4)] :
      ( quotient3(B,C,R12,Abs1,Rep1)
     => ( quotient3(D,E,R23,Abs22,Rep22)
       => ( quotient3(F4,G2,R32,Abs32,Rep32)
         => ( aa(fun(fun(D,F4),fun(fun(B,D),fun(B,F4))),fun(fun(E,G2),fun(fun(C,E),fun(C,G2))),map_fun(fun(E,G2),fun(D,F4),fun(fun(B,D),fun(B,F4)),fun(fun(C,E),fun(C,G2)),map_fun(D,E,G2,F4,Abs22,Rep32),map_fun(fun(C,E),fun(B,D),fun(B,F4),fun(C,G2),map_fun(B,C,E,D,Abs1,Rep22),map_fun(C,B,F4,G2,Rep1,Abs32))),comp(D,F4,B)) = comp(E,G2,C) ) ) ) ) ).

% o_prs(1)
tff(fact_4926_plus__multiset_Orsp,axiom,
    ! [B: $tType] : aa(fun(fun(B,nat),fun(fun(B,nat),fun(B,nat))),$o,aa(fun(fun(B,nat),fun(fun(B,nat),fun(B,nat))),fun(fun(fun(B,nat),fun(fun(B,nat),fun(B,nat))),$o),bNF_rel_fun(fun(B,nat),fun(B,nat),fun(fun(B,nat),fun(B,nat)),fun(fun(B,nat),fun(B,nat)),bNF_eq_onp(fun(B,nat),aTP_Lamp_ts(fun(B,nat),$o)),bNF_rel_fun(fun(B,nat),fun(B,nat),fun(B,nat),fun(B,nat),bNF_eq_onp(fun(B,nat),aTP_Lamp_ts(fun(B,nat),$o)),bNF_eq_onp(fun(B,nat),aTP_Lamp_ts(fun(B,nat),$o)))),aTP_Lamp_tq(fun(B,nat),fun(fun(B,nat),fun(B,nat)))),aTP_Lamp_tq(fun(B,nat),fun(fun(B,nat),fun(B,nat)))) ).

% plus_multiset.rsp
tff(fact_4927_or__not__num__neg_Opelims,axiom,
    ! [X2: num,Xa: num,Y: num] :
      ( ( bit_or_not_num_neg(X2,Xa) = Y )
     => ( aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),X2),Xa))
       => ( ( ( X2 = one2 )
           => ( ( Xa = one2 )
             => ( ( Y = one2 )
               => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),one2)) ) ) )
         => ( ( ( X2 = one2 )
             => ! [M4: num] :
                  ( ( Xa = aa(num,num,bit0,M4) )
                 => ( ( Y = aa(num,num,bit1,M4) )
                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit0,M4))) ) ) )
           => ( ( ( X2 = one2 )
               => ! [M4: num] :
                    ( ( Xa = aa(num,num,bit1,M4) )
                   => ( ( Y = aa(num,num,bit1,M4) )
                     => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit1,M4))) ) ) )
             => ( ! [N3: num] :
                    ( ( X2 = aa(num,num,bit0,N3) )
                   => ( ( Xa = one2 )
                     => ( ( Y = aa(num,num,bit0,one2) )
                       => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,N3)),one2)) ) ) )
               => ( ! [N3: num] :
                      ( ( X2 = aa(num,num,bit0,N3) )
                     => ! [M4: num] :
                          ( ( Xa = aa(num,num,bit0,M4) )
                         => ( ( Y = bitM(bit_or_not_num_neg(N3,M4)) )
                           => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,N3)),aa(num,num,bit0,M4))) ) ) )
                 => ( ! [N3: num] :
                        ( ( X2 = aa(num,num,bit0,N3) )
                       => ! [M4: num] :
                            ( ( Xa = aa(num,num,bit1,M4) )
                           => ( ( Y = aa(num,num,bit0,bit_or_not_num_neg(N3,M4)) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,N3)),aa(num,num,bit1,M4))) ) ) )
                   => ( ! [N3: num] :
                          ( ( X2 = aa(num,num,bit1,N3) )
                         => ( ( Xa = one2 )
                           => ( ( Y = one2 )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,N3)),one2)) ) ) )
                     => ( ! [N3: num] :
                            ( ( X2 = aa(num,num,bit1,N3) )
                           => ! [M4: num] :
                                ( ( Xa = aa(num,num,bit0,M4) )
                               => ( ( Y = bitM(bit_or_not_num_neg(N3,M4)) )
                                 => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,N3)),aa(num,num,bit0,M4))) ) ) )
                       => ~ ! [N3: num] :
                              ( ( X2 = aa(num,num,bit1,N3) )
                             => ! [M4: num] :
                                  ( ( Xa = aa(num,num,bit1,M4) )
                                 => ( ( Y = bitM(bit_or_not_num_neg(N3,M4)) )
                                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_or3848514188828904588eg_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,N3)),aa(num,num,bit1,M4))) ) ) ) ) ) ) ) ) ) ) ) ) ) ).

% or_not_num_neg.pelims
tff(fact_4928_cr__natural__def,axiom,
    ! [X: nat,Xa3: code_natural] :
      ( aa(code_natural,$o,aa(nat,fun(code_natural,$o),code_cr_natural,X),Xa3)
    <=> ( X = aa(code_natural,nat,code_nat_of_natural,Xa3) ) ) ).

% cr_natural_def
tff(fact_4929_inv__o__cancel,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),hilbert_inv_into(B,C,top_top(set(B)),F)),F) = id(B) ) ) ).

% inv_o_cancel
tff(fact_4930_o__inv__o__cancel,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,C),G: fun(B,D)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),G),hilbert_inv_into(B,C,top_top(set(B)),F))),F) = G ) ) ).

% o_inv_o_cancel
tff(fact_4931_inj__map__inv__f,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),L: list(B)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => ( aa(list(C),list(B),map(C,B,hilbert_inv_into(B,C,top_top(set(B)),F)),aa(list(B),list(C),map(B,C,F),L)) = L ) ) ).

% inj_map_inv_f
tff(fact_4932_inv__into__comp,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(B,C),G: fun(D,B),A4: set(D),X2: C] :
      ( inj_on(B,C,F,aa(set(D),set(B),image2(D,B,G),A4))
     => ( inj_on(D,B,G,A4)
       => ( member(C,X2,aa(set(B),set(C),image2(B,C,F),aa(set(D),set(B),image2(D,B,G),A4)))
         => ( aa(C,D,hilbert_inv_into(D,C,A4,aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),F),G)),X2) = aa(C,D,aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),hilbert_inv_into(D,B,A4,G)),hilbert_inv_into(B,C,aa(set(D),set(B),image2(D,B,G),A4),F)),X2) ) ) ) ) ).

% inv_into_comp
tff(fact_4933_inv__unique__comp,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),G: fun(B,C)] :
      ( ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),F),G) = id(B) )
     => ( ( aa(fun(C,B),fun(C,C),aa(fun(B,C),fun(fun(C,B),fun(C,C)),comp(B,C,C),G),F) = id(C) )
       => ( hilbert_inv_into(C,B,top_top(set(C)),F) = G ) ) ) ).

% inv_unique_comp
tff(fact_4934_o__inv__distrib,axiom,
    ! [D: $tType,C: $tType,B: $tType,F: fun(B,C),G: fun(D,B)] :
      ( bij_betw(B,C,F,top_top(set(B)),top_top(set(C)))
     => ( bij_betw(D,B,G,top_top(set(D)),top_top(set(B)))
       => ( hilbert_inv_into(D,C,top_top(set(D)),aa(fun(D,B),fun(D,C),aa(fun(B,C),fun(fun(D,B),fun(D,C)),comp(B,C,D),F),G)) = aa(fun(C,B),fun(C,D),aa(fun(B,D),fun(fun(C,B),fun(C,D)),comp(B,D,C),hilbert_inv_into(D,B,top_top(set(D)),G)),hilbert_inv_into(B,C,top_top(set(B)),F)) ) ) ) ).

% o_inv_distrib
tff(fact_4935_surj__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B)] :
      ( ( aa(set(C),set(B),image2(C,B,F),top_top(set(C))) = top_top(set(B)) )
    <=> ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),F),hilbert_inv_into(C,B,top_top(set(C)),F)) = id(B) ) ) ).

% surj_iff
tff(fact_4936_inj__iff,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
    <=> ( aa(fun(B,C),fun(B,B),aa(fun(C,B),fun(fun(B,C),fun(B,B)),comp(C,B,B),hilbert_inv_into(B,C,top_top(set(B)),F)),F) = id(B) ) ) ).

% inj_iff
tff(fact_4937_fn__o__inv__fn__is__id,axiom,
    ! [B: $tType,F: fun(B,B),N: nat] :
      ( bij_betw(B,B,F,top_top(set(B)),top_top(set(B)))
     => ! [X: B] : aa(B,B,aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),compow(fun(B,B),N,F)),compow(fun(B,B),N,hilbert_inv_into(B,B,top_top(set(B)),F))),X) = X ) ).

% fn_o_inv_fn_is_id
tff(fact_4938_inv__fn__o__fn__is__id,axiom,
    ! [B: $tType,F: fun(B,B),N: nat] :
      ( bij_betw(B,B,F,top_top(set(B)),top_top(set(B)))
     => ! [X: B] : aa(B,B,aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),compow(fun(B,B),N,hilbert_inv_into(B,B,top_top(set(B)),F))),compow(fun(B,B),N,F)),X) = X ) ).

% inv_fn_o_fn_is_id
tff(fact_4939_bijection_Oinv__comp__right,axiom,
    ! [B: $tType,F: fun(B,B)] :
      ( hilbert_bijection(B,F)
     => ( aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),F),hilbert_inv_into(B,B,top_top(set(B)),F)) = id(B) ) ) ).

% bijection.inv_comp_right
tff(fact_4940_bijection_Oinv__comp__left,axiom,
    ! [B: $tType,F: fun(B,B)] :
      ( hilbert_bijection(B,F)
     => ( aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),hilbert_inv_into(B,B,top_top(set(B)),F)),F) = id(B) ) ) ).

% bijection.inv_comp_left
tff(fact_4941_finite__reachable__restrictedI,axiom,
    ! [B: $tType,Q: set(B),I4: set(B),E4: set(product_prod(B,B))] :
      ( finite_finite2(B,Q)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),I4),Q)
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),range2(B,B,E4)),Q)
         => finite_finite2(B,image(B,B,transitive_rtrancl(B,E4),I4)) ) ) ) ).

% finite_reachable_restrictedI
tff(fact_4942_Range__insert,axiom,
    ! [B: $tType,C: $tType,A3: C,B2: B,R: set(product_prod(C,B))] : range2(C,B,aa(set(product_prod(C,B)),set(product_prod(C,B)),insert2(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A3),B2)),R)) = aa(set(B),set(B),insert2(B,B2),range2(C,B,R)) ).

% Range_insert
tff(fact_4943_Range__iff,axiom,
    ! [B: $tType,C: $tType,A3: B,R: set(product_prod(C,B))] :
      ( member(B,A3,range2(C,B,R))
    <=> ? [Y3: C] : member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Y3),A3),R) ) ).

% Range_iff
tff(fact_4944_RangeE,axiom,
    ! [B: $tType,C: $tType,B2: B,R: set(product_prod(C,B))] :
      ( member(B,B2,range2(C,B,R))
     => ~ ! [A5: C] : ~ member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A5),B2),R) ) ).

% RangeE
tff(fact_4945_Range_Ointros,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,R: set(product_prod(B,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R)
     => member(C,B2,range2(B,C,R)) ) ).

% Range.intros
tff(fact_4946_Range_Osimps,axiom,
    ! [B: $tType,C: $tType,A3: B,R: set(product_prod(C,B))] :
      ( member(B,A3,range2(C,B,R))
    <=> ? [A7: C,B7: B] :
          ( ( A3 = B7 )
          & member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A7),B7),R) ) ) ).

% Range.simps
tff(fact_4947_Range_Ocases,axiom,
    ! [B: $tType,C: $tType,A3: B,R: set(product_prod(C,B))] :
      ( member(B,A3,range2(C,B,R))
     => ~ ! [A5: C] : ~ member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),A5),A3),R) ) ).

% Range.cases
tff(fact_4948_trancl__Image__in__Range,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),V5: set(B)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,transitive_trancl(B,R4),V5)),range2(B,B,R4)) ).

% trancl_Image_in_Range
tff(fact_4949_Range__rel__restrict,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),range2(B,B,rel_restrict(B,R4,A4))),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),range2(B,B,R4)),A4)) ).

% Range_rel_restrict
tff(fact_4950_dom__ran__disj__comp,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( ( aa(set(B),set(B),inf_inf(set(B),domain(B,B,R4)),range2(B,B,R4)) = bot_bot(set(B)) )
     => ( relcomp(B,B,B,R4,R4) = bot_bot(set(product_prod(B,B))) ) ) ).

% dom_ran_disj_comp
tff(fact_4951_wf__max,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( wf(B,converse(B,B,R4))
     => ( ( R4 != bot_bot(set(product_prod(B,B))) )
       => ~ ! [M4: B] : ~ member(B,M4,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),range2(B,B,R4)),domain(B,B,R4))) ) ) ).

% wf_max
tff(fact_4952_Rangep__Range__eq,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(C,B)),X: B] :
      ( aa(B,$o,rangep(C,B,aTP_Lamp_au(set(product_prod(C,B)),fun(C,fun(B,$o)),R)),X)
    <=> member(B,X,range2(C,B,R)) ) ).

% Rangep_Range_eq
tff(fact_4953_Domain__insert,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,R: set(product_prod(B,C))] : domain(B,C,aa(set(product_prod(B,C)),set(product_prod(B,C)),insert2(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)),R)) = aa(set(B),set(B),insert2(B,A3),domain(B,C,R)) ).

% Domain_insert
tff(fact_4954_Domain_Ocases,axiom,
    ! [C: $tType,B: $tType,A3: B,R: set(product_prod(B,C))] :
      ( member(B,A3,domain(B,C,R))
     => ~ ! [B3: C] : ~ member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B3),R) ) ).

% Domain.cases
tff(fact_4955_Domain_Osimps,axiom,
    ! [C: $tType,B: $tType,A3: B,R: set(product_prod(B,C))] :
      ( member(B,A3,domain(B,C,R))
    <=> ? [A7: B,B7: C] :
          ( ( A3 = A7 )
          & member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A7),B7),R) ) ) ).

% Domain.simps
tff(fact_4956_Domain_ODomainI,axiom,
    ! [C: $tType,B: $tType,A3: B,B2: C,R: set(product_prod(B,C))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),R)
     => member(B,A3,domain(B,C,R)) ) ).

% Domain.DomainI
tff(fact_4957_DomainE,axiom,
    ! [C: $tType,B: $tType,A3: B,R: set(product_prod(B,C))] :
      ( member(B,A3,domain(B,C,R))
     => ~ ! [B3: C] : ~ member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B3),R) ) ).

% DomainE
tff(fact_4958_Domain__iff,axiom,
    ! [C: $tType,B: $tType,A3: B,R: set(product_prod(B,C))] :
      ( member(B,A3,domain(B,C,R))
    <=> ? [Y3: C] : member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),Y3),R) ) ).

% Domain_iff
tff(fact_4959_Not__Domain__rtrancl,axiom,
    ! [B: $tType,X2: B,R4: set(product_prod(B,B)),Y: B] :
      ( ~ member(B,X2,domain(B,B,R4))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R4))
      <=> ( X2 = Y ) ) ) ).

% Not_Domain_rtrancl
tff(fact_4960_Domain__unfold,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C))] : domain(B,C,R) = aa(fun(B,$o),set(B),collect(B),aTP_Lamp_tt(set(product_prod(B,C)),fun(B,$o),R)) ).

% Domain_unfold
tff(fact_4961_for__in__RI,axiom,
    ! [C: $tType,B: $tType,X2: B,R4: set(product_prod(B,C))] :
      ( member(B,X2,domain(B,C,R4))
     => member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),fun_of_rel(B,C,R4,X2)),R4) ) ).

% for_in_RI
tff(fact_4962_Domain__rel__restrict,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A4: set(B)] : aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),domain(B,B,rel_restrict(B,R4,A4))),aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),domain(B,B,R4)),A4)) ).

% Domain_rel_restrict
tff(fact_4963_wf__no__path,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( ( aa(set(B),set(B),inf_inf(set(B),domain(B,B,R4)),range2(B,B,R4)) = bot_bot(set(B)) )
     => wf(B,R4) ) ).

% wf_no_path
tff(fact_4964_wf__min,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( wf(B,R4)
     => ( ( R4 != bot_bot(set(product_prod(B,B))) )
       => ~ ! [M4: B] : ~ member(B,M4,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),domain(B,B,R4)),range2(B,B,R4))) ) ) ).

% wf_min
tff(fact_4965_Range__def,axiom,
    ! [C: $tType,B: $tType,X: set(product_prod(B,C))] : range2(B,C,X) = aa(fun(C,$o),set(C),collect(C),rangep(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),X))) ).

% Range_def
tff(fact_4966_and_Omonoid__axioms,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => monoid(B,bit_se5824344872417868541ns_and(B),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% and.monoid_axioms
tff(fact_4967_cr__integer__def,axiom,
    ! [X: int,Xa3: code_integer] :
      ( aa(code_integer,$o,aa(int,fun(code_integer,$o),code_cr_integer,X),Xa3)
    <=> ( X = aa(code_integer,int,code_int_of_integer,Xa3) ) ) ).

% cr_integer_def
tff(fact_4968_wo__rel_OisMinim__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A4: set(B),B2: B] :
      ( bNF_Wellorder_wo_rel(B,R)
     => ( bNF_We4791949203932849705sMinim(B,R,A4,B2)
      <=> ( member(B,B2,A4)
          & ! [X4: B] :
              ( member(B,X4,A4)
             => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),X4),R) ) ) ) ) ).

% wo_rel.isMinim_def
tff(fact_4969_monoid_Oleft__neutral,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,A3: B] :
      ( monoid(B,F,Z2)
     => ( aa(B,B,aa(B,fun(B,B),F,Z2),A3) = A3 ) ) ).

% monoid.left_neutral
tff(fact_4970_monoid_Oright__neutral,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,A3: B] :
      ( monoid(B,F,Z2)
     => ( aa(B,B,aa(B,fun(B,B),F,A3),Z2) = A3 ) ) ).

% monoid.right_neutral
tff(fact_4971_add_Omonoid__axioms,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => monoid(B,plus_plus(B),zero_zero(B)) ) ).

% add.monoid_axioms
tff(fact_4972_mult_Omonoid__axioms,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => monoid(B,times_times(B),one_one(B)) ) ).

% mult.monoid_axioms
tff(fact_4973_integer_Opcr__cr__eq,axiom,
    code_pcr_integer = code_cr_integer ).

% integer.pcr_cr_eq
tff(fact_4974_multp__implies__one__step,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),M2: multiset(B),N5: multiset(B)] :
      ( transp(B,R)
     => ( multp(B,R,M2,N5)
       => ? [I7: multiset(B),J5: multiset(B)] :
            ( ( N5 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I7),J5) )
            & ? [K9: multiset(B)] :
                ( ( M2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),I7),K9) )
                & ( J5 != zero_zero(multiset(B)) )
                & ! [X: B] :
                    ( member(B,X,set_mset(B,K9))
                   => ? [Xa4: B] :
                        ( member(B,Xa4,set_mset(B,J5))
                        & aa(B,$o,aa(B,fun(B,$o),R,X),Xa4) ) ) ) ) ) ) ).

% multp_implies_one_step
tff(fact_4975_relpow__fun__conv,axiom,
    ! [B: $tType,A3: B,B2: B,N: nat,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),compow(set(product_prod(B,B)),N,R4))
    <=> ? [F6: fun(nat,B)] :
          ( ( aa(nat,B,F6,zero_zero(nat)) = A3 )
          & ( aa(nat,B,F6,N) = B2 )
          & ! [I3: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),N)
             => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(nat,B,F6,I3)),aa(nat,B,F6,aa(nat,nat,suc,I3))),R4) ) ) ) ).

% relpow_fun_conv
tff(fact_4976_irreflp__irrefl__eq,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( irreflp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R4))
    <=> irrefl(B,R4) ) ).

% irreflp_irrefl_eq
tff(fact_4977_relpow__1,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] : compow(set(product_prod(B,B)),one_one(nat),R4) = R4 ).

% relpow_1
tff(fact_4978_multp__cancel,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),X7: multiset(B),Z7: multiset(B),Y7: multiset(B)] :
      ( transp(B,R)
     => ( irreflp(B,R)
       => ( multp(B,R,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X7),Z7),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Y7),Z7))
        <=> multp(B,R,X7,Y7) ) ) ) ).

% multp_cancel
tff(fact_4979_relpow__Suc__D2_H,axiom,
    ! [B: $tType,N: nat,R4: set(product_prod(B,B)),X: B,Y5: B,Z5: B] :
      ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Y5),compow(set(product_prod(B,B)),N,R4))
        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),Z5),R4) )
     => ? [W3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),W3),R4)
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),W3),Z5),compow(set(product_prod(B,B)),N,R4)) ) ) ).

% relpow_Suc_D2'
tff(fact_4980_relpow__0__E,axiom,
    ! [B: $tType,X2: B,Y: B,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),compow(set(product_prod(B,B)),zero_zero(nat),R4))
     => ( X2 = Y ) ) ).

% relpow_0_E
tff(fact_4981_relpow__0__I,axiom,
    ! [B: $tType,X2: B,R4: set(product_prod(B,B))] : member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),X2),compow(set(product_prod(B,B)),zero_zero(nat),R4)) ).

% relpow_0_I
tff(fact_4982_relpow__Suc__E,axiom,
    ! [B: $tType,X2: B,Z2: B,N: nat,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),aa(nat,nat,suc,N),R4))
     => ~ ! [Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),compow(set(product_prod(B,B)),N,R4))
           => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),R4) ) ) ).

% relpow_Suc_E
tff(fact_4983_relpow__Suc__I,axiom,
    ! [B: $tType,X2: B,Y: B,N: nat,R4: set(product_prod(B,B)),Z2: B] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),compow(set(product_prod(B,B)),N,R4))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),R4)
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),aa(nat,nat,suc,N),R4)) ) ) ).

% relpow_Suc_I
tff(fact_4984_relpow__Suc__D2,axiom,
    ! [B: $tType,X2: B,Z2: B,N: nat,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),aa(nat,nat,suc,N),R4))
     => ? [Y4: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),R4)
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),compow(set(product_prod(B,B)),N,R4)) ) ) ).

% relpow_Suc_D2
tff(fact_4985_relpow__Suc__E2,axiom,
    ! [B: $tType,X2: B,Z2: B,N: nat,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),aa(nat,nat,suc,N),R4))
     => ~ ! [Y4: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),R4)
           => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),compow(set(product_prod(B,B)),N,R4)) ) ) ).

% relpow_Suc_E2
tff(fact_4986_relpow__Suc__I2,axiom,
    ! [B: $tType,X2: B,Y: B,R4: set(product_prod(B,B)),Z2: B,N: nat] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R4)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),compow(set(product_prod(B,B)),N,R4))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),aa(nat,nat,suc,N),R4)) ) ) ).

% relpow_Suc_I2
tff(fact_4987_relpow__add,axiom,
    ! [B: $tType,M: nat,N: nat,R4: set(product_prod(B,B))] : compow(set(product_prod(B,B)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),R4) = relcomp(B,B,B,compow(set(product_prod(B,B)),M,R4),compow(set(product_prod(B,B)),N,R4)) ).

% relpow_add
tff(fact_4988_transp__trans__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( transp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R))
    <=> trans(B,R) ) ).

% transp_trans_eq
tff(fact_4989_relpowp__relpow__eq,axiom,
    ! [B: $tType,N: nat,R4: set(product_prod(B,B)),X: B,Xa3: B] :
      ( aa(B,$o,aa(B,fun(B,$o),compow(fun(B,fun(B,$o)),N,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R4)),X),Xa3)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa3),compow(set(product_prod(B,B)),N,R4)) ) ).

% relpowp_relpow_eq
tff(fact_4990_relpow__E2,axiom,
    ! [B: $tType,X2: B,Z2: B,N: nat,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),N,R4))
     => ( ( ( N = zero_zero(nat) )
         => ( X2 != Z2 ) )
       => ~ ! [Y4: B,M4: nat] :
              ( ( N = aa(nat,nat,suc,M4) )
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),R4)
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),compow(set(product_prod(B,B)),M4,R4)) ) ) ) ) ).

% relpow_E2
tff(fact_4991_relpow__E,axiom,
    ! [B: $tType,X2: B,Z2: B,N: nat,R4: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),compow(set(product_prod(B,B)),N,R4))
     => ( ( ( N = zero_zero(nat) )
         => ( X2 != Z2 ) )
       => ~ ! [Y4: B,M4: nat] :
              ( ( N = aa(nat,nat,suc,M4) )
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y4),compow(set(product_prod(B,B)),M4,R4))
               => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z2),R4) ) ) ) ) ).

% relpow_E
tff(fact_4992_nths__drop,axiom,
    ! [B: $tType,N: nat,Xsa: list(B),I4: set(nat)] : nths(B,drop(B,N,Xsa),I4) = nths(B,Xsa,aa(set(nat),set(nat),image2(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N)),I4)) ).

% nths_drop
tff(fact_4993_nths__append,axiom,
    ! [B: $tType,L: list(B),L4: list(B),A4: set(nat)] : nths(B,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),L),L4),A4) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),nths(B,L,A4)),nths(B,L4,aa(fun(nat,$o),set(nat),collect(nat),aa(set(nat),fun(nat,$o),aTP_Lamp_tu(list(B),fun(set(nat),fun(nat,$o)),L),A4)))) ).

% nths_append
tff(fact_4994_asymp__asym__eq,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( asymp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R4))
    <=> asym(B,R4) ) ).

% asymp_asym_eq
tff(fact_4995_asym_Ocases,axiom,
    ! [B: $tType,A3: set(product_prod(B,B))] :
      ( asym(B,A3)
     => ! [A14: B,B6: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A14),B6),A3)
         => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B6),A14),A3) ) ) ).

% asym.cases
tff(fact_4996_asym_Osimps,axiom,
    ! [B: $tType,A3: set(product_prod(B,B))] :
      ( asym(B,A3)
    <=> ? [R10: set(product_prod(B,B))] :
          ( ( A3 = R10 )
          & ! [X4: B,Xa2: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R10)
             => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),R10) ) ) ) ).

% asym.simps
tff(fact_4997_asym_Ointros,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( ! [A5: B,B3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A5),B3),R4)
         => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B3),A5),R4) )
     => asym(B,R4) ) ).

% asym.intros
tff(fact_4998_asymD,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),X2: B,Y: B] :
      ( asym(B,R4)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R4)
       => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),X2),R4) ) ) ).

% asymD
tff(fact_4999_asym__iff,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( asym(B,R4)
    <=> ! [X4: B,Y3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Y3),R4)
         => ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y3),X4),R4) ) ) ).

% asym_iff
tff(fact_5000_lexord__asymmetric,axiom,
    ! [B: $tType,R4: set(product_prod(B,B)),A3: list(B),B2: list(B)] :
      ( asym(B,R4)
     => ( member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),A3),B2),lexord(B,R4))
       => ~ member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),B2),A3),lexord(B,R4)) ) ) ).

% lexord_asymmetric
tff(fact_5001_ordLess__iff,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
    <=> ( order_well_order_on(B,field2(B,R),R)
        & order_well_order_on(C,field2(C,R3),R3)
        & ~ ? [X_1: fun(C,B)] : bNF_Wellorder_embed(C,B,R3,R,X_1) ) ) ).

% ordLess_iff
tff(fact_5002_option_Oin__rel,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),A3: option(B),B2: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),A3),B2)
    <=> ? [Z4: option(product_prod(B,C))] :
          ( member(option(product_prod(B,C)),Z4,aa(fun(option(product_prod(B,C)),$o),set(option(product_prod(B,C))),collect(option(product_prod(B,C))),aTP_Lamp_tv(fun(B,fun(C,$o)),fun(option(product_prod(B,C)),$o),R4)))
          & ( aa(option(product_prod(B,C)),option(B),aa(fun(product_prod(B,C),B),fun(option(product_prod(B,C)),option(B)),map_option(product_prod(B,C),B),product_fst(B,C)),Z4) = A3 )
          & ( aa(option(product_prod(B,C)),option(C),aa(fun(product_prod(B,C),C),fun(option(product_prod(B,C)),option(C)),map_option(product_prod(B,C),C),product_snd(B,C)),Z4) = B2 ) ) ) ).

% option.in_rel
tff(fact_5003_bit__double__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [A3: B,N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),A3)),N)
        <=> ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),A3),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),one_one(nat)))
            & ( N != zero_zero(nat) )
            & bit_se6407376104438227557le_bit(B,type2(B),N) ) ) ) ).

% bit_double_iff
tff(fact_5004_rel__option__None2,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o)),X2: option(B)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),P),X2),none(C))
    <=> ( X2 = none(B) ) ) ).

% rel_option_None2
tff(fact_5005_rel__option__None1,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),X2: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),P),none(B)),X2)
    <=> ( X2 = none(C) ) ) ).

% rel_option_None1
tff(fact_5006_bit__minus__1__iff,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,uminus_uminus(B),one_one(B))),N)
        <=> bit_se6407376104438227557le_bit(B,type2(B),N) ) ) ).

% bit_minus_1_iff
tff(fact_5007_rel__option__iff,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: option(B),Y: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),X2),Y)
    <=> aa(product_prod(option(B),option(C)),$o,aa(fun(option(B),fun(option(C),$o)),fun(product_prod(option(B),option(C)),$o),product_case_prod(option(B),option(C),$o),aTP_Lamp_ty(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),R4)),aa(option(C),product_prod(option(B),option(C)),aa(option(B),fun(option(C),product_prod(option(B),option(C))),product_Pair(option(B),option(C)),X2),Y)) ) ).

% rel_option_iff
tff(fact_5008_option_Orel__mono,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(C,$o)),Ra2: fun(B,fun(C,$o))] :
      ( aa(fun(B,fun(C,$o)),$o,aa(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),$o),ord_less_eq(fun(B,fun(C,$o))),R4),Ra2)
     => aa(fun(option(B),fun(option(C),$o)),$o,aa(fun(option(B),fun(option(C),$o)),fun(fun(option(B),fun(option(C),$o)),$o),ord_less_eq(fun(option(B),fun(option(C),$o))),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4)),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),Ra2)) ) ).

% option.rel_mono
tff(fact_5009_option_Orel__inject_I2_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X22: B,Y2: C] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),aa(B,option(B),some(B),X22)),aa(C,option(C),some(C),Y2))
    <=> aa(C,$o,aa(B,fun(C,$o),R4,X22),Y2) ) ).

% option.rel_inject(2)
tff(fact_5010_option_Orel__intros_I2_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X22: B,Y2: C] :
      ( aa(C,$o,aa(B,fun(C,$o),R4,X22),Y2)
     => aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),aa(B,option(B),some(B),X22)),aa(C,option(C),some(C),Y2)) ) ).

% option.rel_intros(2)
tff(fact_5011_option__rel__Some1,axiom,
    ! [B: $tType,C: $tType,A4: fun(B,fun(C,$o)),X2: B,Y: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),A4),aa(B,option(B),some(B),X2)),Y)
    <=> ? [Y10: C] :
          ( ( Y = aa(C,option(C),some(C),Y10) )
          & aa(C,$o,aa(B,fun(C,$o),A4,X2),Y10) ) ) ).

% option_rel_Some1
tff(fact_5012_option__rel__Some2,axiom,
    ! [B: $tType,C: $tType,A4: fun(B,fun(C,$o)),X2: option(B),Y: C] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),A4),X2),aa(C,option(C),some(C),Y))
    <=> ? [X13: B] :
          ( ( X2 = aa(B,option(B),some(B),X13) )
          & aa(C,$o,aa(B,fun(C,$o),A4,X13),Y) ) ) ).

% option_rel_Some2
tff(fact_5013_option_Octr__transfer_I1_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),none(B)),none(C)) ).

% option.ctr_transfer(1)
tff(fact_5014_rel__option__inf,axiom,
    ! [C: $tType,B: $tType,A4: fun(B,fun(C,$o)),B5: fun(B,fun(C,$o))] : aa(fun(option(B),fun(option(C),$o)),fun(option(B),fun(option(C),$o)),inf_inf(fun(option(B),fun(option(C),$o)),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),A4)),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),B5)) = aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),inf_inf(fun(B,fun(C,$o)),A4),B5)) ).

% rel_option_inf
tff(fact_5015_option_Orel__refl,axiom,
    ! [B: $tType,Ra2: fun(B,fun(B,$o)),X2: option(B)] :
      ( ! [X3: B] : aa(B,$o,aa(B,fun(B,$o),Ra2,X3),X3)
     => aa(option(B),$o,aa(option(B),fun(option(B),$o),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),Ra2),X2),X2) ) ).

% option.rel_refl
tff(fact_5016_option_Orel__eq,axiom,
    ! [B: $tType] : aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),fequal(B)) = fequal(option(B)) ).

% option.rel_eq
tff(fact_5017_option_Orel__cong,axiom,
    ! [B: $tType,C: $tType,X2: option(B),Ya: option(B),Y: option(C),Xa: option(C),R4: fun(B,fun(C,$o)),Ra2: fun(B,fun(C,$o))] :
      ( ( X2 = Ya )
     => ( ( Y = Xa )
       => ( ! [Z3: B,Yb: C] :
              ( member(B,Z3,aa(option(B),set(B),set_option(B),Ya))
             => ( member(C,Yb,aa(option(C),set(C),set_option(C),Xa))
               => ( aa(C,$o,aa(B,fun(C,$o),R4,Z3),Yb)
                <=> aa(C,$o,aa(B,fun(C,$o),Ra2,Z3),Yb) ) ) )
         => ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),X2),Y)
          <=> aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),Ra2),Ya),Xa) ) ) ) ) ).

% option.rel_cong
tff(fact_5018_option_Orel__mono__strong,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: option(B),Y: option(C),Ra2: fun(B,fun(C,$o))] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),X2),Y)
     => ( ! [Z3: B,Yb: C] :
            ( member(B,Z3,aa(option(B),set(B),set_option(B),X2))
           => ( member(C,Yb,aa(option(C),set(C),set_option(C),Y))
             => ( aa(C,$o,aa(B,fun(C,$o),R4,Z3),Yb)
               => aa(C,$o,aa(B,fun(C,$o),Ra2,Z3),Yb) ) ) )
       => aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),Ra2),X2),Y) ) ) ).

% option.rel_mono_strong
tff(fact_5019_option_Orel__refl__strong,axiom,
    ! [B: $tType,X2: option(B),Ra2: fun(B,fun(B,$o))] :
      ( ! [Z3: B] :
          ( member(B,Z3,aa(option(B),set(B),set_option(B),X2))
         => aa(B,$o,aa(B,fun(B,$o),Ra2,Z3),Z3) )
     => aa(option(B),$o,aa(option(B),fun(option(B),$o),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),Ra2),X2),X2) ) ).

% option.rel_refl_strong
tff(fact_5020_rel__option__reflI,axiom,
    ! [B: $tType,Y: option(B),P: fun(B,fun(B,$o))] :
      ( ! [X3: B] :
          ( member(B,X3,aa(option(B),set(B),set_option(B),Y))
         => aa(B,$o,aa(B,fun(B,$o),P,X3),X3) )
     => aa(option(B),$o,aa(option(B),fun(option(B),$o),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),P),Y),Y) ) ).

% rel_option_reflI
tff(fact_5021_option_Orel__map_I1_J,axiom,
    ! [D: $tType,B: $tType,C: $tType,Sb: fun(B,fun(C,$o)),I: fun(D,B),X2: option(D),Y: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),Sb),aa(option(D),option(B),aa(fun(D,B),fun(option(D),option(B)),map_option(D,B),I),X2)),Y)
    <=> aa(option(C),$o,aa(option(D),fun(option(C),$o),aa(fun(D,fun(C,$o)),fun(option(D),fun(option(C),$o)),rel_option(D,C),aa(fun(D,B),fun(D,fun(C,$o)),aTP_Lamp_tz(fun(B,fun(C,$o)),fun(fun(D,B),fun(D,fun(C,$o))),Sb),I)),X2),Y) ) ).

% option.rel_map(1)
tff(fact_5022_option_Orel__map_I2_J,axiom,
    ! [B: $tType,C: $tType,D: $tType,Sa: fun(B,fun(C,$o)),X2: option(B),G: fun(D,C),Y: option(D)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),Sa),X2),aa(option(D),option(C),aa(fun(D,C),fun(option(D),option(C)),map_option(D,C),G),Y))
    <=> aa(option(D),$o,aa(option(B),fun(option(D),$o),aa(fun(B,fun(D,$o)),fun(option(B),fun(option(D),$o)),rel_option(B,D),aa(fun(D,C),fun(B,fun(D,$o)),aTP_Lamp_ua(fun(B,fun(C,$o)),fun(fun(D,C),fun(B,fun(D,$o))),Sa),G)),X2),Y) ) ).

% option.rel_map(2)
tff(fact_5023_option_Orel__flip,axiom,
    ! [C: $tType,B: $tType,R4: fun(C,fun(B,$o)),A3: option(B),B2: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),conversep(C,B,R4)),A3),B2)
    <=> aa(option(B),$o,aa(option(C),fun(option(B),$o),aa(fun(C,fun(B,$o)),fun(option(C),fun(option(B),$o)),rel_option(C,B),R4),B2),A3) ) ).

% option.rel_flip
tff(fact_5024_option_Orel__conversep,axiom,
    ! [B: $tType,C: $tType,R4: fun(C,fun(B,$o))] : aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),conversep(C,B,R4)) = conversep(option(C),option(B),aa(fun(C,fun(B,$o)),fun(option(C),fun(option(B),$o)),rel_option(C,B),R4)) ).

% option.rel_conversep
tff(fact_5025_option_Octr__transfer_I2_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(fun(C,option(C)),$o,aa(fun(B,option(B)),fun(fun(C,option(C)),$o),bNF_rel_fun(B,C,option(B),option(C),R4,aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4)),some(B)),some(C)) ).

% option.ctr_transfer(2)
tff(fact_5026_option_Odisc__transfer_I2_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(fun(option(C),$o),$o,aa(fun(option(B),$o),fun(fun(option(C),$o),$o),bNF_rel_fun(option(B),option(C),$o,$o,aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),fequal($o)),aTP_Lamp_ub(option(B),$o)),aTP_Lamp_uc(option(C),$o)) ).

% option.disc_transfer(2)
tff(fact_5027_option_Odisc__transfer_I1_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(fun(option(C),$o),$o,aa(fun(option(B),$o),fun(fun(option(C),$o),$o),bNF_rel_fun(option(B),option(C),$o,$o,aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),fequal($o)),aTP_Lamp_ud(option(B),$o)),aTP_Lamp_ue(option(C),$o)) ).

% option.disc_transfer(1)
tff(fact_5028_option__bind__transfer,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,A4: fun(B,fun(C,$o)),B5: fun(D,fun(E,$o))] : aa(fun(option(C),fun(fun(C,option(E)),option(E))),$o,aa(fun(option(B),fun(fun(B,option(D)),option(D))),fun(fun(option(C),fun(fun(C,option(E)),option(E))),$o),bNF_rel_fun(option(B),option(C),fun(fun(B,option(D)),option(D)),fun(fun(C,option(E)),option(E)),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),A4),bNF_rel_fun(fun(B,option(D)),fun(C,option(E)),option(D),option(E),bNF_rel_fun(B,C,option(D),option(E),A4,aa(fun(D,fun(E,$o)),fun(option(D),fun(option(E),$o)),rel_option(D,E),B5)),aa(fun(D,fun(E,$o)),fun(option(D),fun(option(E),$o)),rel_option(D,E),B5))),bind(B,D)),bind(C,E)) ).

% option_bind_transfer
tff(fact_5029_option_Orel__transp,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o))] :
      ( transp(B,R4)
     => transp(option(B),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),R4)) ) ).

% option.rel_transp
tff(fact_5030_option_Orel__distinct_I2_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),Y2: B] : ~ aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),aa(B,option(B),some(B),Y2)),none(C)) ).

% option.rel_distinct(2)
tff(fact_5031_option_Orel__distinct_I1_J,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),Y2: C] : ~ aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),none(B)),aa(C,option(C),some(C),Y2)) ).

% option.rel_distinct(1)
tff(fact_5032_option_Orel__cases,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),A3: option(B),B2: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),A3),B2)
     => ( ( ( A3 = none(B) )
         => ( B2 != none(C) ) )
       => ~ ! [X3: B] :
              ( ( A3 = aa(B,option(B),some(B),X3) )
             => ! [Y4: C] :
                  ( ( B2 = aa(C,option(C),some(C),Y4) )
                 => ~ aa(C,$o,aa(B,fun(C,$o),R4,X3),Y4) ) ) ) ) ).

% option.rel_cases
tff(fact_5033_option_Orel__induct,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: option(B),Y: option(C),Q: fun(option(B),fun(option(C),$o))] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),X2),Y)
     => ( aa(option(C),$o,aa(option(B),fun(option(C),$o),Q,none(B)),none(C))
       => ( ! [A23: B,B23: C] :
              ( aa(C,$o,aa(B,fun(C,$o),R4,A23),B23)
             => aa(option(C),$o,aa(option(B),fun(option(C),$o),Q,aa(B,option(B),some(B),A23)),aa(C,option(C),some(C),B23)) )
         => aa(option(C),$o,aa(option(B),fun(option(C),$o),Q,X2),Y) ) ) ) ).

% option.rel_induct
tff(fact_5034_option_Omap__transfer,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,Rb2: fun(B,fun(D,$o)),Sd: fun(C,fun(E,$o))] : aa(fun(fun(D,E),fun(option(D),option(E))),$o,aa(fun(fun(B,C),fun(option(B),option(C))),fun(fun(fun(D,E),fun(option(D),option(E))),$o),bNF_rel_fun(fun(B,C),fun(D,E),fun(option(B),option(C)),fun(option(D),option(E)),bNF_rel_fun(B,D,C,E,Rb2,Sd),bNF_rel_fun(option(B),option(D),option(C),option(E),aa(fun(B,fun(D,$o)),fun(option(B),fun(option(D),$o)),rel_option(B,D),Rb2),aa(fun(C,fun(E,$o)),fun(option(C),fun(option(E),$o)),rel_option(C,E),Sd))),map_option(B,C)),map_option(D,E)) ).

% option.map_transfer
tff(fact_5035_option_Ocase__transfer,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,S2: fun(B,fun(C,$o)),R4: fun(D,fun(E,$o))] : aa(fun(C,fun(fun(E,C),fun(option(E),C))),$o,aa(fun(B,fun(fun(D,B),fun(option(D),B))),fun(fun(C,fun(fun(E,C),fun(option(E),C))),$o),bNF_rel_fun(B,C,fun(fun(D,B),fun(option(D),B)),fun(fun(E,C),fun(option(E),C)),S2,bNF_rel_fun(fun(D,B),fun(E,C),fun(option(D),B),fun(option(E),C),bNF_rel_fun(D,E,B,C,R4,S2),bNF_rel_fun(option(D),option(E),B,C,aa(fun(D,fun(E,$o)),fun(option(D),fun(option(E),$o)),rel_option(D,E),R4),S2))),case_option(B,D)),case_option(C,E)) ).

% option.case_transfer
tff(fact_5036_option_Orel__transfer,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,Sa: fun(B,fun(D,$o)),Sc: fun(C,fun(E,$o))] : aa(fun(fun(D,fun(E,$o)),fun(option(D),fun(option(E),$o))),$o,aa(fun(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o))),fun(fun(fun(D,fun(E,$o)),fun(option(D),fun(option(E),$o))),$o),bNF_rel_fun(fun(B,fun(C,$o)),fun(D,fun(E,$o)),fun(option(B),fun(option(C),$o)),fun(option(D),fun(option(E),$o)),bNF_rel_fun(B,D,fun(C,$o),fun(E,$o),Sa,bNF_rel_fun(C,E,$o,$o,Sc,fequal($o))),bNF_rel_fun(option(B),option(D),fun(option(C),$o),fun(option(E),$o),aa(fun(B,fun(D,$o)),fun(option(B),fun(option(D),$o)),rel_option(B,D),Sa),bNF_rel_fun(option(C),option(E),$o,$o,aa(fun(C,fun(E,$o)),fun(option(C),fun(option(E),$o)),rel_option(C,E),Sc),fequal($o)))),rel_option(B,C)),rel_option(D,E)) ).

% option.rel_transfer
tff(fact_5037_bit__minus__iff,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => ! [A3: B,N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,uminus_uminus(B),A3)),N)
        <=> ( bit_se6407376104438227557le_bit(B,type2(B),N)
            & ~ aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),A3),one_one(B))),N) ) ) ) ).

% bit_minus_iff
tff(fact_5038_option_Orel__sel,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),A3: option(B),B2: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),A3),B2)
    <=> ( ( ( A3 = none(B) )
        <=> ( B2 = none(C) ) )
        & ( ( A3 != none(B) )
         => ( ( B2 != none(C) )
           => aa(C,$o,aa(B,fun(C,$o),R4,aa(option(B),B,the2(B),A3)),aa(option(C),C,the2(C),B2)) ) ) ) ) ).

% option.rel_sel
tff(fact_5039_ordLess__not__embed,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => ~ ? [X_12: fun(C,B)] : bNF_Wellorder_embed(C,B,R3,R,X_12) ) ).

% ordLess_not_embed
tff(fact_5040_option_Orec__transfer,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,S2: fun(B,fun(C,$o)),R4: fun(D,fun(E,$o))] : aa(fun(C,fun(fun(E,C),fun(option(E),C))),$o,aa(fun(B,fun(fun(D,B),fun(option(D),B))),fun(fun(C,fun(fun(E,C),fun(option(E),C))),$o),bNF_rel_fun(B,C,fun(fun(D,B),fun(option(D),B)),fun(fun(E,C),fun(option(E),C)),S2,bNF_rel_fun(fun(D,B),fun(E,C),fun(option(D),B),fun(option(E),C),bNF_rel_fun(D,E,B,C,R4,S2),bNF_rel_fun(option(D),option(E),B,C,aa(fun(D,fun(E,$o)),fun(option(D),fun(option(E),$o)),rel_option(D,E),R4),S2))),rec_option(B,D)),rec_option(C,E)) ).

% option.rec_transfer
tff(fact_5041_bit__2__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),N)
        <=> ( bit_se6407376104438227557le_bit(B,type2(B),one_one(nat))
            & ( N = one_one(nat) ) ) ) ) ).

% bit_2_iff
tff(fact_5042_BNF__Wellorder__Constructions_OordLess__Field,axiom,
    ! [B: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),F: fun(B,C)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R1),R22),bNF_We4044943003108391690rdLess(B,C))
     => ( bNF_Wellorder_embed(B,C,R1,R22,F)
       => ( aa(set(B),set(C),image2(B,C,F),field2(B,R1)) != field2(C,R22) ) ) ) ).

% BNF_Wellorder_Constructions.ordLess_Field
tff(fact_5043_bit__mask__sub__iff,axiom,
    ! [B: $tType] :
      ( bit_semiring_bits(B)
     => ! [M: nat,N: nat] :
          ( aa(nat,$o,aa(B,fun(nat,$o),bit_se5641148757651400278ts_bit(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),M)),one_one(B))),N)
        <=> ( bit_se6407376104438227557le_bit(B,type2(B),N)
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M) ) ) ) ).

% bit_mask_sub_iff
tff(fact_5044_embed__ordLess__ofilterIncl,axiom,
    ! [C: $tType,B: $tType,D: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),R33: set(product_prod(D,D)),F13: fun(B,D),F23: fun(C,D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R1),R22),bNF_We4044943003108391690rdLess(B,C))
     => ( member(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))),R22),R33),bNF_We4044943003108391690rdLess(C,D))
       => ( bNF_Wellorder_embed(B,D,R1,R33,F13)
         => ( bNF_Wellorder_embed(C,D,R22,R33,F23)
           => member(product_prod(set(D),set(D)),aa(set(D),product_prod(set(D),set(D)),aa(set(D),fun(set(D),product_prod(set(D),set(D))),product_Pair(set(D),set(D)),aa(set(B),set(D),image2(B,D,F13),field2(B,R1))),aa(set(C),set(D),image2(C,D,F23),field2(C,R22))),bNF_We413866401316099525erIncl(D,R33)) ) ) ) ) ).

% embed_ordLess_ofilterIncl
tff(fact_5045_comp__embed,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( bNF_Wellorder_embed(B,C,R,R3,F)
     => ( bNF_Wellorder_embed(C,D,R3,R8,F2)
       => bNF_Wellorder_embed(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ).

% comp_embed
tff(fact_5046_override__on__insert,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),G: fun(B,C),X2: B,X7: set(B)] : override_on(B,C,F,G,aa(set(B),set(B),insert2(B,X2),X7)) = fun_upd(B,C,override_on(B,C,F,G,X7),X2,aa(B,C,G,X2)) ).

% override_on_insert
tff(fact_5047_override__on__apply__in,axiom,
    ! [C: $tType,B: $tType,A3: B,A4: set(B),F: fun(B,C),G: fun(B,C)] :
      ( member(B,A3,A4)
     => ( aa(B,C,override_on(B,C,F,G,A4),A3) = aa(B,C,G,A3) ) ) ).

% override_on_apply_in
tff(fact_5048_override__on__apply__notin,axiom,
    ! [C: $tType,B: $tType,A3: B,A4: set(B),F: fun(B,C),G: fun(B,C)] :
      ( ~ member(B,A3,A4)
     => ( aa(B,C,override_on(B,C,F,G,A4),A3) = aa(B,C,F,A3) ) ) ).

% override_on_apply_notin
tff(fact_5049_override__on__emptyset,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),G: fun(B,C)] : override_on(B,C,F,G,bot_bot(set(B))) = F ).

% override_on_emptyset
tff(fact_5050_override__on__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),G: fun(B,C),A4: set(B),X: B] :
      aa(B,C,override_on(B,C,F,G,A4),X) = $ite(member(B,X,A4),aa(B,C,G,X),aa(B,C,F,X)) ).

% override_on_def
tff(fact_5051_override__on__insert_H,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),G: fun(B,C),X2: B,X7: set(B)] : override_on(B,C,F,G,aa(set(B),set(B),insert2(B,X2),X7)) = override_on(B,C,fun_upd(B,C,F,X2,aa(B,C,G,X2)),G,X7) ).

% override_on_insert'
tff(fact_5052_embedS__comp__embed,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( bNF_Wellorder_embedS(B,C,R,R3,F)
         => ( bNF_Wellorder_embed(C,D,R3,R8,F2)
           => bNF_Wellorder_embedS(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ) ) ).

% embedS_comp_embed
tff(fact_5053_embed__comp__embedS,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( bNF_Wellorder_embed(B,C,R,R3,F)
         => ( bNF_Wellorder_embedS(C,D,R3,R8,F2)
           => bNF_Wellorder_embedS(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ) ) ).

% embed_comp_embedS
tff(fact_5054_pred__option__parametric,axiom,
    ! [B: $tType,C: $tType,A4: fun(B,fun(C,$o))] : aa(fun(fun(C,$o),fun(option(C),$o)),$o,aa(fun(fun(B,$o),fun(option(B),$o)),fun(fun(fun(C,$o),fun(option(C),$o)),$o),bNF_rel_fun(fun(B,$o),fun(C,$o),fun(option(B),$o),fun(option(C),$o),bNF_rel_fun(B,C,$o,$o,A4,fequal($o)),bNF_rel_fun(option(B),option(C),$o,$o,aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),A4),fequal($o))),pred_option(B)),pred_option(C)) ).

% pred_option_parametric
tff(fact_5055_option_Opred__inject_I2_J,axiom,
    ! [B: $tType,P: fun(B,$o),A3: B] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),P),aa(B,option(B),some(B),A3))
    <=> aa(B,$o,P,A3) ) ).

% option.pred_inject(2)
tff(fact_5056_option_Opred__mono,axiom,
    ! [B: $tType,P: fun(B,$o),Pa: fun(B,$o)] :
      ( aa(fun(B,$o),$o,aa(fun(B,$o),fun(fun(B,$o),$o),ord_less_eq(fun(B,$o)),P),Pa)
     => aa(fun(option(B),$o),$o,aa(fun(option(B),$o),fun(fun(option(B),$o),$o),ord_less_eq(fun(option(B),$o)),aa(fun(B,$o),fun(option(B),$o),pred_option(B),P)),aa(fun(B,$o),fun(option(B),$o),pred_option(B),Pa)) ) ).

% option.pred_mono
tff(fact_5057_option_Opred__inject_I1_J,axiom,
    ! [B: $tType,P: fun(B,$o)] : aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),P),none(B)) ).

% option.pred_inject(1)
tff(fact_5058_option_Opred__True,axiom,
    ! [B: $tType,X: option(B)] : aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),aTP_Lamp_af(B,$o)),X) ).

% option.pred_True
tff(fact_5059_option_Opred__mono__strong,axiom,
    ! [B: $tType,P: fun(B,$o),X2: option(B),Pa: fun(B,$o)] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),P),X2)
     => ( ! [Z3: B] :
            ( member(B,Z3,aa(option(B),set(B),set_option(B),X2))
           => ( aa(B,$o,P,Z3)
             => aa(B,$o,Pa,Z3) ) )
       => aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),Pa),X2) ) ) ).

% option.pred_mono_strong
tff(fact_5060_option_Opred__cong,axiom,
    ! [B: $tType,X2: option(B),Ya: option(B),P: fun(B,$o),Pa: fun(B,$o)] :
      ( ( X2 = Ya )
     => ( ! [Z3: B] :
            ( member(B,Z3,aa(option(B),set(B),set_option(B),Ya))
           => ( aa(B,$o,P,Z3)
            <=> aa(B,$o,Pa,Z3) ) )
       => ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),P),X2)
        <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),Pa),Ya) ) ) ) ).

% option.pred_cong
tff(fact_5061_option_Omap__cong__pred,axiom,
    ! [C: $tType,B: $tType,X2: option(B),Ya: option(B),F: fun(B,C),G: fun(B,C)] :
      ( ( X2 = Ya )
     => ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_uf(fun(B,C),fun(fun(B,C),fun(B,$o)),F),G)),Ya)
       => ( aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),X2) = aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),G),Ya) ) ) ) ).

% option.map_cong_pred
tff(fact_5062_option_Opred__set,axiom,
    ! [B: $tType,P: fun(B,$o),X: option(B)] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),P),X)
    <=> ! [Xa2: B] :
          ( member(B,Xa2,aa(option(B),set(B),set_option(B),X))
         => aa(B,$o,P,Xa2) ) ) ).

% option.pred_set
tff(fact_5063_option_Opred__rel,axiom,
    ! [B: $tType,P: fun(B,$o),X2: option(B)] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),P),X2)
    <=> aa(option(B),$o,aa(option(B),fun(option(B),$o),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),bNF_eq_onp(B,P)),X2),X2) ) ).

% option.pred_rel
tff(fact_5064_option_Orel__eq__onp,axiom,
    ! [B: $tType,P: fun(B,$o)] : aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),bNF_eq_onp(B,P)) = bNF_eq_onp(option(B),aa(fun(B,$o),fun(option(B),$o),pred_option(B),P)) ).

% option.rel_eq_onp
tff(fact_5065_option_Opred__map,axiom,
    ! [B: $tType,C: $tType,Q: fun(B,$o),F: fun(C,B),X2: option(C)] :
      ( aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),pred_option(B),Q),aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),X2))
    <=> aa(option(C),$o,aa(fun(C,$o),fun(option(C),$o),pred_option(C),aa(fun(C,B),fun(C,$o),aa(fun(B,$o),fun(fun(C,B),fun(C,$o)),comp(B,$o,C),Q),F)),X2) ) ).

% option.pred_map
tff(fact_5066_option_Opred__transfer,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(fun(fun(C,$o),fun(option(C),$o)),$o,aa(fun(fun(B,$o),fun(option(B),$o)),fun(fun(fun(C,$o),fun(option(C),$o)),$o),bNF_rel_fun(fun(B,$o),fun(C,$o),fun(option(B),$o),fun(option(C),$o),bNF_rel_fun(B,C,$o,$o,R4,fequal($o)),bNF_rel_fun(option(B),option(C),$o,$o,aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),fequal($o))),pred_option(B)),pred_option(C)) ).

% option.pred_transfer
tff(fact_5067_iso__comp__embedS,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( order_well_order_on(C,field2(C,R3),R3)
       => ( bNF_Wellorder_iso(B,C,R,R3,F)
         => ( bNF_Wellorder_embedS(C,D,R3,R8,F2)
           => bNF_Wellorder_embedS(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ) ) ).

% iso_comp_embedS
tff(fact_5068_cut__def,axiom,
    ! [B: $tType,C: $tType,F: fun(B,C),R4: set(product_prod(B,B)),X2: B,X: B] :
      aa(B,C,cut(B,C,F,R4,X2),X) = $ite(member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),X2),R4),aa(B,C,F,X),undefined(C)) ).

% cut_def
tff(fact_5069_above__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] : order_above(B,R,A3) = aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R),A3)) ).

% above_def
tff(fact_5070_comp__iso,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( bNF_Wellorder_iso(B,C,R,R3,F)
     => ( bNF_Wellorder_iso(C,D,R3,R8,F2)
       => bNF_Wellorder_iso(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ).

% comp_iso
tff(fact_5071_iso__forward,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: B,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
     => ( bNF_Wellorder_iso(B,C,R,R3,F)
       => member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,F,X2)),aa(B,C,F,Y)),R3) ) ) ).

% iso_forward
tff(fact_5072_cut__apply,axiom,
    ! [C: $tType,B: $tType,X2: B,A3: B,R4: set(product_prod(B,B)),F: fun(B,C)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),A3),R4)
     => ( aa(B,C,cut(B,C,F,R4,A3),X2) = aa(B,C,F,X2) ) ) ).

% cut_apply
tff(fact_5073_cuts__eq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),R4: set(product_prod(B,B)),X2: B,G: fun(B,C)] :
      ( ( cut(B,C,F,R4,X2) = cut(B,C,G,R4,X2) )
    <=> ! [Y3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y3),X2),R4)
         => ( aa(B,C,F,Y3) = aa(B,C,G,Y3) ) ) ) ).

% cuts_eq
tff(fact_5074_iso__comp__embed,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( bNF_Wellorder_iso(B,C,R,R3,F)
     => ( bNF_Wellorder_embed(C,D,R3,R8,F2)
       => bNF_Wellorder_embed(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ).

% iso_comp_embed
tff(fact_5075_embed__comp__iso,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( bNF_Wellorder_embed(B,C,R,R3,F)
     => ( bNF_Wellorder_iso(C,D,R3,R8,F2)
       => bNF_Wellorder_embed(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ).

% embed_comp_iso
tff(fact_5076_embedS__comp__iso,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C),R8: set(product_prod(D,D)),F2: fun(C,D)] :
      ( bNF_Wellorder_embedS(B,C,R,R3,F)
     => ( bNF_Wellorder_iso(C,D,R3,R8,F2)
       => bNF_Wellorder_embedS(B,D,R,R8,aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F2),F)) ) ) ).

% embedS_comp_iso
tff(fact_5077_iso__iff2,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C)] :
      ( bNF_Wellorder_iso(B,C,R,R3,F)
    <=> ( bij_betw(B,C,F,field2(B,R),field2(C,R3))
        & ! [X4: B] :
            ( member(B,X4,field2(B,R))
           => ! [Xa2: B] :
                ( member(B,Xa2,field2(B,R))
               => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R)
                <=> member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,F,X4)),aa(B,C,F,Xa2)),R3) ) ) ) ) ) ).

% iso_iff2
tff(fact_5078_iso__backward,axiom,
    ! [B: $tType,C: $tType,X2: B,Y: B,R3: set(product_prod(B,B)),R: set(product_prod(C,C)),F: fun(C,B)] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R3)
     => ( bNF_Wellorder_iso(C,B,R,R3,F)
       => member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,hilbert_inv_into(C,B,field2(C,R),F),X2)),aa(B,C,hilbert_inv_into(C,B,field2(C,R),F),Y)),R) ) ) ).

% iso_backward
tff(fact_5079_lists__of__len__fin1,axiom,
    ! [B: $tType,P: set(B),N: nat] :
      ( finite_finite2(B,P)
     => finite_finite2(list(B),aa(set(list(B)),set(list(B)),inf_inf(set(list(B)),lists(B,P)),aa(fun(list(B),$o),set(list(B)),collect(list(B)),aTP_Lamp_ug(nat,fun(list(B),$o),N)))) ) ).

% lists_of_len_fin1
tff(fact_5080_lists__of__len__fin2,axiom,
    ! [B: $tType,P: set(B),N: nat] :
      ( finite_finite2(B,P)
     => finite_finite2(list(B),aa(set(list(B)),set(list(B)),inf_inf(set(list(B)),lists(B,P)),aa(fun(list(B),$o),set(list(B)),collect(list(B)),aTP_Lamp_uh(nat,fun(list(B),$o),N)))) ) ).

% lists_of_len_fin2
tff(fact_5081_Random__Pred_Ounion__def,axiom,
    ! [B: $tType,R12: fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),R23: fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),X: product_prod(code_natural,code_natural)] : random_union(B,R12,R23,X) = aa(product_prod(pred(B),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(fun(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(product_prod(pred(B),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural))),product_case_prod(pred(B),product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aTP_Lamp_uj(fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),fun(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),R23)),aa(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)),R12,X)) ).

% Random_Pred.union_def
tff(fact_5082_lists__image__witness,axiom,
    ! [B: $tType,C: $tType,X2: list(B),F: fun(C,B),Q: set(C)] :
      ( member(list(B),X2,lists(B,aa(set(C),set(B),image2(C,B,F),Q)))
     => ~ ! [Xo2: list(C)] :
            ( member(list(C),Xo2,lists(C,Q))
           => ( X2 != aa(list(C),list(B),map(C,B,F),Xo2) ) ) ) ).

% lists_image_witness
tff(fact_5083_Random__Pred_Oempty__def,axiom,
    ! [B: $tType] : random_empty(B) = aa(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),product_Pair(pred(B),product_prod(code_natural,code_natural)),bot_bot(pred(B))) ).

% Random_Pred.empty_def
tff(fact_5084_Random__Pred_Obind__def,axiom,
    ! [B: $tType,C: $tType,R4: fun(product_prod(code_natural,code_natural),product_prod(pred(C),product_prod(code_natural,code_natural))),F: fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),X: product_prod(code_natural,code_natural)] : random_bind(C,B,R4,F,X) = aa(product_prod(pred(C),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(fun(pred(C),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(product_prod(pred(C),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural))),product_case_prod(pred(C),product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aTP_Lamp_um(fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(pred(C),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),F)),aa(product_prod(code_natural,code_natural),product_prod(pred(C),product_prod(code_natural,code_natural)),R4,X)) ).

% Random_Pred.bind_def
tff(fact_5085_card__Plus__conv__if,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      finite_card(sum_sum(B,C),sum_Plus(B,C,A4,B5)) = $ite(
        ( finite_finite2(B,A4)
        & finite_finite2(C,B5) ),
        aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,A4)),finite_card(C,B5)),
        zero_zero(nat) ) ).

% card_Plus_conv_if
tff(fact_5086_card__Plus,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( finite_finite2(B,A4)
     => ( finite_finite2(C,B5)
       => ( finite_card(sum_sum(B,C),sum_Plus(B,C,A4,B5)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(B,A4)),finite_card(C,B5)) ) ) ) ).

% card_Plus
tff(fact_5087_option_Orel__compp__Grp,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(C,$o))] : aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4) = relcompp(option(B),option(product_prod(B,C)),option(C),conversep(option(product_prod(B,C)),option(B),bNF_Grp(option(product_prod(B,C)),option(B),aa(fun(option(product_prod(B,C)),$o),set(option(product_prod(B,C))),collect(option(product_prod(B,C))),aTP_Lamp_tv(fun(B,fun(C,$o)),fun(option(product_prod(B,C)),$o),R4)),aa(fun(product_prod(B,C),B),fun(option(product_prod(B,C)),option(B)),map_option(product_prod(B,C),B),product_fst(B,C)))),bNF_Grp(option(product_prod(B,C)),option(C),aa(fun(option(product_prod(B,C)),$o),set(option(product_prod(B,C))),collect(option(product_prod(B,C))),aTP_Lamp_tv(fun(B,fun(C,$o)),fun(option(product_prod(B,C)),$o),R4)),aa(fun(product_prod(B,C),C),fun(option(product_prod(B,C)),option(C)),map_option(product_prod(B,C),C),product_snd(B,C)))) ).

% option.rel_compp_Grp
tff(fact_5088_mult__one__div__unit__factor,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B,B2: B] : aa(B,B,aa(B,fun(B,B),times_times(B),A3),aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),unit_f5069060285200089521factor(B,B2))) = aa(B,B,aa(B,fun(B,B),divide_divide(B),A3),unit_f5069060285200089521factor(B,B2)) ) ).

% mult_one_div_unit_factor
tff(fact_5089_unit__factor__mult__unit__left,axiom,
    ! [B: $tType] :
      ( semido2269285787275462019factor(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( unit_f5069060285200089521factor(B,aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,B,aa(B,fun(B,B),times_times(B),A3),unit_f5069060285200089521factor(B,B2)) ) ) ) ).

% unit_factor_mult_unit_left
tff(fact_5090_unit__factor__simps_I2_J,axiom,
    ! [N: nat] : unit_f5069060285200089521factor(nat,aa(nat,nat,suc,N)) = one_one(nat) ).

% unit_factor_simps(2)
tff(fact_5091_unit__factor__1,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ( unit_f5069060285200089521factor(B,one_one(B)) = one_one(B) ) ) ).

% unit_factor_1
tff(fact_5092_inv__unit__factor__eq__0__iff,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] :
          ( ( aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),unit_f5069060285200089521factor(B,A3)) = zero_zero(B) )
        <=> ( A3 = zero_zero(B) ) ) ) ).

% inv_unit_factor_eq_0_iff
tff(fact_5093_unit__factor__mult__unit__right,axiom,
    ! [B: $tType] :
      ( semido2269285787275462019factor(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( unit_f5069060285200089521factor(B,aa(B,B,aa(B,fun(B,B),times_times(B),B2),A3)) = aa(B,B,aa(B,fun(B,B),times_times(B),unit_f5069060285200089521factor(B,B2)),A3) ) ) ) ).

% unit_factor_mult_unit_right
tff(fact_5094_option_Orel__compp,axiom,
    ! [B: $tType,C: $tType,D: $tType,R4: fun(B,fun(D,$o)),S2: fun(D,fun(C,$o))] : aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),relcompp(B,D,C,R4,S2)) = relcompp(option(B),option(D),option(C),aa(fun(B,fun(D,$o)),fun(option(B),fun(option(D),$o)),rel_option(B,D),R4),aa(fun(D,fun(C,$o)),fun(option(D),fun(option(C),$o)),rel_option(D,C),S2)) ).

% option.rel_compp
tff(fact_5095_OOO__quotient3,axiom,
    ! [B: $tType,C: $tType,D: $tType,R12: fun(B,fun(B,$o)),Abs1: fun(B,C),Rep1: fun(C,B),R23: fun(C,fun(C,$o)),Abs22: fun(C,D),Rep22: fun(D,C),R24: fun(B,fun(B,$o))] :
      ( quotient3(B,C,R12,Abs1,Rep1)
     => ( quotient3(C,D,R23,Abs22,Rep22)
       => ( ! [X3: B,Y4: B] :
              ( aa(B,$o,aa(B,fun(B,$o),R24,X3),Y4)
             => ( aa(B,$o,aa(B,fun(B,$o),R12,X3),X3)
               => ( aa(B,$o,aa(B,fun(B,$o),R12,Y4),Y4)
                 => aa(C,$o,aa(C,fun(C,$o),R23,aa(B,C,Abs1,X3)),aa(B,C,Abs1,Y4)) ) ) )
         => ( ! [X3: C,Y4: C] :
                ( aa(C,$o,aa(C,fun(C,$o),R23,X3),Y4)
               => aa(B,$o,aa(B,fun(B,$o),R24,aa(C,B,Rep1,X3)),aa(C,B,Rep1,Y4)) )
           => quotient3(B,D,relcompp(B,B,B,R12,relcompp(B,B,B,R24,R12)),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),Abs22),Abs1),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Rep1),Rep22)) ) ) ) ) ).

% OOO_quotient3
tff(fact_5096_OOO__eq__quotient3,axiom,
    ! [B: $tType,C: $tType,D: $tType,R12: fun(B,fun(B,$o)),Abs1: fun(B,C),Rep1: fun(C,B),Abs22: fun(C,D),Rep22: fun(D,C)] :
      ( quotient3(B,C,R12,Abs1,Rep1)
     => ( quotient3(C,D,fequal(C),Abs22,Rep22)
       => quotient3(B,D,relcompp(B,B,B,R12,relcompp(B,B,B,fequal(B),R12)),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),Abs22),Abs1),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Rep1),Rep22)) ) ) ).

% OOO_eq_quotient3
tff(fact_5097_relpowp__add,axiom,
    ! [B: $tType,M: nat,N: nat,P: fun(B,fun(B,$o))] : compow(fun(B,fun(B,$o)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),P) = relcompp(B,B,B,compow(fun(B,fun(B,$o)),M,P),compow(fun(B,fun(B,$o)),N,P)) ).

% relpowp_add
tff(fact_5098_relcompp__relcomp__eq,axiom,
    ! [B: $tType,C: $tType,D: $tType,R: set(product_prod(B,D)),S: set(product_prod(D,C)),X: B,Xa3: C] :
      ( aa(C,$o,aa(B,fun(C,$o),relcompp(B,D,C,aTP_Lamp_un(set(product_prod(B,D)),fun(B,fun(D,$o)),R),aTP_Lamp_uo(set(product_prod(D,C)),fun(D,fun(C,$o)),S)),X),Xa3)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X),Xa3),relcomp(B,D,C,R,S)) ) ).

% relcompp_relcomp_eq
tff(fact_5099_is__unit__unit__factor,axiom,
    ! [B: $tType] :
      ( semido2269285787275462019factor(B)
     => ! [A3: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( unit_f5069060285200089521factor(B,A3) = A3 ) ) ) ).

% is_unit_unit_factor
tff(fact_5100_unit__factor__nat__def,axiom,
    ! [N: nat] :
      unit_f5069060285200089521factor(nat,N) = $ite(N = zero_zero(nat),zero_zero(nat),one_one(nat)) ).

% unit_factor_nat_def
tff(fact_5101_option_Orel__Grp,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,C)] : aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),bNF_Grp(B,C,A4,F)) = bNF_Grp(option(B),option(C),aa(fun(option(B),$o),set(option(B)),collect(option(B)),aTP_Lamp_up(set(B),fun(option(B),$o),A4)),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F)) ).

% option.rel_Grp
tff(fact_5102_fun_Orel__Grp,axiom,
    ! [B: $tType,D: $tType,C: $tType,A4: set(C),F: fun(C,D)] : bNF_rel_fun(B,B,C,D,fequal(B),bNF_Grp(C,D,A4,F)) = bNF_Grp(fun(B,C),fun(B,D),aa(fun(fun(B,C),$o),set(fun(B,C)),collect(fun(B,C)),aTP_Lamp_uq(set(C),fun(fun(B,C),$o),A4)),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F)) ).

% fun.rel_Grp
tff(fact_5103_relcomp__def,axiom,
    ! [B: $tType,D: $tType,C: $tType,X: set(product_prod(B,C)),Xa3: set(product_prod(C,D))] : relcomp(B,C,D,X,Xa3) = aa(fun(product_prod(B,D),$o),set(product_prod(B,D)),collect(product_prod(B,D)),aa(fun(B,fun(D,$o)),fun(product_prod(B,D),$o),product_case_prod(B,D,$o),relcompp(B,C,D,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),X),aTP_Lamp_ur(set(product_prod(C,D)),fun(C,fun(D,$o)),Xa3)))) ).

% relcomp_def
tff(fact_5104_unit__factor__is__unit,axiom,
    ! [B: $tType] :
      ( semido2269285787275462019factor(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => dvd_dvd(B,unit_f5069060285200089521factor(B,A3),one_one(B)) ) ) ).

% unit_factor_is_unit
tff(fact_5105_unit__factor__gcd,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          unit_f5069060285200089521factor(B,aa(B,B,aa(B,fun(B,B),gcd_gcd(B),A3),B2)) = $ite(
            ( ( A3 = zero_zero(B) )
            & ( B2 = zero_zero(B) ) ),
            zero_zero(B),
            one_one(B) ) ) ).

% unit_factor_gcd
tff(fact_5106_type__copy__vimage2p__Grp__Abs,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,Rep: fun(B,C),Abs: fun(C,B),G: fun(D,E),P: fun(E,$o),Ha: fun(E,B)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( aa(fun(E,fun(B,$o)),fun(D,fun(C,$o)),bNF_vimage2p(D,E,C,B,$o,G,Abs),bNF_Grp(E,B,aa(fun(E,$o),set(E),collect(E),P),Ha)) = bNF_Grp(D,C,aa(fun(D,$o),set(D),collect(D),aa(fun(E,$o),fun(D,$o),aTP_Lamp_us(fun(D,E),fun(fun(E,$o),fun(D,$o)),G),P)),aa(fun(D,E),fun(D,C),aa(fun(E,C),fun(fun(D,E),fun(D,C)),comp(E,C,D),aa(fun(E,B),fun(E,C),aa(fun(B,C),fun(fun(E,B),fun(E,C)),comp(B,C,E),Rep),Ha)),G)) ) ) ).

% type_copy_vimage2p_Grp_Abs
tff(fact_5107_type__copy__vimage2p__Grp__Rep,axiom,
    ! [C: $tType,B: $tType,E: $tType,D: $tType,Rep: fun(B,C),Abs: fun(C,B),F: fun(D,E),P: fun(E,$o),Ha: fun(E,C)] :
      ( type_definition(B,C,Rep,Abs,top_top(set(C)))
     => ( aa(fun(E,fun(C,$o)),fun(D,fun(B,$o)),bNF_vimage2p(D,E,B,C,$o,F,Rep),bNF_Grp(E,C,aa(fun(E,$o),set(E),collect(E),P),Ha)) = bNF_Grp(D,B,aa(fun(D,$o),set(D),collect(D),aa(fun(E,$o),fun(D,$o),aTP_Lamp_us(fun(D,E),fun(fun(E,$o),fun(D,$o)),F),P)),aa(fun(D,E),fun(D,B),aa(fun(E,B),fun(fun(D,E),fun(D,B)),comp(E,B,D),aa(fun(E,C),fun(E,B),aa(fun(C,B),fun(fun(E,C),fun(E,B)),comp(C,B,E),Abs),Ha)),F)) ) ) ).

% type_copy_vimage2p_Grp_Rep
tff(fact_5108_Nat_Otransfer,axiom,
    aa(fun(code_integer,code_natural),$o,aa(fun(int,nat),fun(fun(code_integer,code_natural),$o),bNF_rel_fun(int,code_integer,nat,code_natural,code_pcr_integer,code_pcr_natural),nat2),code_Nat) ).

% Nat.transfer
tff(fact_5109_pcr__natural__def,axiom,
    code_pcr_natural = relcompp(nat,nat,code_natural,fequal(nat),code_cr_natural) ).

% pcr_natural_def
tff(fact_5110_natural_Orep__transfer,axiom,
    aa(fun(code_natural,nat),$o,aa(fun(nat,nat),fun(fun(code_natural,nat),$o),bNF_rel_fun(nat,code_natural,nat,nat,code_pcr_natural,fequal(nat)),aTP_Lamp_bz(nat,nat)),code_nat_of_natural) ).

% natural.rep_transfer
tff(fact_5111_natural_Oid__abs__transfer,axiom,
    aa(fun(nat,code_natural),$o,aa(fun(nat,nat),fun(fun(nat,code_natural),$o),bNF_rel_fun(nat,nat,nat,code_natural,fequal(nat),code_pcr_natural),aTP_Lamp_bz(nat,nat)),code_natural_of_nat) ).

% natural.id_abs_transfer
tff(fact_5112_natural_Opcr__cr__eq,axiom,
    code_pcr_natural = code_cr_natural ).

% natural.pcr_cr_eq
tff(fact_5113_zero__natural_Otransfer,axiom,
    aa(code_natural,$o,aa(nat,fun(code_natural,$o),code_pcr_natural,zero_zero(nat)),zero_zero(code_natural)) ).

% zero_natural.transfer
tff(fact_5114_one__natural_Otransfer,axiom,
    aa(code_natural,$o,aa(nat,fun(code_natural,$o),code_pcr_natural,one_one(nat)),one_one(code_natural)) ).

% one_natural.transfer
tff(fact_5115_less__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,$o)),$o,aa(fun(nat,fun(nat,$o)),fun(fun(code_natural,fun(code_natural,$o)),$o),bNF_rel_fun(nat,code_natural,fun(nat,$o),fun(code_natural,$o),code_pcr_natural,bNF_rel_fun(nat,code_natural,$o,$o,code_pcr_natural,fequal($o))),ord_less(nat)),ord_less(code_natural)) ).

% less_natural.transfer
tff(fact_5116_vimage2p__comp,axiom,
    ! [F4: $tType,E: $tType,G2: $tType,B: $tType,D: $tType,C: $tType,H5: $tType,F1: fun(G2,B),F22: fun(E,G2),G1: fun(H5,C),G22: fun(F4,H5)] : bNF_vimage2p(E,B,F4,C,D,aa(fun(E,G2),fun(E,B),aa(fun(G2,B),fun(fun(E,G2),fun(E,B)),comp(G2,B,E),F1),F22),aa(fun(F4,H5),fun(F4,C),aa(fun(H5,C),fun(fun(F4,H5),fun(F4,C)),comp(H5,C,F4),G1),G22)) = aa(fun(fun(B,fun(C,D)),fun(G2,fun(H5,D))),fun(fun(B,fun(C,D)),fun(E,fun(F4,D))),aa(fun(fun(G2,fun(H5,D)),fun(E,fun(F4,D))),fun(fun(fun(B,fun(C,D)),fun(G2,fun(H5,D))),fun(fun(B,fun(C,D)),fun(E,fun(F4,D)))),comp(fun(G2,fun(H5,D)),fun(E,fun(F4,D)),fun(B,fun(C,D))),bNF_vimage2p(E,G2,F4,H5,D,F22,G22)),bNF_vimage2p(G2,B,H5,C,D,F1,G1)) ).

% vimage2p_comp
tff(fact_5117_plus__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),plus_plus(nat)),plus_plus(code_natural)) ).

% plus_natural.transfer
tff(fact_5118_Suc_Otransfer,axiom,
    aa(fun(code_natural,code_natural),$o,aa(fun(nat,nat),fun(fun(code_natural,code_natural),$o),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural),suc),code_Suc) ).

% Suc.transfer
tff(fact_5119_minus__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),minus_minus(nat)),minus_minus(code_natural)) ).

% minus_natural.transfer
tff(fact_5120_pcr__integer__def,axiom,
    code_pcr_integer = relcompp(int,int,code_integer,fequal(int),code_cr_integer) ).

% pcr_integer_def
tff(fact_5121_less__eq__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,$o)),$o,aa(fun(nat,fun(nat,$o)),fun(fun(code_natural,fun(code_natural,$o)),$o),bNF_rel_fun(nat,code_natural,fun(nat,$o),fun(code_natural,$o),code_pcr_natural,bNF_rel_fun(nat,code_natural,$o,$o,code_pcr_natural,fequal($o))),ord_less_eq(nat)),ord_less_eq(code_natural)) ).

% less_eq_natural.transfer
tff(fact_5122_times__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),times_times(nat)),times_times(code_natural)) ).

% times_natural.transfer
tff(fact_5123_divide__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),divide_divide(nat)),divide_divide(code_natural)) ).

% divide_natural.transfer
tff(fact_5124_modulo__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),modulo_modulo(nat)),modulo_modulo(code_natural)) ).

% modulo_natural.transfer
tff(fact_5125_take__bit__natural_Otransfer,axiom,
    aa(fun(nat,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),fequal(nat),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se2584673776208193580ke_bit(nat)),bit_se2584673776208193580ke_bit(code_natural)) ).

% take_bit_natural.transfer
tff(fact_5126_xor__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se5824344971392196577ns_xor(nat)),bit_se5824344971392196577ns_xor(code_natural)) ).

% xor_natural.transfer
tff(fact_5127_or__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se1065995026697491101ons_or(nat)),bit_se1065995026697491101ons_or(code_natural)) ).

% or_natural.transfer
tff(fact_5128_and__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(code_natural,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,code_natural,fun(nat,nat),fun(code_natural,code_natural),code_pcr_natural,bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se5824344872417868541ns_and(nat)),bit_se5824344872417868541ns_and(code_natural)) ).

% and_natural.transfer
tff(fact_5129_bit__natural_Otransfer,axiom,
    aa(fun(code_natural,fun(nat,$o)),$o,aa(fun(nat,fun(nat,$o)),fun(fun(code_natural,fun(nat,$o)),$o),bNF_rel_fun(nat,code_natural,fun(nat,$o),fun(nat,$o),code_pcr_natural,fequal(fun(nat,$o))),bit_se5641148757651400278ts_bit(nat)),bit_se5641148757651400278ts_bit(code_natural)) ).

% bit_natural.transfer
tff(fact_5130_push__bit__natural_Otransfer,axiom,
    aa(fun(nat,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),fequal(nat),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se4730199178511100633sh_bit(nat)),bit_se4730199178511100633sh_bit(code_natural)) ).

% push_bit_natural.transfer
tff(fact_5131_mask__natural_Otransfer,axiom,
    aa(fun(nat,code_natural),$o,aa(fun(nat,nat),fun(fun(nat,code_natural),$o),bNF_rel_fun(nat,nat,nat,code_natural,fequal(nat),code_pcr_natural),bit_se2239418461657761734s_mask(nat)),bit_se2239418461657761734s_mask(code_natural)) ).

% mask_natural.transfer
tff(fact_5132_drop__bit__natural_Otransfer,axiom,
    aa(fun(nat,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),fequal(nat),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se4197421643247451524op_bit(nat)),bit_se4197421643247451524op_bit(code_natural)) ).

% drop_bit_natural.transfer
tff(fact_5133_division__segment__natural_Otransfer,axiom,
    aa(fun(code_natural,code_natural),$o,aa(fun(nat,nat),fun(fun(code_natural,code_natural),$o),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural),euclid7384307370059645450egment(nat)),euclid7384307370059645450egment(code_natural)) ).

% division_segment_natural.transfer
tff(fact_5134_flip__bit__natural_Otransfer,axiom,
    aa(fun(nat,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),fequal(nat),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se8732182000553998342ip_bit(nat)),bit_se8732182000553998342ip_bit(code_natural)) ).

% flip_bit_natural.transfer
tff(fact_5135_set__bit__natural_Otransfer,axiom,
    aa(fun(nat,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),fequal(nat),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se5668285175392031749et_bit(nat)),bit_se5668285175392031749et_bit(code_natural)) ).

% set_bit_natural.transfer
tff(fact_5136_unset__bit__natural_Otransfer,axiom,
    aa(fun(nat,fun(code_natural,code_natural)),$o,aa(fun(nat,fun(nat,nat)),fun(fun(nat,fun(code_natural,code_natural)),$o),bNF_rel_fun(nat,nat,fun(nat,nat),fun(code_natural,code_natural),fequal(nat),bNF_rel_fun(nat,code_natural,nat,code_natural,code_pcr_natural,code_pcr_natural)),bit_se2638667681897837118et_bit(nat)),bit_se2638667681897837118et_bit(code_natural)) ).

% unset_bit_natural.transfer
tff(fact_5137_euclidean__size__natural_Otransfer,axiom,
    aa(fun(code_natural,nat),$o,aa(fun(nat,nat),fun(fun(code_natural,nat),$o),bNF_rel_fun(nat,code_natural,nat,nat,code_pcr_natural,fequal(nat)),euclid6346220572633701492n_size(nat)),euclid6346220572633701492n_size(code_natural)) ).

% euclidean_size_natural.transfer
tff(fact_5138_integer__of__natural_Otransfer,axiom,
    aa(fun(code_natural,code_integer),$o,aa(fun(nat,int),fun(fun(code_natural,code_integer),$o),bNF_rel_fun(nat,code_natural,int,code_integer,code_pcr_natural,code_pcr_integer),semiring_1_of_nat(int)),code_i5400310926305786745atural) ).

% integer_of_natural.transfer
tff(fact_5139_natural__of__integer_Otransfer,axiom,
    aa(fun(code_integer,code_natural),$o,aa(fun(int,nat),fun(fun(code_integer,code_natural),$o),bNF_rel_fun(int,code_integer,nat,code_natural,code_pcr_integer,code_pcr_natural),nat2),code_n4118661773612635043nteger) ).

% natural_of_integer.transfer
tff(fact_5140_fun_Orel__compp__Grp,axiom,
    ! [B: $tType,D: $tType,C: $tType,R4: fun(C,fun(D,$o))] : bNF_rel_fun(B,B,C,D,fequal(B),R4) = relcompp(fun(B,C),fun(B,product_prod(C,D)),fun(B,D),conversep(fun(B,product_prod(C,D)),fun(B,C),bNF_Grp(fun(B,product_prod(C,D)),fun(B,C),aa(fun(fun(B,product_prod(C,D)),$o),set(fun(B,product_prod(C,D))),collect(fun(B,product_prod(C,D))),aTP_Lamp_ji(fun(C,fun(D,$o)),fun(fun(B,product_prod(C,D)),$o),R4)),aa(fun(product_prod(C,D),C),fun(fun(B,product_prod(C,D)),fun(B,C)),comp(product_prod(C,D),C,B),product_fst(C,D)))),bNF_Grp(fun(B,product_prod(C,D)),fun(B,D),aa(fun(fun(B,product_prod(C,D)),$o),set(fun(B,product_prod(C,D))),collect(fun(B,product_prod(C,D))),aTP_Lamp_ji(fun(C,fun(D,$o)),fun(fun(B,product_prod(C,D)),$o),R4)),aa(fun(product_prod(C,D),D),fun(fun(B,product_prod(C,D)),fun(B,D)),comp(product_prod(C,D),D,B),product_snd(C,D)))) ).

% fun.rel_compp_Grp
tff(fact_5141_plus__num__def,axiom,
    ! [M: num,N: num] : aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N) = aa(nat,num,num_of_nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_of_num(M)),nat_of_num(N))) ).

% plus_num_def
tff(fact_5142_Lcm__no__units,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [A4: set(B)] : gcd_Lcm(B,A4) = gcd_Lcm(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),A4),aa(fun(B,$o),set(B),collect(B),aTP_Lamp_ut(B,$o)))) ) ).

% Lcm_no_units
tff(fact_5143_remdups__adj__altdef,axiom,
    ! [B: $tType,Xsa: list(B),Ys: list(B)] :
      ( ( remdups_adj(B,Xsa) = 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(B),nat,size_size(list(B)),Xsa))) = set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(list(B),nat,size_size(list(B)),Ys)) )
          & ! [I3: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),Xsa))
             => ( aa(nat,B,nth(B,Xsa),I3) = aa(nat,B,nth(B,Ys),aa(nat,nat,F6,I3)) ) )
          & ! [I3: nat] :
              ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I3),one_one(nat))),aa(list(B),nat,size_size(list(B)),Xsa))
             => ( ( aa(nat,B,nth(B,Xsa),I3) = aa(nat,B,nth(B,Xsa),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I3),one_one(nat))) )
              <=> ( aa(nat,nat,F6,I3) = aa(nat,nat,F6,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),I3),one_one(nat))) ) ) ) ) ) ).

% remdups_adj_altdef
tff(fact_5144_Lcm__empty,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ( gcd_Lcm(B,bot_bot(set(B))) = one_one(B) ) ) ).

% Lcm_empty
tff(fact_5145_Lcm__1__iff,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [A4: set(B)] :
          ( ( gcd_Lcm(B,A4) = one_one(B) )
        <=> ! [X4: B] :
              ( member(B,X4,A4)
             => dvd_dvd(B,X4,one_one(B)) ) ) ) ).

% Lcm_1_iff
tff(fact_5146_mono__add,axiom,
    ! [B: $tType] :
      ( ordere6658533253407199908up_add(B)
     => ! [A3: B] : order_mono(B,B,aa(B,fun(B,B),plus_plus(B),A3)) ) ).

% mono_add
tff(fact_5147_Lcm__nat__empty,axiom,
    gcd_Lcm(nat,bot_bot(set(nat))) = one_one(nat) ).

% Lcm_nat_empty
tff(fact_5148_nat__of__num_Osimps_I2_J,axiom,
    ! [X2: num] : nat_of_num(aa(num,num,bit0,X2)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_of_num(X2)),nat_of_num(X2)) ).

% nat_of_num.simps(2)
tff(fact_5149_nat__of__num__code_I1_J,axiom,
    nat_of_num(one2) = one_one(nat) ).

% nat_of_num_code(1)
tff(fact_5150_nat__of__num__add,axiom,
    ! [X2: num,Y: num] : nat_of_num(aa(num,num,aa(num,fun(num,num),plus_plus(num),X2),Y)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_of_num(X2)),nat_of_num(Y)) ).

% nat_of_num_add
tff(fact_5151_nat__of__num__code_I2_J,axiom,
    ! [N: num] :
      nat_of_num(aa(num,num,bit0,N)) = $let(
        m: nat,
        m:= nat_of_num(N),
        aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),m),m) ) ).

% nat_of_num_code(2)
tff(fact_5152_mono__image__least,axiom,
    ! [B: $tType,C: $tType] :
      ( ( order(C)
        & order(B) )
     => ! [F: fun(B,C),M: B,N: B,M7: C,N2: C] :
          ( order_mono(B,C,F)
         => ( ( aa(set(B),set(C),image2(B,C,F),set_or7035219750837199246ssThan(B,M,N)) = set_or7035219750837199246ssThan(C,M7,N2) )
           => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),N)
             => ( aa(B,C,F,M) = M7 ) ) ) ) ) ).

% mono_image_least
tff(fact_5153_nat__of__num_Osimps_I3_J,axiom,
    ! [X2: num] : nat_of_num(aa(num,num,bit1,X2)) = aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_of_num(X2)),nat_of_num(X2))) ).

% nat_of_num.simps(3)
tff(fact_5154_unit__factor__Lcm,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [A4: set(B)] :
          unit_f5069060285200089521factor(B,gcd_Lcm(B,A4)) = $ite(gcd_Lcm(B,A4) = zero_zero(B),zero_zero(B),one_one(B)) ) ).

% unit_factor_Lcm
tff(fact_5155_nat__of__num__code_I3_J,axiom,
    ! [N: num] :
      nat_of_num(aa(num,num,bit1,N)) = $let(
        m: nat,
        m:= nat_of_num(N),
        aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),m),m)) ) ).

% nat_of_num_code(3)
tff(fact_5156_remdups__adj_Opelims,axiom,
    ! [B: $tType,X2: list(B),Y: list(B)] :
      ( ( remdups_adj(B,X2) = Y )
     => ( aa(list(B),$o,accp(list(B),remdups_adj_rel(B)),X2)
       => ( ( ( X2 = nil(B) )
           => ( ( Y = nil(B) )
             => ~ aa(list(B),$o,accp(list(B),remdups_adj_rel(B)),nil(B)) ) )
         => ( ! [X3: B] :
                ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
               => ( ( Y = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
                 => ~ aa(list(B),$o,accp(list(B),remdups_adj_rel(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B))) ) )
           => ~ ! [X3: B,Y4: B,Xs: list(B)] :
                  ( ( X2 = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) )
                 => ( ( Y = $ite(X3 = Y4,remdups_adj(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),Xs)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),remdups_adj(B,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)))) )
                   => ~ aa(list(B),$o,accp(list(B),remdups_adj_rel(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs))) ) ) ) ) ) ) ).

% remdups_adj.pelims
tff(fact_5157_relChain__def,axiom,
    ! [C: $tType,B: $tType] :
      ( ord(C)
     => ! [R: set(product_prod(B,B)),As3: fun(B,C)] :
          ( bNF_Ca3754400796208372196lChain(B,C,R,As3)
        <=> ! [I3: B,J2: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),I3),J2),R)
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,As3,I3)),aa(B,C,As3,J2)) ) ) ) ).

% relChain_def
tff(fact_5158_unit__factor__Gcd,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [A4: set(B)] :
          unit_f5069060285200089521factor(B,gcd_Gcd(B,A4)) = $ite(gcd_Gcd(B,A4) = zero_zero(B),zero_zero(B),one_one(B)) ) ).

% unit_factor_Gcd
tff(fact_5159_Gcd__UNIV,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ( gcd_Gcd(B,top_top(set(B))) = one_one(B) ) ) ).

% Gcd_UNIV
tff(fact_5160_Gcd__1,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [A4: set(B)] :
          ( member(B,one_one(B),A4)
         => ( gcd_Gcd(B,A4) = one_one(B) ) ) ) ).

% Gcd_1
tff(fact_5161_Gcd__nat__eq__one,axiom,
    ! [N5: set(nat)] :
      ( member(nat,one_one(nat),N5)
     => ( gcd_Gcd(nat,N5) = one_one(nat) ) ) ).

% Gcd_nat_eq_one
tff(fact_5162_Gcd__eq__1__I,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [A3: B,A4: set(B)] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( member(B,A3,A4)
           => ( gcd_Gcd(B,A4) = one_one(B) ) ) ) ) ).

% Gcd_eq_1_I
tff(fact_5163_cofinal__def,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( bNF_Ca7293521722713021262ofinal(B,A4,R)
    <=> ! [X4: B] :
          ( member(B,X4,field2(B,R))
         => ? [Xa2: B] :
              ( member(B,Xa2,A4)
              & ( X4 != Xa2 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),R) ) ) ) ).

% cofinal_def
tff(fact_5164_card__of__UNION__ordLeq__infinite,axiom,
    ! [C: $tType,B: $tType,D: $tType,B5: set(B),I4: set(C),A4: fun(C,set(D))] :
      ( ~ finite_finite2(B,B5)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,I4)),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(C,B))
       => ( ! [X3: C] :
              ( member(C,X3,I4)
             => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),A4,X3))),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(D,B)) )
         => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I4)))),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(D,B)) ) ) ) ).

% card_of_UNION_ordLeq_infinite
tff(fact_5165_card__of__ordLess,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ~ ? [F6: fun(B,C)] :
            ( inj_on(B,C,F6,A4)
            & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),image2(B,C,F6),A4)),B5) )
    <=> member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_We4044943003108391690rdLess(C,B)) ) ).

% card_of_ordLess
tff(fact_5166_card__of__Times3,axiom,
    ! [B: $tType,A4: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,B),product_prod(B,B)))),aa(set(product_prod(product_prod(B,B),product_prod(B,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,B),product_prod(B,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(product_prod(B,B),product_prod(B,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,B),product_prod(B,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(product_prod(B,B),product_prod(B,B)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(product_prod(B,B),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))),bNF_Wellorder_ordLeq(B,product_prod(B,B))) ).

% card_of_Times3
tff(fact_5167_card__of__Sigma__mono1,axiom,
    ! [D: $tType,C: $tType,B: $tType,I4: set(B),A4: fun(B,set(C)),B5: fun(B,set(D))] :
      ( ! [X3: B] :
          ( member(B,X3,I4)
         => member(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,aa(B,set(C),A4,X3))),bNF_Ca6860139660246222851ard_of(D,aa(B,set(D),B5,X3))),bNF_Wellorder_ordLeq(C,D)) )
     => member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(product_prod(B,D),product_prod(B,D))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D))))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D)))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,I4,A4))),bNF_Ca6860139660246222851ard_of(product_prod(B,D),product_Sigma(B,D,I4,B5))),bNF_Wellorder_ordLeq(product_prod(B,C),product_prod(B,D))) ) ).

% card_of_Sigma_mono1
tff(fact_5168_card__of__Times__mono1,axiom,
    ! [C: $tType,D: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,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(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Ca6860139660246222851ard_of(product_prod(B,D),product_Sigma(B,D,A4,aTP_Lamp_to(set(D),fun(B,set(D)),C5)))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,B5,aTP_Lamp_mz(set(D),fun(C,set(D)),C5)))),bNF_Wellorder_ordLeq(product_prod(B,D),product_prod(C,D))) ) ).

% card_of_Times_mono1
tff(fact_5169_card__of__Times__mono2,axiom,
    ! [C: $tType,B: $tType,D: $tType,A4: set(B),B5: set(C),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),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(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,B),product_prod(D,B))),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),bNF_Ca6860139660246222851ard_of(product_prod(D,B),product_Sigma(D,B,C5,aTP_Lamp_uu(set(B),fun(D,set(B)),A4)))),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,C5,aTP_Lamp_uv(set(C),fun(D,set(C)),B5)))),bNF_Wellorder_ordLeq(product_prod(D,B),product_prod(D,C))) ) ).

% card_of_Times_mono2
tff(fact_5170_infinite__iff__card__of__nat,axiom,
    ! [B: $tType,A4: set(B)] :
      ( ~ finite_finite2(B,A4)
    <=> member(product_prod(set(product_prod(nat,nat)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(nat,nat)),set(product_prod(B,B))),aa(set(product_prod(nat,nat)),fun(set(product_prod(B,B)),product_prod(set(product_prod(nat,nat)),set(product_prod(B,B)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(nat,top_top(set(nat)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(nat,B)) ) ).

% infinite_iff_card_of_nat
tff(fact_5171_card__of__UNION__Sigma,axiom,
    ! [C: $tType,B: $tType,A4: fun(C,set(B)),I4: set(C)] : member(product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),bNF_Ca6860139660246222851ard_of(B,aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(C),set(set(B)),image2(C,set(B),A4),I4)))),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,I4,A4))),bNF_Wellorder_ordLeq(B,product_prod(C,B))) ).

% card_of_UNION_Sigma
tff(fact_5172_card__of__Times__commute,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] : member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B)))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),A4)))),bNF_Wellorder_ordIso(product_prod(B,C),product_prod(C,B))) ).

% card_of_Times_commute
tff(fact_5173_card__of__Times__same__infinite,axiom,
    ! [B: $tType,A4: set(B)] :
      ( ~ finite_finite2(B,A4)
     => member(product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,B),product_prod(B,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(B,B),product_Sigma(B,B,A4,aTP_Lamp_ma(set(B),fun(B,set(B)),A4)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(product_prod(B,B),B)) ) ).

% card_of_Times_same_infinite
tff(fact_5174_card__of__Times1,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ( A4 != bot_bot(set(B)) )
     => member(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(C,B),product_prod(C,B)))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),A4)))),bNF_Wellorder_ordLeq(C,product_prod(C,B))) ) ).

% card_of_Times1
tff(fact_5175_card__of__Times2,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ( A4 != bot_bot(set(B)) )
     => member(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C)))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Wellorder_ordLeq(C,product_prod(B,C))) ) ).

% card_of_Times2
tff(fact_5176_card__of__bool,axiom,
    ! [B: $tType,A1: B,A22: B] :
      ( ( A1 != A22 )
     => member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of($o,top_top(set($o)))),bNF_Ca6860139660246222851ard_of(B,aa(set(B),set(B),insert2(B,A1),aa(set(B),set(B),insert2(B,A22),bot_bot(set(B)))))),bNF_Wellorder_ordIso($o,B)) ) ).

% card_of_bool
tff(fact_5177_card__of__Plus__empty1,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,bot_bot(set(C))))),bNF_Wellorder_ordIso(B,sum_sum(B,C))) ).

% card_of_Plus_empty1
tff(fact_5178_card__of__Plus__empty2,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,bot_bot(set(C)),A4))),bNF_Wellorder_ordIso(B,sum_sum(C,B))) ).

% card_of_Plus_empty2
tff(fact_5179_card__of__Plus__Times__bool,axiom,
    ! [B: $tType,A4: set(B)] : member(product_prod(set(product_prod(sum_sum(B,B),sum_sum(B,B))),set(product_prod(product_prod(B,$o),product_prod(B,$o)))),aa(set(product_prod(product_prod(B,$o),product_prod(B,$o))),product_prod(set(product_prod(sum_sum(B,B),sum_sum(B,B))),set(product_prod(product_prod(B,$o),product_prod(B,$o)))),aa(set(product_prod(sum_sum(B,B),sum_sum(B,B))),fun(set(product_prod(product_prod(B,$o),product_prod(B,$o))),product_prod(set(product_prod(sum_sum(B,B),sum_sum(B,B))),set(product_prod(product_prod(B,$o),product_prod(B,$o))))),product_Pair(set(product_prod(sum_sum(B,B),sum_sum(B,B))),set(product_prod(product_prod(B,$o),product_prod(B,$o)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,B),sum_Plus(B,B,A4,A4))),bNF_Ca6860139660246222851ard_of(product_prod(B,$o),product_Sigma(B,$o,A4,aTP_Lamp_uw(B,set($o))))),bNF_Wellorder_ordIso(sum_sum(B,B),product_prod(B,$o))) ).

% card_of_Plus_Times_bool
tff(fact_5180_card__of__Plus__commute,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] : member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B))))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,B5,A4))),bNF_Wellorder_ordIso(sum_sum(B,C),sum_sum(C,B))) ).

% card_of_Plus_commute
tff(fact_5181_card__of__Plus__cong2,axiom,
    ! [C: $tType,B: $tType,D: $tType,A4: set(B),B5: set(C),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),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(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,B),sum_sum(D,B))),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(D,B),sum_Plus(D,B,C5,A4))),bNF_Ca6860139660246222851ard_of(sum_sum(D,C),sum_Plus(D,C,C5,B5))),bNF_Wellorder_ordIso(sum_sum(D,B),sum_sum(D,C))) ) ).

% card_of_Plus_cong2
tff(fact_5182_card__of__Plus__cong1,axiom,
    ! [C: $tType,D: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),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(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,A4,C5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,B5,C5))),bNF_Wellorder_ordIso(sum_sum(B,D),sum_sum(C,D))) ) ).

% card_of_Plus_cong1
tff(fact_5183_card__of__Plus__assoc,axiom,
    ! [D: $tType,C: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] : member(product_prod(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D))))),aa(set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D)))),product_prod(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D))))),aa(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),fun(set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D)))),product_prod(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D)))))),product_Pair(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D))))),bNF_Ca6860139660246222851ard_of(sum_sum(sum_sum(B,C),D),sum_Plus(sum_sum(B,C),D,sum_Plus(B,C,A4,B5),C5))),bNF_Ca6860139660246222851ard_of(sum_sum(B,sum_sum(C,D)),sum_Plus(B,sum_sum(C,D),A4,sum_Plus(C,D,B5,C5)))),bNF_Wellorder_ordIso(sum_sum(sum_sum(B,C),D),sum_sum(B,sum_sum(C,D)))) ).

% card_of_Plus_assoc
tff(fact_5184_card__of__Plus__cong,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D),D4: set(E)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordIso(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),bNF_Ca6860139660246222851ard_of(D,C5)),bNF_Ca6860139660246222851ard_of(E,D4)),bNF_Wellorder_ordIso(D,E))
       => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,A4,C5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,E),sum_Plus(C,E,B5,D4))),bNF_Wellorder_ordIso(sum_sum(B,D),sum_sum(C,E))) ) ) ).

% card_of_Plus_cong
tff(fact_5185_card__of__Times__Plus__distrib,axiom,
    ! [D: $tType,C: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] : member(product_prod(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D))))),aa(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),product_prod(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D))))),aa(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),fun(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),product_prod(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))))),product_Pair(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D))))),bNF_Ca6860139660246222851ard_of(product_prod(B,sum_sum(C,D)),product_Sigma(B,sum_sum(C,D),A4,aa(set(D),fun(B,set(sum_sum(C,D))),aTP_Lamp_ux(set(C),fun(set(D),fun(B,set(sum_sum(C,D)))),B5),C5)))),bNF_Ca6860139660246222851ard_of(sum_sum(product_prod(B,C),product_prod(B,D)),sum_Plus(product_prod(B,C),product_prod(B,D),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)),product_Sigma(B,D,A4,aTP_Lamp_to(set(D),fun(B,set(D)),C5))))),bNF_Wellorder_ordIso(product_prod(B,sum_sum(C,D)),sum_sum(product_prod(B,C),product_prod(B,D)))) ).

% card_of_Times_Plus_distrib
tff(fact_5186_card__of__Plus__mono2,axiom,
    ! [C: $tType,B: $tType,D: $tType,A4: set(B),B5: set(C),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),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(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,B),sum_sum(D,B))),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(D,B),sum_Plus(D,B,C5,A4))),bNF_Ca6860139660246222851ard_of(sum_sum(D,C),sum_Plus(D,C,C5,B5))),bNF_Wellorder_ordLeq(sum_sum(D,B),sum_sum(D,C))) ) ).

% card_of_Plus_mono2
tff(fact_5187_card__of__Plus__mono1,axiom,
    ! [C: $tType,D: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),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(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,A4,C5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,B5,C5))),bNF_Wellorder_ordLeq(sum_sum(B,D),sum_sum(C,D))) ) ).

% card_of_Plus_mono1
tff(fact_5188_card__of__Plus__mono,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D),D4: set(E)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),bNF_Ca6860139660246222851ard_of(D,C5)),bNF_Ca6860139660246222851ard_of(E,D4)),bNF_Wellorder_ordLeq(D,E))
       => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,A4,C5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,E),sum_Plus(C,E,B5,D4))),bNF_Wellorder_ordLeq(sum_sum(B,D),sum_sum(C,E))) ) ) ).

% card_of_Plus_mono
tff(fact_5189_card__of__Plus2,axiom,
    ! [C: $tType,B: $tType,B5: set(B),A4: set(C)] : member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,A4,B5))),bNF_Wellorder_ordLeq(B,sum_sum(C,B))) ).

% card_of_Plus2
tff(fact_5190_card__of__Plus1,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] : member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Wellorder_ordLeq(B,sum_sum(B,C))) ).

% card_of_Plus1
tff(fact_5191_card__of__Un__Plus__ordLeq,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),aa(set(product_prod(sum_sum(B,B),sum_sum(B,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(B,B),sum_sum(B,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),bNF_Ca6860139660246222851ard_of(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))),bNF_Ca6860139660246222851ard_of(sum_sum(B,B),sum_Plus(B,B,A4,B5))),bNF_Wellorder_ordLeq(B,sum_sum(B,B))) ).

% card_of_Un_Plus_ordLeq
tff(fact_5192_card__of__Plus__infinite,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
       => ( member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(sum_sum(B,C),B))
          & member(product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,B5,A4))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(sum_sum(C,B),B)) ) ) ) ).

% card_of_Plus_infinite
tff(fact_5193_card__of__Plus__infinite1,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
       => member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(sum_sum(B,C),B)) ) ) ).

% card_of_Plus_infinite1
tff(fact_5194_card__of__Plus__infinite2,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
       => member(product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,B5,A4))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(sum_sum(C,B),B)) ) ) ).

% card_of_Plus_infinite2
tff(fact_5195_card__of__Plus__ordLess__infinite,axiom,
    ! [B: $tType,D: $tType,C: $tType,C5: set(B),A4: set(C),B5: set(D)] :
      ( ~ finite_finite2(B,C5)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(B,C5)),bNF_We4044943003108391690rdLess(C,B))
       => ( member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,B5)),bNF_Ca6860139660246222851ard_of(B,C5)),bNF_We4044943003108391690rdLess(D,B))
         => member(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,A4,B5))),bNF_Ca6860139660246222851ard_of(B,C5)),bNF_We4044943003108391690rdLess(sum_sum(C,D),B)) ) ) ) ).

% card_of_Plus_ordLess_infinite
tff(fact_5196_card__of__Sigma__ordLeq__infinite,axiom,
    ! [B: $tType,D: $tType,C: $tType,B5: set(B),I4: set(C),A4: fun(C,set(D))] :
      ( ~ finite_finite2(B,B5)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,I4)),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(C,B))
       => ( ! [X3: C] :
              ( member(C,X3,I4)
             => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),A4,X3))),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(D,B)) )
         => member(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,I4,A4))),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(product_prod(C,D),B)) ) ) ) ).

% card_of_Sigma_ordLeq_infinite
tff(fact_5197_card__of__refl,axiom,
    ! [B: $tType,A4: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(B,B)) ).

% card_of_refl
tff(fact_5198_card__of__Plus__Times__aux,axiom,
    ! [C: $tType,B: $tType,A1: B,A22: B,A4: set(B),B5: set(C)] :
      ( ( ( A1 != A22 )
        & aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,A1),aa(set(B),set(B),insert2(B,A22),bot_bot(set(B))))),A4) )
     => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
       => member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C))))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Wellorder_ordLeq(sum_sum(B,C),product_prod(B,C))) ) ) ).

% card_of_Plus_Times_aux
tff(fact_5199_card__of__Times__infinite__simps_I4_J,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( ( B5 != bot_bot(set(C)) )
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
         => member(product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),A4)))),bNF_Wellorder_ordIso(B,product_prod(C,B))) ) ) ) ).

% card_of_Times_infinite_simps(4)
tff(fact_5200_card__of__Times__infinite__simps_I3_J,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( ( B5 != bot_bot(set(C)) )
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
         => member(product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),A4)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(product_prod(C,B),B)) ) ) ) ).

% card_of_Times_infinite_simps(3)
tff(fact_5201_card__of__Times__infinite__simps_I2_J,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( ( B5 != bot_bot(set(C)) )
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
         => member(product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C))))),product_Pair(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Wellorder_ordIso(B,product_prod(B,C))) ) ) ) ).

% card_of_Times_infinite_simps(2)
tff(fact_5202_card__of__Times__infinite__simps_I1_J,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( ( B5 != bot_bot(set(C)) )
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
         => member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(product_prod(B,C),B)) ) ) ) ).

% card_of_Times_infinite_simps(1)
tff(fact_5203_card__of__Times__infinite,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( ~ finite_finite2(B,A4)
     => ( ( B5 != bot_bot(set(C)) )
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B))
         => ( member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(product_prod(B,C),B))
            & member(product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,B5,aTP_Lamp_jr(set(B),fun(C,set(B)),A4)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(product_prod(C,B),B)) ) ) ) ) ).

% card_of_Times_infinite
tff(fact_5204_card__of__Plus__Times,axiom,
    ! [C: $tType,B: $tType,A1: B,A22: B,A4: set(B),B1: C,B22: C,B5: set(C)] :
      ( ( ( A1 != A22 )
        & aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,A1),aa(set(B),set(B),insert2(B,A22),bot_bot(set(B))))),A4) )
     => ( ( ( B1 != B22 )
          & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(C),set(C),insert2(C,B1),aa(set(C),set(C),insert2(C,B22),bot_bot(set(C))))),B5) )
       => member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C))))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(product_prod(B,C),product_prod(B,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Wellorder_ordLeq(sum_sum(B,C),product_prod(B,C))) ) ) ).

% card_of_Plus_Times
tff(fact_5205_card__of__image,axiom,
    ! [C: $tType,B: $tType,F: fun(C,B),A4: set(C)] : member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,aa(set(C),set(B),image2(C,B,F),A4))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(B,C)) ).

% card_of_image
tff(fact_5206_card__of__empty,axiom,
    ! [C: $tType,B: $tType,A4: set(C)] : member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,bot_bot(set(B)))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(B,C)) ).

% card_of_empty
tff(fact_5207_card__of__empty3,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),bNF_Wellorder_ordLeq(B,C))
     => ( A4 = bot_bot(set(B)) ) ) ).

% card_of_empty3
tff(fact_5208_card__of__ordLeq__finite,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => ( finite_finite2(C,B5)
       => finite_finite2(B,A4) ) ) ).

% card_of_ordLeq_finite
tff(fact_5209_card__of__ordLeq__infinite,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C))
     => ( ~ finite_finite2(B,A4)
       => ~ finite_finite2(C,B5) ) ) ).

% card_of_ordLeq_infinite
tff(fact_5210_card__of__mono1,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),A4),B5)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordLeq(B,B)) ) ).

% card_of_mono1
tff(fact_5211_card__of__empty__ordIso,axiom,
    ! [C: $tType,B: $tType] : member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,bot_bot(set(B)))),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),bNF_Wellorder_ordIso(B,C)) ).

% card_of_empty_ordIso
tff(fact_5212_card__of__empty2,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),bNF_Wellorder_ordIso(B,C))
     => ( A4 = bot_bot(set(B)) ) ) ).

% card_of_empty2
tff(fact_5213_card__of__ordIso__finite,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B5: set(C)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordIso(B,C))
     => ( finite_finite2(B,A4)
      <=> finite_finite2(C,B5) ) ) ).

% card_of_ordIso_finite
tff(fact_5214_card__of__mono2,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),bNF_Ca6860139660246222851ard_of(C,field2(C,R3))),bNF_Wellorder_ordLeq(B,C)) ) ).

% card_of_mono2
tff(fact_5215_card__of__cong,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),bNF_Ca6860139660246222851ard_of(C,field2(C,R3))),bNF_Wellorder_ordIso(B,C)) ) ).

% card_of_cong
tff(fact_5216_card__of__ordLeqI,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( inj_on(B,C,F,A4)
     => ( ! [A5: B] :
            ( member(B,A5,A4)
           => member(C,aa(B,C,F,A5),B5) )
       => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C)) ) ) ).

% card_of_ordLeqI
tff(fact_5217_ex__bij__betw,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
     => ? [F3: fun(C,B),B8: set(C)] : bij_betw(C,B,F3,B8,A4) ) ).

% ex_bij_betw
tff(fact_5218_card__of__least,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( order_well_order_on(B,A4,R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,B)) ) ).

% card_of_least
tff(fact_5219_BNF__Cardinal__Order__Relation_OordLess__Field,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),R3),bNF_We4044943003108391690rdLess(B,C)) ) ).

% BNF_Cardinal_Order_Relation.ordLess_Field
tff(fact_5220_card__of__ordIsoI,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B),B5: set(C)] :
      ( bij_betw(B,C,F,A4,B5)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordIso(B,C)) ) ).

% card_of_ordIsoI
tff(fact_5221_card__of__ordIso,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ? [F6: fun(B,C)] : bij_betw(B,C,F6,A4,B5)
    <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordIso(B,C)) ) ).

% card_of_ordIso
tff(fact_5222_type__copy__set__bd,axiom,
    ! [B: $tType,E: $tType,D: $tType,C: $tType,S2: fun(B,set(C)),Bd: set(product_prod(D,D)),Rep: fun(E,B),X2: E] :
      ( ! [Y4: B] : member(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,aa(B,set(C),S2,Y4))),Bd),bNF_Wellorder_ordLeq(C,D))
     => member(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,aa(E,set(C),aa(fun(E,B),fun(E,set(C)),aa(fun(B,set(C)),fun(fun(E,B),fun(E,set(C))),comp(B,set(C),E),S2),Rep),X2))),Bd),bNF_Wellorder_ordLeq(C,D)) ) ).

% type_copy_set_bd
tff(fact_5223_card__of__ordLeq2,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ( A4 != bot_bot(set(B)) )
     => ( ? [G5: fun(C,B)] : aa(set(C),set(B),image2(C,B,G5),B5) = A4
      <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C)) ) ) ).

% card_of_ordLeq2
tff(fact_5224_surj__imp__ordLeq,axiom,
    ! [C: $tType,B: $tType,B5: set(B),F: fun(C,B),A4: set(C)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),aa(set(C),set(B),image2(C,B,F),A4))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordLeq(B,C)) ) ).

% surj_imp_ordLeq
tff(fact_5225_card__of__singl__ordLeq,axiom,
    ! [B: $tType,C: $tType,A4: set(B),B2: C] :
      ( ( A4 != bot_bot(set(B)) )
     => member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,aa(set(C),set(C),insert2(C,B2),bot_bot(set(C))))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(C,B)) ) ).

% card_of_singl_ordLeq
tff(fact_5226_card__of__ordLess2,axiom,
    ! [B: $tType,C: $tType,B5: set(B),A4: set(C)] :
      ( ( B5 != bot_bot(set(B)) )
     => ( ~ ? [F6: fun(C,B)] : aa(set(C),set(B),image2(C,B,F6),A4) = B5
      <=> member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_We4044943003108391690rdLess(C,B)) ) ) ).

% card_of_ordLess2
tff(fact_5227_internalize__card__of__ordLeq2,axiom,
    ! [B: $tType,C: $tType,A4: set(B),C5: set(C)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,C5)),bNF_Wellorder_ordLeq(B,C))
    <=> ? [B9: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B9),C5)
          & member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B9)),bNF_Wellorder_ordIso(B,C))
          & member(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))),bNF_Ca6860139660246222851ard_of(C,B9)),bNF_Ca6860139660246222851ard_of(C,C5)),bNF_Wellorder_ordLeq(C,C)) ) ) ).

% internalize_card_of_ordLeq2
tff(fact_5228_card__of__Field__ordLess,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_well_order_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),R),bNF_Wellorder_ordLeq(B,B)) ) ).

% card_of_Field_ordLess
tff(fact_5229_ordLeq__Plus__mono,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),P3: set(product_prod(D,D)),P7: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P3),P7),bNF_Wellorder_ordLeq(D,E))
       => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,field2(B,R),field2(D,P3)))),bNF_Ca6860139660246222851ard_of(sum_sum(C,E),sum_Plus(C,E,field2(C,R3),field2(E,P7)))),bNF_Wellorder_ordLeq(sum_sum(B,D),sum_sum(C,E))) ) ) ).

% ordLeq_Plus_mono
tff(fact_5230_ordLeq__Plus__mono1,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),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(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,field2(B,R),C5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,field2(C,R3),C5))),bNF_Wellorder_ordLeq(sum_sum(B,D),sum_sum(C,D))) ) ).

% ordLeq_Plus_mono1
tff(fact_5231_ordLeq__Plus__mono2,axiom,
    ! [C: $tType,B: $tType,D: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),A4: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),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(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,B),sum_sum(D,B))),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(D,B),sum_Plus(D,B,A4,field2(B,R)))),bNF_Ca6860139660246222851ard_of(sum_sum(D,C),sum_Plus(D,C,A4,field2(C,R3)))),bNF_Wellorder_ordLeq(sum_sum(D,B),sum_sum(D,C))) ) ).

% ordLeq_Plus_mono2
tff(fact_5232_ordIso__Plus__cong,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),P3: set(product_prod(D,D)),P7: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P3),P7),bNF_Wellorder_ordIso(D,E))
       => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,field2(B,R),field2(D,P3)))),bNF_Ca6860139660246222851ard_of(sum_sum(C,E),sum_Plus(C,E,field2(C,R3),field2(E,P7)))),bNF_Wellorder_ordIso(sum_sum(B,D),sum_sum(C,E))) ) ) ).

% ordIso_Plus_cong
tff(fact_5233_ordIso__Plus__cong1,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),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(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,D),sum_Plus(B,D,field2(B,R),C5))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,field2(C,R3),C5))),bNF_Wellorder_ordIso(sum_sum(B,D),sum_sum(C,D))) ) ).

% ordIso_Plus_cong1
tff(fact_5234_ordIso__Plus__cong2,axiom,
    ! [C: $tType,B: $tType,D: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),A4: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),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(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,B),sum_sum(D,B))),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(D,B),sum_Plus(D,B,A4,field2(B,R)))),bNF_Ca6860139660246222851ard_of(sum_sum(D,C),sum_Plus(D,C,A4,field2(C,R3)))),bNF_Wellorder_ordIso(sum_sum(D,B),sum_sum(D,C))) ) ).

% ordIso_Plus_cong2
tff(fact_5235_ordLeq__Times__mono1,axiom,
    ! [C: $tType,D: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),C5: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,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(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Ca6860139660246222851ard_of(product_prod(B,D),product_Sigma(B,D,field2(B,R),aTP_Lamp_to(set(D),fun(B,set(D)),C5)))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,field2(C,R3),aTP_Lamp_mz(set(D),fun(C,set(D)),C5)))),bNF_Wellorder_ordLeq(product_prod(B,D),product_prod(C,D))) ) ).

% ordLeq_Times_mono1
tff(fact_5236_ordLeq__Times__mono2,axiom,
    ! [C: $tType,B: $tType,D: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),A4: set(D)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),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(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,B),product_prod(D,B))),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),bNF_Ca6860139660246222851ard_of(product_prod(D,B),product_Sigma(D,B,A4,aTP_Lamp_uy(set(product_prod(B,B)),fun(D,set(B)),R)))),bNF_Ca6860139660246222851ard_of(product_prod(D,C),product_Sigma(D,C,A4,aTP_Lamp_uz(set(product_prod(C,C)),fun(D,set(C)),R3)))),bNF_Wellorder_ordLeq(product_prod(D,B),product_prod(D,C))) ) ).

% ordLeq_Times_mono2
tff(fact_5237_card__of__ordLeq,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] :
      ( ? [F6: fun(B,C)] :
          ( inj_on(B,C,F6,A4)
          & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),image2(B,C,F6),A4)),B5) )
    <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B5)),bNF_Wellorder_ordLeq(B,C)) ) ).

% card_of_ordLeq
tff(fact_5238_internalize__card__of__ordLeq,axiom,
    ! [B: $tType,C: $tType,A4: set(B),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
    <=> ? [B9: set(C)] :
          ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B9),field2(C,R))
          & member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(C,B9)),bNF_Wellorder_ordIso(B,C))
          & member(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))),bNF_Ca6860139660246222851ard_of(C,B9)),R),bNF_Wellorder_ordLeq(C,C)) ) ) ).

% internalize_card_of_ordLeq
tff(fact_5239_regularCard__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca7133664381575040944arCard(B,R)
    <=> ! [K10: set(B)] :
          ( ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),K10),field2(B,R))
            & bNF_Ca7293521722713021262ofinal(B,K10,R) )
         => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,K10)),R),bNF_Wellorder_ordIso(B,B)) ) ) ).

% regularCard_def
tff(fact_5240_card__of__ordIso__subst,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] :
      ( ( A4 = B5 )
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(B,B5)),bNF_Wellorder_ordIso(B,B)) ) ).

% card_of_ordIso_subst
tff(fact_5241_comp__set__bd__Union__o__collect,axiom,
    ! [D: $tType,C: $tType,B: $tType,X2: D,X7: set(fun(D,set(set(B)))),Hbd: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(set(set(B))),set(set(B)),complete_Sup_Sup(set(set(B))),aa(set(fun(D,set(set(B)))),set(set(set(B))),image2(fun(D,set(set(B))),set(set(B)),aTP_Lamp_va(D,fun(fun(D,set(set(B))),set(set(B))),X2)),X7))))),Hbd),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,aa(D,set(B),aa(fun(D,set(set(B))),fun(D,set(B)),aa(fun(set(set(B)),set(B)),fun(fun(D,set(set(B))),fun(D,set(B))),comp(set(set(B)),set(B),D),complete_Sup_Sup(set(B))),bNF_collect(D,set(B),X7)),X2))),Hbd),bNF_Wellorder_ordLeq(B,C)) ) ).

% comp_set_bd_Union_o_collect
tff(fact_5242_card__of__Plus__ordLess__infinite__Field,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),A4: set(C),B5: set(D)] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,A4)),R),bNF_We4044943003108391690rdLess(C,B))
         => ( member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,B5)),R),bNF_We4044943003108391690rdLess(D,B))
           => member(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,A4,B5))),R),bNF_We4044943003108391690rdLess(sum_sum(C,D),B)) ) ) ) ) ).

% card_of_Plus_ordLess_infinite_Field
tff(fact_5243_card__of__Times__ordLeq__infinite__Field,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),A4: set(C),B5: set(D)] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,A4)),R),bNF_Wellorder_ordLeq(C,B))
       => ( member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,B5)),R),bNF_Wellorder_ordLeq(D,B))
         => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
           => member(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,A4,aTP_Lamp_mz(set(D),fun(C,set(D)),B5)))),R),bNF_Wellorder_ordLeq(product_prod(C,D),B)) ) ) ) ) ).

% card_of_Times_ordLeq_infinite_Field
tff(fact_5244_card__of__Sigma__ordLeq__infinite__Field,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),I4: set(C),A4: fun(C,set(D))] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,I4)),R),bNF_Wellorder_ordLeq(C,B))
         => ( ! [X3: C] :
                ( member(C,X3,I4)
               => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),A4,X3))),R),bNF_Wellorder_ordLeq(D,B)) )
           => member(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(C,D),product_Sigma(C,D,I4,A4))),R),bNF_Wellorder_ordLeq(product_prod(C,D),B)) ) ) ) ) ).

% card_of_Sigma_ordLeq_infinite_Field
tff(fact_5245_Card__order__trans,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: B,Y: B,Z2: B] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ( X2 != Y )
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
         => ( ( Y != Z2 )
           => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),R)
             => ( ( X2 != Z2 )
                & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),R) ) ) ) ) ) ) ).

% Card_order_trans
tff(fact_5246_card__order__on__ordIso,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),R3: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,A4,R)
     => ( bNF_Ca8970107618336181345der_on(B,A4,R3)
       => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R3),bNF_Wellorder_ordIso(B,B)) ) ) ).

% card_order_on_ordIso
tff(fact_5247_infinite__Card__order__limit,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ~ finite_finite2(B,field2(B,R))
       => ( member(B,A3,field2(B,R))
         => ? [X3: B] :
              ( member(B,X3,field2(B,R))
              & ( A3 != X3 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),X3),R) ) ) ) ) ).

% infinite_Card_order_limit
tff(fact_5248_ordLeq__refl,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R),bNF_Wellorder_ordLeq(B,B)) ) ).

% ordLeq_refl
tff(fact_5249_Card__order__ordIso,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordIso(C,B))
       => bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3) ) ) ).

% Card_order_ordIso
tff(fact_5250_Card__order__ordIso2,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C))
       => bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3) ) ) ).

% Card_order_ordIso2
tff(fact_5251_ordIso__refl,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R),bNF_Wellorder_ordIso(B,B)) ) ).

% ordIso_refl
tff(fact_5252_card__of__unique,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,A4,R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordIso(B,B)) ) ).

% card_of_unique
tff(fact_5253_card__order__on__def,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,A4,R)
    <=> ( order_well_order_on(B,A4,R)
        & ! [R11: set(product_prod(B,B))] :
            ( order_well_order_on(B,A4,R11)
           => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),R11),bNF_Wellorder_ordLeq(B,B)) ) ) ) ).

% card_order_on_def
tff(fact_5254_Card__order__iff__ordLeq__card__of,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
    <=> member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),bNF_Wellorder_ordLeq(B,B)) ) ).

% Card_order_iff_ordLeq_card_of
tff(fact_5255_ordIso__card__of__imp__Card__order,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),A4: set(C)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordIso(B,C))
     => bNF_Ca8970107618336181345der_on(B,field2(B,R),R) ) ).

% ordIso_card_of_imp_Card_order
tff(fact_5256_Card__order__iff__ordIso__card__of,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
    <=> member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),bNF_Wellorder_ordIso(B,B)) ) ).

% Card_order_iff_ordIso_card_of
tff(fact_5257_card__of__Field__ordIso,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),R),bNF_Wellorder_ordIso(B,B)) ) ).

% card_of_Field_ordIso
tff(fact_5258_dir__image,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),R: set(product_prod(B,B))] :
      ( ! [X3: B,Y4: B] :
          ( ( aa(B,C,F,X3) = aa(B,C,F,Y4) )
        <=> ( X3 = Y4 ) )
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_We2720479622203943262_image(B,C,R,F)),bNF_Wellorder_ordIso(B,C)) ) ) ).

% dir_image
tff(fact_5259_exists__minim__Card__order,axiom,
    ! [B: $tType,R4: set(set(product_prod(B,B)))] :
      ( ( R4 != bot_bot(set(set(product_prod(B,B)))) )
     => ( ! [X3: set(product_prod(B,B))] :
            ( member(set(product_prod(B,B)),X3,R4)
           => bNF_Ca8970107618336181345der_on(B,field2(B,X3),X3) )
       => ? [X3: set(product_prod(B,B))] :
            ( member(set(product_prod(B,B)),X3,R4)
            & ! [Xa3: set(product_prod(B,B))] :
                ( member(set(product_prod(B,B)),Xa3,R4)
               => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),X3),Xa3),bNF_Wellorder_ordLeq(B,B)) ) ) ) ) ).

% exists_minim_Card_order
tff(fact_5260_Card__order__empty,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),R),bNF_Wellorder_ordLeq(C,B)) ) ).

% Card_order_empty
tff(fact_5261_card__of__ordIso__finite__Field,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),A4: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_Ca6860139660246222851ard_of(C,A4)),bNF_Wellorder_ordIso(B,C))
       => ( finite_finite2(B,field2(B,R))
        <=> finite_finite2(C,A4) ) ) ) ).

% card_of_ordIso_finite_Field
tff(fact_5262_card__of__underS,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( member(B,A3,field2(B,R))
       => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,order_underS(B,R,A3))),R),bNF_We4044943003108391690rdLess(B,B)) ) ) ).

% card_of_underS
tff(fact_5263_Card__order__Plus1,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),B5: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),R),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,field2(B,R),B5))),bNF_Wellorder_ordLeq(B,sum_sum(B,C))) ) ).

% Card_order_Plus1
tff(fact_5264_Card__order__Plus2,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),A4: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),R),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,A4,field2(B,R)))),bNF_Wellorder_ordLeq(B,sum_sum(C,B))) ) ).

% Card_order_Plus2
tff(fact_5265_Card__order__singl__ordLeq,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),B2: C] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ( field2(B,R) != bot_bot(set(B)) )
       => member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,aa(set(C),set(C),insert2(C,B2),bot_bot(set(C))))),R),bNF_Wellorder_ordLeq(C,B)) ) ) ).

% Card_order_singl_ordLeq
tff(fact_5266_card__of__Un__ordLeq__infinite__Field,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),A4: set(C),B5: set(C)] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,A4)),R),bNF_Wellorder_ordLeq(C,B))
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),R),bNF_Wellorder_ordLeq(C,B))
         => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
           => member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),A4),B5))),R),bNF_Wellorder_ordLeq(C,B)) ) ) ) ) ).

% card_of_Un_ordLeq_infinite_Field
tff(fact_5267_card__of__empty1,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B))] :
      ( ( order_well_order_on(B,field2(B,R),R)
        | bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,bot_bot(set(C)))),R),bNF_Wellorder_ordLeq(C,B)) ) ).

% card_of_empty1
tff(fact_5268_Card__order__Times1,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),B5: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ( B5 != bot_bot(set(C)) )
       => member(product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C))))),product_Pair(set(product_prod(B,B)),set(product_prod(product_prod(B,C),product_prod(B,C)))),R),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,field2(B,R),aTP_Lamp_jm(set(C),fun(B,set(C)),B5)))),bNF_Wellorder_ordLeq(B,product_prod(B,C))) ) ) ).

% Card_order_Times1
tff(fact_5269_Card__order__Times2,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),A4: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ( A4 != bot_bot(set(C)) )
       => member(product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(product_prod(C,B),product_prod(C,B)))),R),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,A4,aTP_Lamp_vb(set(product_prod(B,B)),fun(C,set(B)),R)))),bNF_Wellorder_ordLeq(B,product_prod(C,B))) ) ) ).

% Card_order_Times2
tff(fact_5270_Card__order__Times__same__infinite,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ~ finite_finite2(B,field2(B,R))
       => member(product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,B),product_prod(B,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(B,B),product_Sigma(B,B,field2(B,R),aTP_Lamp_kw(set(product_prod(B,B)),fun(B,set(B)),R)))),R),bNF_Wellorder_ordLeq(product_prod(B,B),B)) ) ) ).

% Card_order_Times_same_infinite
tff(fact_5271_card__of__UNION__ordLeq__infinite__Field,axiom,
    ! [C: $tType,B: $tType,D: $tType,R: set(product_prod(B,B)),I4: set(C),A4: fun(C,set(D))] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,I4)),R),bNF_Wellorder_ordLeq(C,B))
         => ( ! [X3: C] :
                ( member(C,X3,I4)
               => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),A4,X3))),R),bNF_Wellorder_ordLeq(D,B)) )
           => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),A4),I4)))),R),bNF_Wellorder_ordLeq(D,B)) ) ) ) ) ).

% card_of_UNION_ordLeq_infinite_Field
tff(fact_5272_Card__order__Plus__infinite,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),P3: set(product_prod(C,C))] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),P3),R),bNF_Wellorder_ordLeq(C,B))
         => ( member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,field2(B,R),field2(C,P3)))),R),bNF_Wellorder_ordIso(sum_sum(B,C),B))
            & member(product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(C,B),sum_Plus(C,B,field2(C,P3),field2(B,R)))),R),bNF_Wellorder_ordIso(sum_sum(C,B),B)) ) ) ) ) ).

% Card_order_Plus_infinite
tff(fact_5273_Card__order__iff__Restr__underS,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( order_well_order_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
      <=> ! [X4: B] :
            ( member(B,X4,field2(B,R))
           => member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),set(product_prod(B,B)),inf_inf(set(product_prod(B,B)),R),product_Sigma(B,B,order_underS(B,R,X4),aa(B,fun(B,set(B)),aTP_Lamp_st(set(product_prod(B,B)),fun(B,fun(B,set(B))),R),X4)))),bNF_Ca6860139660246222851ard_of(B,field2(B,R))),bNF_We4044943003108391690rdLess(B,B)) ) ) ) ).

% Card_order_iff_Restr_underS
tff(fact_5274_regularCard__UNION,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),As3: fun(B,set(C)),B5: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca7133664381575040944arCard(B,R)
       => ( bNF_Ca3754400796208372196lChain(B,set(C),R,As3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(B),set(set(C)),image2(B,set(C),As3),field2(B,R))))
           => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),R),bNF_We4044943003108391690rdLess(C,B))
             => ? [X3: B] :
                  ( member(B,X3,field2(B,R))
                  & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(B,set(C),As3,X3)) ) ) ) ) ) ) ).

% regularCard_UNION
tff(fact_5275_card__of__Plus__ordLeq__infinite__Field,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),A4: set(C),B5: set(D)] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,A4)),R),bNF_Wellorder_ordLeq(C,B))
       => ( member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,B5)),R),bNF_Wellorder_ordLeq(D,B))
         => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
           => member(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(sum_sum(C,D),sum_Plus(C,D,A4,B5))),R),bNF_Wellorder_ordLeq(sum_sum(C,D),B)) ) ) ) ) ).

% card_of_Plus_ordLeq_infinite_Field
tff(fact_5276_Card__order__Times__infinite,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),P3: set(product_prod(C,C))] :
      ( ~ finite_finite2(B,field2(B,R))
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( ( field2(C,P3) != bot_bot(set(C)) )
         => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),P3),R),bNF_Wellorder_ordLeq(C,B))
           => ( member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(B,C),product_Sigma(B,C,field2(B,R),aTP_Lamp_vc(set(product_prod(C,C)),fun(B,set(C)),P3)))),R),bNF_Wellorder_ordIso(product_prod(B,C),B))
              & member(product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,B),product_prod(C,B))),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(product_prod(C,B),product_Sigma(C,B,field2(C,P3),aTP_Lamp_vb(set(product_prod(B,B)),fun(C,set(B)),R)))),R),bNF_Wellorder_ordIso(product_prod(C,B),B)) ) ) ) ) ) ).

% Card_order_Times_infinite
tff(fact_5277_ex__toCard__pred,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R),R)
       => ? [X_13: fun(B,C)] : bNF_Gr1419584066657907630d_pred(B,C,A4,R,X_13) ) ) ).

% ex_toCard_pred
tff(fact_5278_cardSuc__UNION,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),As3: fun(set(B),set(C)),B5: set(C)] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ~ finite_finite2(B,field2(B,R))
       => ( bNF_Ca3754400796208372196lChain(set(B),set(C),bNF_Ca8387033319878233205ardSuc(B,R),As3)
         => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(set(B)),set(set(C)),image2(set(B),set(C),As3),field2(set(B),bNF_Ca8387033319878233205ardSuc(B,R)))))
           => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),R),bNF_Wellorder_ordLeq(C,B))
             => ? [X3: set(B)] :
                  ( member(set(B),X3,field2(set(B),bNF_Ca8387033319878233205ardSuc(B,R)))
                  & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(B),set(C),As3,X3)) ) ) ) ) ) ) ).

% cardSuc_UNION
tff(fact_5279_toCard__inj,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(C,C)),X2: B,Y: B] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R),R)
       => ( member(B,X2,A4)
         => ( member(B,Y,A4)
           => ( ( aa(B,C,bNF_Greatest_toCard(B,C,A4,R),X2) = aa(B,C,bNF_Greatest_toCard(B,C,A4,R),Y) )
            <=> ( X2 = Y ) ) ) ) ) ) ).

% toCard_inj
tff(fact_5280_cardSuc__greater,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),R),bNF_Ca8387033319878233205ardSuc(B,R)),bNF_We4044943003108391690rdLess(B,set(B))) ) ).

% cardSuc_greater
tff(fact_5281_cardSuc__ordLeq,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),R),bNF_Ca8387033319878233205ardSuc(B,R)),bNF_Wellorder_ordLeq(B,set(B))) ) ).

% cardSuc_ordLeq
tff(fact_5282_toCard__pred__toCard,axiom,
    ! [B: $tType,C: $tType,A4: set(B),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R),R)
       => bNF_Gr1419584066657907630d_pred(B,C,A4,R,bNF_Greatest_toCard(B,C,A4,R)) ) ) ).

% toCard_pred_toCard
tff(fact_5283_cardSuc__least__aux,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(set(B),set(B)))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(set(B),field2(set(B),R3),R3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),R),R3),bNF_We4044943003108391690rdLess(B,set(B)))
         => member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),bNF_Ca8387033319878233205ardSuc(B,R)),R3),bNF_Wellorder_ordLeq(set(B),set(B))) ) ) ) ).

% cardSuc_least_aux
tff(fact_5284_cardSuc__ordLeq__ordLess,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(C,C)),set(product_prod(set(B),set(B)))),aa(set(product_prod(C,C)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(C,C)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(C,C)),set(product_prod(set(B),set(B)))),R3),bNF_Ca8387033319878233205ardSuc(B,R)),bNF_We4044943003108391690rdLess(C,set(B)))
        <=> member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R3),R),bNF_Wellorder_ordLeq(C,B)) ) ) ) ).

% cardSuc_ordLeq_ordLess
tff(fact_5285_cardSuc__ordLess__ordLeq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
        <=> member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(set(B),set(B))),set(product_prod(C,C))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(C,C)),product_prod(set(product_prod(set(B),set(B))),set(product_prod(C,C)))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(C,C))),bNF_Ca8387033319878233205ardSuc(B,R)),R3),bNF_Wellorder_ordLeq(set(B),C)) ) ) ) ).

% cardSuc_ordLess_ordLeq
tff(fact_5286_cardSuc__least,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_We4044943003108391690rdLess(B,C))
         => member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(set(B),set(B))),set(product_prod(C,C))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(C,C)),product_prod(set(product_prod(set(B),set(B))),set(product_prod(C,C)))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(C,C))),bNF_Ca8387033319878233205ardSuc(B,R)),R3),bNF_Wellorder_ordLeq(set(B),C)) ) ) ) ).

% cardSuc_least
tff(fact_5287_cardSuc__mono__ordLeq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C)))),aa(set(product_prod(set(C),set(C))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C)))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(C),set(C))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C))))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C)))),bNF_Ca8387033319878233205ardSuc(B,R)),bNF_Ca8387033319878233205ardSuc(C,R3)),bNF_Wellorder_ordLeq(set(B),set(C)))
        <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordLeq(B,C)) ) ) ) ).

% cardSuc_mono_ordLeq
tff(fact_5288_cardSuc__invar__ordIso,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R3),R3)
       => ( member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C)))),aa(set(product_prod(set(C),set(C))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C)))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(C),set(C))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C))))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(set(C),set(C)))),bNF_Ca8387033319878233205ardSuc(B,R)),bNF_Ca8387033319878233205ardSuc(C,R3)),bNF_Wellorder_ordIso(set(B),set(C)))
        <=> member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),R3),bNF_Wellorder_ordIso(B,C)) ) ) ) ).

% cardSuc_invar_ordIso
tff(fact_5289_fromCard__toCard,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(C,C)),B2: B] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R),R)
       => ( member(B,B2,A4)
         => ( bNF_Gr5436034075474128252omCard(B,C,A4,R,aa(B,C,bNF_Greatest_toCard(B,C,A4,R),B2)) = B2 ) ) ) ) ).

% fromCard_toCard
tff(fact_5290_cardSuc__UNION__Cinfinite,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),As3: fun(set(B),set(C)),B5: set(C)] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( bNF_Ca3754400796208372196lChain(set(B),set(C),bNF_Ca8387033319878233205ardSuc(B,R),As3)
       => ( aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(set(B)),set(set(C)),image2(set(B),set(C),As3),field2(set(B),bNF_Ca8387033319878233205ardSuc(B,R)))))
         => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(C,B5)),R),bNF_Wellorder_ordLeq(C,B))
           => ? [X3: set(B)] :
                ( member(set(B),X3,field2(set(B),bNF_Ca8387033319878233205ardSuc(B,R)))
                & aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),B5),aa(set(B),set(C),As3,X3)) ) ) ) ) ) ).

% cardSuc_UNION_Cinfinite
tff(fact_5291_isCardSuc__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),R3: set(product_prod(set(B),set(B)))] :
      ( bNF_Ca6246979054910435723ardSuc(B,R,R3)
    <=> ( bNF_Ca8970107618336181345der_on(set(B),field2(set(B),R3),R3)
        & member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),R),R3),bNF_We4044943003108391690rdLess(B,set(B)))
        & ! [R13: set(product_prod(set(B),set(B)))] :
            ( ( bNF_Ca8970107618336181345der_on(set(B),field2(set(B),R13),R13)
              & member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),R),R13),bNF_We4044943003108391690rdLess(B,set(B))) )
           => member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(set(B),set(B)))),R3),R13),bNF_Wellorder_ordLeq(set(B),set(B))) ) ) ) ).

% isCardSuc_def
tff(fact_5292_cinfinite__mono,axiom,
    ! [B: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R1),R22),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca4139267488887388095finite(B,R1)
       => bNF_Ca4139267488887388095finite(C,R22) ) ) ).

% cinfinite_mono
tff(fact_5293_Cinfinite__limit2,axiom,
    ! [B: $tType,X1: B,R: set(product_prod(B,B)),X22: B] :
      ( member(B,X1,field2(B,R))
     => ( member(B,X22,field2(B,R))
       => ( ( bNF_Ca4139267488887388095finite(B,R)
            & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
         => ? [X3: B] :
              ( member(B,X3,field2(B,R))
              & ( X1 != X3 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X1),X3),R)
              & ( X22 != X3 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X22),X3),R) ) ) ) ) ).

% Cinfinite_limit2
tff(fact_5294_Cinfinite__limit,axiom,
    ! [B: $tType,X2: B,R: set(product_prod(B,B))] :
      ( member(B,X2,field2(B,R))
     => ( ( bNF_Ca4139267488887388095finite(B,R)
          & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
       => ? [X3: B] :
            ( member(B,X3,field2(B,R))
            & ( X2 != X3 )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),X3),R) ) ) ) ).

% Cinfinite_limit
tff(fact_5295_Cinfinite__cong,axiom,
    ! [B: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R1),R22),bNF_Wellorder_ordIso(B,C))
     => ( ( bNF_Ca4139267488887388095finite(B,R1)
          & bNF_Ca8970107618336181345der_on(B,field2(B,R1),R1) )
       => ( bNF_Ca4139267488887388095finite(C,R22)
          & bNF_Ca8970107618336181345der_on(C,field2(C,R22),R22) ) ) ) ).

% Cinfinite_cong
tff(fact_5296_Cinfinite__limit__finite,axiom,
    ! [B: $tType,X7: set(B),R: set(product_prod(B,B))] :
      ( finite_finite2(B,X7)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),X7),field2(B,R))
       => ( ( bNF_Ca4139267488887388095finite(B,R)
            & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
         => ? [X3: B] :
              ( member(B,X3,field2(B,R))
              & ! [Xa3: B] :
                  ( member(B,Xa3,X7)
                 => ( ( Xa3 != X3 )
                    & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa3),X3),R) ) ) ) ) ) ) ).

% Cinfinite_limit_finite
tff(fact_5297_Un__Cinfinite__bound,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(C,C)),B5: set(B)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),R),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,B5)),R),bNF_Wellorder_ordLeq(B,C))
       => ( ( bNF_Ca4139267488887388095finite(C,R)
            & bNF_Ca8970107618336181345der_on(C,field2(C,R),R) )
         => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))),R),bNF_Wellorder_ordLeq(B,C)) ) ) ) ).

% Un_Cinfinite_bound
tff(fact_5298_UNION__Cinfinite__bound,axiom,
    ! [B: $tType,C: $tType,D: $tType,I4: set(B),R: set(product_prod(C,C)),A4: fun(B,set(D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,I4)),R),bNF_Wellorder_ordLeq(B,C))
     => ( ! [X3: B] :
            ( member(B,X3,I4)
           => member(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(B,set(D),A4,X3))),R),bNF_Wellorder_ordLeq(D,C)) )
       => ( ( bNF_Ca4139267488887388095finite(C,R)
            & bNF_Ca8970107618336181345der_on(C,field2(C,R),R) )
         => member(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(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(B),set(set(D)),image2(B,set(D),A4),I4)))),R),bNF_Wellorder_ordLeq(D,C)) ) ) ) ).

% UNION_Cinfinite_bound
tff(fact_5299_Cfinite__ordLess__Cinfinite,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),S: set(product_prod(C,C))] :
      ( ( bNF_Cardinal_cfinite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( ( bNF_Ca4139267488887388095finite(C,S)
          & bNF_Ca8970107618336181345der_on(C,field2(C,S),S) )
       => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),S),bNF_We4044943003108391690rdLess(B,C)) ) ) ).

% Cfinite_ordLess_Cinfinite
tff(fact_5300_comp__single__set__bd,axiom,
    ! [C: $tType,E: $tType,B: $tType,F4: $tType,D: $tType,Fbd: set(product_prod(B,B)),Fset: fun(C,set(D)),Gset: fun(E,set(C)),Gbd: set(product_prod(F4,F4)),X2: E] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,Fbd),Fbd)
     => ( ! [X3: C] : member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),Fset,X3))),Fbd),bNF_Wellorder_ordLeq(D,B))
       => ( ! [X3: E] : member(product_prod(set(product_prod(C,C)),set(product_prod(F4,F4))),aa(set(product_prod(F4,F4)),product_prod(set(product_prod(C,C)),set(product_prod(F4,F4))),aa(set(product_prod(C,C)),fun(set(product_prod(F4,F4)),product_prod(set(product_prod(C,C)),set(product_prod(F4,F4)))),product_Pair(set(product_prod(C,C)),set(product_prod(F4,F4))),bNF_Ca6860139660246222851ard_of(C,aa(E,set(C),Gset,X3))),Gbd),bNF_Wellorder_ordLeq(C,F4))
         => member(product_prod(set(product_prod(D,D)),set(product_prod(product_prod(F4,B),product_prod(F4,B)))),aa(set(product_prod(product_prod(F4,B),product_prod(F4,B))),product_prod(set(product_prod(D,D)),set(product_prod(product_prod(F4,B),product_prod(F4,B)))),aa(set(product_prod(D,D)),fun(set(product_prod(product_prod(F4,B),product_prod(F4,B))),product_prod(set(product_prod(D,D)),set(product_prod(product_prod(F4,B),product_prod(F4,B))))),product_Pair(set(product_prod(D,D)),set(product_prod(product_prod(F4,B),product_prod(F4,B)))),bNF_Ca6860139660246222851ard_of(D,aa(set(set(D)),set(D),complete_Sup_Sup(set(D)),aa(set(C),set(set(D)),image2(C,set(D),Fset),aa(E,set(C),Gset,X2))))),bNF_Cardinal_cprod(F4,B,Gbd,Fbd)),bNF_Wellorder_ordLeq(D,product_prod(F4,B))) ) ) ) ).

% comp_single_set_bd
tff(fact_5301_cprod__dup,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),P3: set(product_prod(C,C)),P7: set(product_prod(D,D))] :
      ( bNF_Ca4139267488887388095finite(B,R)
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( member(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(B,B),product_prod(B,B)))),aa(set(product_prod(product_prod(B,B),product_prod(B,B))),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(B,B),product_prod(B,B)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(product_prod(B,B),product_prod(B,B))),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(B,B),product_prod(B,B))))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(B,B),product_prod(B,B)))),bNF_Cardinal_cprod(C,D,P3,P7)),bNF_Cardinal_cprod(B,B,R,R)),bNF_Wellorder_ordIso(product_prod(C,D),product_prod(B,B)))
         => member(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(B,B))),bNF_Cardinal_cprod(C,D,P3,P7)),R),bNF_Wellorder_ordIso(product_prod(C,D),B)) ) ) ) ).

% cprod_dup
tff(fact_5302_cprod__com,axiom,
    ! [C: $tType,B: $tType,P12: set(product_prod(B,B)),P23: set(product_prod(C,C))] : member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(C,B),product_prod(C,B)))),bNF_Cardinal_cprod(B,C,P12,P23)),bNF_Cardinal_cprod(C,B,P23,P12)),bNF_Wellorder_ordIso(product_prod(B,C),product_prod(C,B))) ).

% cprod_com
tff(fact_5303_Cfinite__cprod__Cinfinite,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),S: set(product_prod(C,C))] :
      ( ( bNF_Cardinal_cfinite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( ( bNF_Ca4139267488887388095finite(C,S)
          & bNF_Ca8970107618336181345der_on(C,field2(C,S),S) )
       => member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(C,C))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(C,C))),bNF_Cardinal_cprod(B,C,R,S)),S),bNF_Wellorder_ordLeq(product_prod(B,C),C)) ) ) ).

% Cfinite_cprod_Cinfinite
tff(fact_5304_cprod__mono,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordLeq(D,E))
       => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E)))),aa(set(product_prod(product_prod(C,E),product_prod(C,E))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(product_prod(C,E),product_prod(C,E))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E))))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E)))),bNF_Cardinal_cprod(B,D,P12,P23)),bNF_Cardinal_cprod(C,E,R1,R22)),bNF_Wellorder_ordLeq(product_prod(B,D),product_prod(C,E))) ) ) ).

% cprod_mono
tff(fact_5305_cprod__mono1,axiom,
    ! [C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,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(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Cardinal_cprod(B,D,P12,Q3)),bNF_Cardinal_cprod(C,D,R1,Q3)),bNF_Wellorder_ordLeq(product_prod(B,D),product_prod(C,D))) ) ).

% cprod_mono1
tff(fact_5306_cprod__mono2,axiom,
    ! [C: $tType,B: $tType,D: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),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(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,B),product_prod(D,B))),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),bNF_Cardinal_cprod(D,B,Q3,P23)),bNF_Cardinal_cprod(D,C,Q3,R22)),bNF_Wellorder_ordLeq(product_prod(D,B),product_prod(D,C))) ) ).

% cprod_mono2
tff(fact_5307_cprod__cong,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordIso(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordIso(D,E))
       => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E)))),aa(set(product_prod(product_prod(C,E),product_prod(C,E))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(product_prod(C,E),product_prod(C,E))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E))))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,E),product_prod(C,E)))),bNF_Cardinal_cprod(B,D,P12,P23)),bNF_Cardinal_cprod(C,E,R1,R22)),bNF_Wellorder_ordIso(product_prod(B,D),product_prod(C,E))) ) ) ).

% cprod_cong
tff(fact_5308_cprod__cong1,axiom,
    ! [C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,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(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(product_prod(C,D),product_prod(C,D))),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D))))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(product_prod(C,D),product_prod(C,D)))),bNF_Cardinal_cprod(B,D,P12,P23)),bNF_Cardinal_cprod(C,D,R1,P23)),bNF_Wellorder_ordIso(product_prod(B,D),product_prod(C,D))) ) ).

% cprod_cong1
tff(fact_5309_cprod__cong2,axiom,
    ! [C: $tType,B: $tType,D: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),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(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),aa(set(product_prod(product_prod(D,B),product_prod(D,B))),fun(set(product_prod(product_prod(D,C),product_prod(D,C))),product_prod(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C))))),product_Pair(set(product_prod(product_prod(D,B),product_prod(D,B))),set(product_prod(product_prod(D,C),product_prod(D,C)))),bNF_Cardinal_cprod(D,B,Q3,P23)),bNF_Cardinal_cprod(D,C,Q3,R22)),bNF_Wellorder_ordIso(product_prod(D,B),product_prod(D,C))) ) ).

% cprod_cong2
tff(fact_5310_cprod__infinite,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => member(product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,B),product_prod(B,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,B),product_prod(B,B))),set(product_prod(B,B))),bNF_Cardinal_cprod(B,B,R,R)),R),bNF_Wellorder_ordIso(product_prod(B,B),B)) ) ).

% cprod_infinite
tff(fact_5311_cprod__cinfinite__bound,axiom,
    ! [C: $tType,D: $tType,B: $tType,P3: set(product_prod(B,B)),R: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P3),R),bNF_Wellorder_ordLeq(B,C))
     => ( member(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))),Q3),R),bNF_Wellorder_ordLeq(D,C))
       => ( bNF_Ca8970107618336181345der_on(B,field2(B,P3),P3)
         => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
           => ( ( bNF_Ca4139267488887388095finite(C,R)
                & bNF_Ca8970107618336181345der_on(C,field2(C,R),R) )
             => member(product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(C,C))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),fun(set(product_prod(C,C)),product_prod(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(C,C)))),product_Pair(set(product_prod(product_prod(B,D),product_prod(B,D))),set(product_prod(C,C))),bNF_Cardinal_cprod(B,D,P3,Q3)),R),bNF_Wellorder_ordLeq(product_prod(B,D),C)) ) ) ) ) ) ).

% cprod_cinfinite_bound
tff(fact_5312_card__of__Csum__Times_H,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),I4: set(C),A4: fun(C,set(D))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ! [X3: C] :
            ( member(C,X3,I4)
           => member(product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B))),aa(set(product_prod(D,D)),fun(set(product_prod(B,B)),product_prod(set(product_prod(D,D)),set(product_prod(B,B)))),product_Pair(set(product_prod(D,D)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),A4,X3))),R),bNF_Wellorder_ordLeq(D,B)) )
       => member(product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(C,B),product_prod(C,B)))),aa(set(product_prod(product_prod(C,D),product_prod(C,D))),fun(set(product_prod(product_prod(C,B),product_prod(C,B))),product_prod(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(C,B),product_prod(C,B))))),product_Pair(set(product_prod(product_prod(C,D),product_prod(C,D))),set(product_prod(product_prod(C,B),product_prod(C,B)))),bNF_Cardinal_Csum(C,D,bNF_Ca6860139660246222851ard_of(C,I4),aTP_Lamp_vd(fun(C,set(D)),fun(C,set(product_prod(D,D))),A4))),bNF_Cardinal_cprod(C,B,bNF_Ca6860139660246222851ard_of(C,I4),R)),bNF_Wellorder_ordLeq(product_prod(C,D),product_prod(C,B))) ) ) ).

% card_of_Csum_Times'
tff(fact_5313_card__of__Csum__Times,axiom,
    ! [D: $tType,C: $tType,B: $tType,I4: set(B),A4: fun(B,set(C)),B5: set(D)] :
      ( ! [X3: B] :
          ( member(B,X3,I4)
         => member(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,aa(B,set(C),A4,X3))),bNF_Ca6860139660246222851ard_of(D,B5)),bNF_Wellorder_ordLeq(C,D)) )
     => member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D)))),aa(set(product_prod(product_prod(B,D),product_prod(B,D))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(product_prod(B,D),product_prod(B,D))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D))))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(product_prod(B,D),product_prod(B,D)))),bNF_Cardinal_Csum(B,C,bNF_Ca6860139660246222851ard_of(B,I4),aTP_Lamp_ve(fun(B,set(C)),fun(B,set(product_prod(C,C))),A4))),bNF_Cardinal_cprod(B,D,bNF_Ca6860139660246222851ard_of(B,I4),bNF_Ca6860139660246222851ard_of(D,B5))),bNF_Wellorder_ordLeq(product_prod(B,C),product_prod(B,D))) ) ).

% card_of_Csum_Times
tff(fact_5314_cprod__infinite1_H,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),P3: set(product_prod(C,C))] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( ( ~ member(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))),P3),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(C,C))
          & bNF_Ca8970107618336181345der_on(C,field2(C,P3),P3) )
       => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),P3),R),bNF_Wellorder_ordLeq(C,B))
         => member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(B,B))),bNF_Cardinal_cprod(B,C,R,P3)),R),bNF_Wellorder_ordIso(product_prod(B,C),B)) ) ) ) ).

% cprod_infinite1'
tff(fact_5315_czero__ordIso,axiom,
    ! [C: $tType,B: $tType] : member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Cardinal_czero(B)),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(B,C)) ).

% czero_ordIso
tff(fact_5316_cinfinite__not__czero,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca4139267488887388095finite(B,R)
     => ~ member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(B,C)) ) ).

% cinfinite_not_czero
tff(fact_5317_czeroE,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(B,C))
     => ( field2(B,R) = bot_bot(set(B)) ) ) ).

% czeroE
tff(fact_5318_card__of__ordIso__czero__iff__empty,axiom,
    ! [C: $tType,B: $tType,A4: set(B)] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(B,C))
    <=> ( A4 = bot_bot(set(B)) ) ) ).

% card_of_ordIso_czero_iff_empty
tff(fact_5319_czeroI,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ( field2(B,R) = bot_bot(set(B)) )
       => member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(B,C)) ) ) ).

% czeroI
tff(fact_5320_Cnotzero__imp__not__empty,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( field2(B,R) != bot_bot(set(B)) ) ) ).

% Cnotzero_imp_not_empty
tff(fact_5321_Cnotzero__mono,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),Q3: set(product_prod(C,C))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,Q3),Q3)
       => ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),R),Q3),bNF_Wellorder_ordLeq(B,C))
         => ( ~ member(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))),Q3),bNF_Cardinal_czero(C)),bNF_Wellorder_ordIso(C,C))
            & bNF_Ca8970107618336181345der_on(C,field2(C,Q3),Q3) ) ) ) ) ).

% Cnotzero_mono
tff(fact_5322_Cinfinite__Cnotzero,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) ) ) ).

% Cinfinite_Cnotzero
tff(fact_5323_Cnotzero__UNIV,axiom,
    ! [B: $tType] :
      ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),bNF_Ca6860139660246222851ard_of(B,top_top(set(B)))),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
      & bNF_Ca8970107618336181345der_on(B,field2(B,bNF_Ca6860139660246222851ard_of(B,top_top(set(B)))),bNF_Ca6860139660246222851ard_of(B,top_top(set(B)))) ) ).

% Cnotzero_UNIV
tff(fact_5324_cinfinite__cprod2,axiom,
    ! [B: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R1),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R1),R1) )
     => ( ( bNF_Ca4139267488887388095finite(C,R22)
          & bNF_Ca8970107618336181345der_on(C,field2(C,R22),R22) )
       => bNF_Ca4139267488887388095finite(product_prod(B,C),bNF_Cardinal_cprod(B,C,R1,R22)) ) ) ).

% cinfinite_cprod2
tff(fact_5325_Cinfinite__cprod2,axiom,
    ! [B: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R1),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R1),R1) )
     => ( ( bNF_Ca4139267488887388095finite(C,R22)
          & bNF_Ca8970107618336181345der_on(C,field2(C,R22),R22) )
       => ( bNF_Ca4139267488887388095finite(product_prod(B,C),bNF_Cardinal_cprod(B,C,R1,R22))
          & bNF_Ca8970107618336181345der_on(product_prod(B,C),field2(product_prod(B,C),bNF_Cardinal_cprod(B,C,R1,R22)),bNF_Cardinal_cprod(B,C,R1,R22)) ) ) ) ).

% Cinfinite_cprod2
tff(fact_5326_ordLeq__cprod2,axiom,
    ! [B: $tType,C: $tType,P12: set(product_prod(B,B)),P23: set(product_prod(C,C))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),P12),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,P12),P12) )
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,P23),P23)
       => member(product_prod(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C)))),aa(set(product_prod(C,C)),fun(set(product_prod(product_prod(B,C),product_prod(B,C))),product_prod(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C))))),product_Pair(set(product_prod(C,C)),set(product_prod(product_prod(B,C),product_prod(B,C)))),P23),bNF_Cardinal_cprod(B,C,P12,P23)),bNF_Wellorder_ordLeq(C,product_prod(B,C))) ) ) ).

% ordLeq_cprod2
tff(fact_5327_cone__ordLeq__Cnotzero,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => member(product_prod(set(product_prod(product_unit,product_unit)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_unit,product_unit)),set(product_prod(B,B))),aa(set(product_prod(product_unit,product_unit)),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_unit,product_unit)),set(product_prod(B,B)))),product_Pair(set(product_prod(product_unit,product_unit)),set(product_prod(B,B))),bNF_Cardinal_cone),R),bNF_Wellorder_ordLeq(product_unit,B)) ) ).

% cone_ordLeq_Cnotzero
tff(fact_5328_csum__dup,axiom,
    ! [B: $tType,D: $tType,C: $tType,R: set(product_prod(B,B)),P3: set(product_prod(C,C)),P7: set(product_prod(D,D))] :
      ( bNF_Ca4139267488887388095finite(B,R)
     => ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
       => ( member(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),aa(set(product_prod(sum_sum(B,B),sum_sum(B,B))),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(sum_sum(B,B),sum_sum(B,B))),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(sum_sum(B,B),sum_sum(B,B))))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),bNF_Cardinal_csum(C,D,P3,P7)),bNF_Cardinal_csum(B,B,R,R)),bNF_Wellorder_ordIso(sum_sum(C,D),sum_sum(B,B)))
         => member(product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,D),sum_sum(C,D))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,D),sum_sum(C,D))),set(product_prod(B,B))),bNF_Cardinal_csum(C,D,P3,P7)),R),bNF_Wellorder_ordIso(sum_sum(C,D),B)) ) ) ) ).

% csum_dup
tff(fact_5329_csum__Cnotzero1,axiom,
    ! [B: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R1),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R1),R1) )
     => ( ~ member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C))))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),bNF_Cardinal_csum(B,C,R1,R22)),bNF_Cardinal_czero(sum_sum(B,C))),bNF_Wellorder_ordIso(sum_sum(B,C),sum_sum(B,C)))
        & bNF_Ca8970107618336181345der_on(sum_sum(B,C),field2(sum_sum(B,C),bNF_Cardinal_csum(B,C,R1,R22)),bNF_Cardinal_csum(B,C,R1,R22)) ) ) ).

% csum_Cnotzero1
tff(fact_5330_csum__csum,axiom,
    ! [E: $tType,D: $tType,C: $tType,B: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),R33: set(product_prod(D,D)),R42: set(product_prod(E,E))] : member(product_prod(set(product_prod(sum_sum(sum_sum(B,C),sum_sum(D,E)),sum_sum(sum_sum(B,C),sum_sum(D,E)))),set(product_prod(sum_sum(sum_sum(B,D),sum_sum(C,E)),sum_sum(sum_sum(B,D),sum_sum(C,E))))),aa(set(product_prod(sum_sum(sum_sum(B,D),sum_sum(C,E)),sum_sum(sum_sum(B,D),sum_sum(C,E)))),product_prod(set(product_prod(sum_sum(sum_sum(B,C),sum_sum(D,E)),sum_sum(sum_sum(B,C),sum_sum(D,E)))),set(product_prod(sum_sum(sum_sum(B,D),sum_sum(C,E)),sum_sum(sum_sum(B,D),sum_sum(C,E))))),aa(set(product_prod(sum_sum(sum_sum(B,C),sum_sum(D,E)),sum_sum(sum_sum(B,C),sum_sum(D,E)))),fun(set(product_prod(sum_sum(sum_sum(B,D),sum_sum(C,E)),sum_sum(sum_sum(B,D),sum_sum(C,E)))),product_prod(set(product_prod(sum_sum(sum_sum(B,C),sum_sum(D,E)),sum_sum(sum_sum(B,C),sum_sum(D,E)))),set(product_prod(sum_sum(sum_sum(B,D),sum_sum(C,E)),sum_sum(sum_sum(B,D),sum_sum(C,E)))))),product_Pair(set(product_prod(sum_sum(sum_sum(B,C),sum_sum(D,E)),sum_sum(sum_sum(B,C),sum_sum(D,E)))),set(product_prod(sum_sum(sum_sum(B,D),sum_sum(C,E)),sum_sum(sum_sum(B,D),sum_sum(C,E))))),bNF_Cardinal_csum(sum_sum(B,C),sum_sum(D,E),bNF_Cardinal_csum(B,C,R1,R22),bNF_Cardinal_csum(D,E,R33,R42))),bNF_Cardinal_csum(sum_sum(B,D),sum_sum(C,E),bNF_Cardinal_csum(B,D,R1,R33),bNF_Cardinal_csum(C,E,R22,R42))),bNF_Wellorder_ordIso(sum_sum(sum_sum(B,C),sum_sum(D,E)),sum_sum(sum_sum(B,D),sum_sum(C,E)))) ).

% csum_csum
tff(fact_5331_csum__assoc,axiom,
    ! [D: $tType,C: $tType,B: $tType,P12: set(product_prod(B,B)),P23: set(product_prod(C,C)),P32: set(product_prod(D,D))] : member(product_prod(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D))))),aa(set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D)))),product_prod(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D))))),aa(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),fun(set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D)))),product_prod(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D)))))),product_Pair(set(product_prod(sum_sum(sum_sum(B,C),D),sum_sum(sum_sum(B,C),D))),set(product_prod(sum_sum(B,sum_sum(C,D)),sum_sum(B,sum_sum(C,D))))),bNF_Cardinal_csum(sum_sum(B,C),D,bNF_Cardinal_csum(B,C,P12,P23),P32)),bNF_Cardinal_csum(B,sum_sum(C,D),P12,bNF_Cardinal_csum(C,D,P23,P32))),bNF_Wellorder_ordIso(sum_sum(sum_sum(B,C),D),sum_sum(B,sum_sum(C,D)))) ).

% csum_assoc
tff(fact_5332_cprod__csum__distrib1,axiom,
    ! [D: $tType,C: $tType,B: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),R33: set(product_prod(D,D))] : member(product_prod(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D))))),aa(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),product_prod(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D))))),aa(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),fun(set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))),product_prod(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D)))))),product_Pair(set(product_prod(sum_sum(product_prod(B,C),product_prod(B,D)),sum_sum(product_prod(B,C),product_prod(B,D)))),set(product_prod(product_prod(B,sum_sum(C,D)),product_prod(B,sum_sum(C,D))))),bNF_Cardinal_csum(product_prod(B,C),product_prod(B,D),bNF_Cardinal_cprod(B,C,R1,R22),bNF_Cardinal_cprod(B,D,R1,R33))),bNF_Cardinal_cprod(B,sum_sum(C,D),R1,bNF_Cardinal_csum(C,D,R22,R33))),bNF_Wellorder_ordIso(sum_sum(product_prod(B,C),product_prod(B,D)),product_prod(B,sum_sum(C,D)))) ).

% cprod_csum_distrib1
tff(fact_5333_cone__not__czero,axiom,
    ! [B: $tType] : ~ member(product_prod(set(product_prod(product_unit,product_unit)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(product_unit,product_unit)),set(product_prod(B,B))),aa(set(product_prod(product_unit,product_unit)),fun(set(product_prod(B,B)),product_prod(set(product_prod(product_unit,product_unit)),set(product_prod(B,B)))),product_Pair(set(product_prod(product_unit,product_unit)),set(product_prod(B,B))),bNF_Cardinal_cone),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(product_unit,B)) ).

% cone_not_czero
tff(fact_5334_csum__com,axiom,
    ! [C: $tType,B: $tType,P12: set(product_prod(B,B)),P23: set(product_prod(C,C))] : member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B))))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),bNF_Cardinal_csum(B,C,P12,P23)),bNF_Cardinal_csum(C,B,P23,P12)),bNF_Wellorder_ordIso(sum_sum(B,C),sum_sum(C,B))) ).

% csum_com
tff(fact_5335_Un__csum,axiom,
    ! [B: $tType,A4: set(B),B5: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),aa(set(product_prod(sum_sum(B,B),sum_sum(B,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(B,B),sum_sum(B,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(B,B),sum_sum(B,B)))),bNF_Ca6860139660246222851ard_of(B,aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),A4),B5))),bNF_Cardinal_csum(B,B,bNF_Ca6860139660246222851ard_of(B,A4),bNF_Ca6860139660246222851ard_of(B,B5))),bNF_Wellorder_ordLeq(B,sum_sum(B,B))) ).

% Un_csum
tff(fact_5336_ordLeq__csum1,axiom,
    ! [C: $tType,B: $tType,P12: set(product_prod(B,B)),P23: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,P12),P12)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),P12),bNF_Cardinal_csum(B,C,P12,P23)),bNF_Wellorder_ordLeq(B,sum_sum(B,C))) ) ).

% ordLeq_csum1
tff(fact_5337_ordLeq__csum2,axiom,
    ! [C: $tType,B: $tType,P23: set(product_prod(B,B)),P12: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,P23),P23)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),aa(set(product_prod(B,B)),fun(set(product_prod(sum_sum(C,B),sum_sum(C,B))),product_prod(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B))))),product_Pair(set(product_prod(B,B)),set(product_prod(sum_sum(C,B),sum_sum(C,B)))),P23),bNF_Cardinal_csum(C,B,P12,P23)),bNF_Wellorder_ordLeq(B,sum_sum(C,B))) ) ).

% ordLeq_csum2
tff(fact_5338_csum__cong,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordIso(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordIso(D,E))
       => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),bNF_Cardinal_csum(B,D,P12,P23)),bNF_Cardinal_csum(C,E,R1,R22)),bNF_Wellorder_ordIso(sum_sum(B,D),sum_sum(C,E))) ) ) ).

% csum_cong
tff(fact_5339_csum__cong1,axiom,
    ! [C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),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(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Cardinal_csum(B,D,P12,Q3)),bNF_Cardinal_csum(C,D,R1,Q3)),bNF_Wellorder_ordIso(sum_sum(B,D),sum_sum(C,D))) ) ).

% csum_cong1
tff(fact_5340_csum__cong2,axiom,
    ! [C: $tType,B: $tType,D: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordIso(B,C))
     => member(product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),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(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,B),sum_sum(D,B))),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Cardinal_csum(D,B,Q3,P23)),bNF_Cardinal_csum(D,C,Q3,R22)),bNF_Wellorder_ordIso(sum_sum(D,B),sum_sum(D,C))) ) ).

% csum_cong2
tff(fact_5341_csum__mono,axiom,
    ! [E: $tType,C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordLeq(D,E))
       => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,E),sum_sum(C,E))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,E),sum_sum(C,E)))),bNF_Cardinal_csum(B,D,P12,P23)),bNF_Cardinal_csum(C,E,R1,R22)),bNF_Wellorder_ordLeq(sum_sum(B,D),sum_sum(C,E))) ) ) ).

% csum_mono
tff(fact_5342_csum__mono1,axiom,
    ! [C: $tType,D: $tType,B: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),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(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(sum_sum(C,D),sum_sum(C,D))),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D))))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(sum_sum(C,D),sum_sum(C,D)))),bNF_Cardinal_csum(B,D,P12,Q3)),bNF_Cardinal_csum(C,D,R1,Q3)),bNF_Wellorder_ordLeq(sum_sum(B,D),sum_sum(C,D))) ) ).

% csum_mono1
tff(fact_5343_csum__mono2,axiom,
    ! [C: $tType,B: $tType,D: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordLeq(B,C))
     => member(product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),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(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),aa(set(product_prod(sum_sum(D,B),sum_sum(D,B))),fun(set(product_prod(sum_sum(D,C),sum_sum(D,C))),product_prod(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C))))),product_Pair(set(product_prod(sum_sum(D,B),sum_sum(D,B))),set(product_prod(sum_sum(D,C),sum_sum(D,C)))),bNF_Cardinal_csum(D,B,Q3,P23)),bNF_Cardinal_csum(D,C,Q3,R22)),bNF_Wellorder_ordLeq(sum_sum(D,B),sum_sum(D,C))) ) ).

% csum_mono2
tff(fact_5344_Plus__csum,axiom,
    ! [C: $tType,B: $tType,A4: set(B),B5: set(C)] : member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(sum_sum(B,C),sum_sum(B,C))),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C))))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(sum_sum(B,C),sum_sum(B,C)))),bNF_Ca6860139660246222851ard_of(sum_sum(B,C),sum_Plus(B,C,A4,B5))),bNF_Cardinal_csum(B,C,bNF_Ca6860139660246222851ard_of(B,A4),bNF_Ca6860139660246222851ard_of(C,B5))),bNF_Wellorder_ordIso(sum_sum(B,C),sum_sum(B,C))) ).

% Plus_csum
tff(fact_5345_csum__absorb2_H,axiom,
    ! [B: $tType,C: $tType,R22: set(product_prod(B,B)),R1: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R22),R22)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R1),R22),bNF_Wellorder_ordLeq(C,B))
       => ( ( bNF_Ca4139267488887388095finite(C,R1)
            | bNF_Ca4139267488887388095finite(B,R22) )
         => member(product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(C,B),sum_sum(C,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(C,B),sum_sum(C,B))),set(product_prod(B,B))),bNF_Cardinal_csum(C,B,R1,R22)),R22),bNF_Wellorder_ordIso(sum_sum(C,B),B)) ) ) ) ).

% csum_absorb2'
tff(fact_5346_csum__absorb1_H,axiom,
    ! [C: $tType,B: $tType,R22: set(product_prod(B,B)),R1: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R22),R22)
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R1),R22),bNF_Wellorder_ordLeq(C,B))
       => ( ( bNF_Ca4139267488887388095finite(C,R1)
            | bNF_Ca4139267488887388095finite(B,R22) )
         => member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),bNF_Cardinal_csum(B,C,R22,R1)),R22),bNF_Wellorder_ordIso(sum_sum(B,C),B)) ) ) ) ).

% csum_absorb1'
tff(fact_5347_csum__absorb1,axiom,
    ! [C: $tType,B: $tType,R22: set(product_prod(B,B)),R1: set(product_prod(C,C))] :
      ( ( bNF_Ca4139267488887388095finite(B,R22)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R22),R22) )
     => ( member(product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B))),aa(set(product_prod(C,C)),fun(set(product_prod(B,B)),product_prod(set(product_prod(C,C)),set(product_prod(B,B)))),product_Pair(set(product_prod(C,C)),set(product_prod(B,B))),R1),R22),bNF_Wellorder_ordLeq(C,B))
       => member(product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),aa(set(product_prod(sum_sum(B,C),sum_sum(B,C))),fun(set(product_prod(B,B)),product_prod(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B)))),product_Pair(set(product_prod(sum_sum(B,C),sum_sum(B,C))),set(product_prod(B,B))),bNF_Cardinal_csum(B,C,R22,R1)),R22),bNF_Wellorder_ordIso(sum_sum(B,C),B)) ) ) ).

% csum_absorb1
tff(fact_5348_csum__cinfinite__bound,axiom,
    ! [C: $tType,D: $tType,B: $tType,P3: set(product_prod(B,B)),R: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P3),R),bNF_Wellorder_ordLeq(B,C))
     => ( member(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))),Q3),R),bNF_Wellorder_ordLeq(D,C))
       => ( bNF_Ca8970107618336181345der_on(B,field2(B,P3),P3)
         => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
           => ( ( bNF_Ca4139267488887388095finite(C,R)
                & bNF_Ca8970107618336181345der_on(C,field2(C,R),R) )
             => member(product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(C,C))),aa(set(product_prod(sum_sum(B,D),sum_sum(B,D))),fun(set(product_prod(C,C)),product_prod(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(C,C)))),product_Pair(set(product_prod(sum_sum(B,D),sum_sum(B,D))),set(product_prod(C,C))),bNF_Cardinal_csum(B,D,P3,Q3)),R),bNF_Wellorder_ordLeq(sum_sum(B,D),C)) ) ) ) ) ) ).

% csum_cinfinite_bound
tff(fact_5349_natLeq__ordLeq__cinfinite,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => member(product_prod(set(product_prod(nat,nat)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(nat,nat)),set(product_prod(B,B))),aa(set(product_prod(nat,nat)),fun(set(product_prod(B,B)),product_prod(set(product_prod(nat,nat)),set(product_prod(B,B)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(B,B))),bNF_Ca8665028551170535155natLeq),R),bNF_Wellorder_ordLeq(nat,B)) ) ).

% natLeq_ordLeq_cinfinite
tff(fact_5350_cexp__mono2__Cnotzero,axiom,
    ! [C: $tType,D: $tType,B: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
       => ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),P23),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
            & bNF_Ca8970107618336181345der_on(B,field2(B,P23),P23) )
         => member(product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(B,D),fun(B,D))),fun(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D))))),product_Pair(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),bNF_Cardinal_cexp(D,B,Q3,P23)),bNF_Cardinal_cexp(D,C,Q3,R22)),bNF_Wellorder_ordLeq(fun(B,D),fun(C,D))) ) ) ) ).

% cexp_mono2_Cnotzero
tff(fact_5351_cexp__mono2,axiom,
    ! [E: $tType,F4: $tType,C: $tType,D: $tType,B: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
       => ( ( member(product_prod(set(product_prod(B,B)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(B,B)),set(product_prod(E,E))),aa(set(product_prod(B,B)),fun(set(product_prod(E,E)),product_prod(set(product_prod(B,B)),set(product_prod(E,E)))),product_Pair(set(product_prod(B,B)),set(product_prod(E,E))),P23),bNF_Cardinal_czero(E)),bNF_Wellorder_ordIso(B,E))
           => member(product_prod(set(product_prod(C,C)),set(product_prod(F4,F4))),aa(set(product_prod(F4,F4)),product_prod(set(product_prod(C,C)),set(product_prod(F4,F4))),aa(set(product_prod(C,C)),fun(set(product_prod(F4,F4)),product_prod(set(product_prod(C,C)),set(product_prod(F4,F4)))),product_Pair(set(product_prod(C,C)),set(product_prod(F4,F4))),R22),bNF_Cardinal_czero(F4)),bNF_Wellorder_ordIso(C,F4)) )
         => ( bNF_Ca8970107618336181345der_on(B,field2(B,P23),P23)
           => member(product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(B,D),fun(B,D))),fun(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D))))),product_Pair(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),bNF_Cardinal_cexp(D,B,Q3,P23)),bNF_Cardinal_cexp(D,C,Q3,R22)),bNF_Wellorder_ordLeq(fun(B,D),fun(C,D))) ) ) ) ) ).

% cexp_mono2
tff(fact_5352_cprod__cexp,axiom,
    ! [D: $tType,C: $tType,B: $tType,R: set(product_prod(C,C)),S: set(product_prod(D,D)),T2: set(product_prod(B,B))] : member(product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D))))),aa(set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D)))),product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D))))),aa(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),fun(set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D)))),product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D)))))),product_Pair(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D))))),bNF_Cardinal_cexp(product_prod(C,D),B,bNF_Cardinal_cprod(C,D,R,S),T2)),bNF_Cardinal_cprod(fun(B,C),fun(B,D),bNF_Cardinal_cexp(C,B,R,T2),bNF_Cardinal_cexp(D,B,S,T2))),bNF_Wellorder_ordIso(fun(B,product_prod(C,D)),product_prod(fun(B,C),fun(B,D)))) ).

% cprod_cexp
tff(fact_5353_cexp__cprod,axiom,
    ! [B: $tType,D: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(D,D)),R33: set(product_prod(C,C))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R1),R1)
     => member(product_prod(set(product_prod(fun(C,fun(D,B)),fun(C,fun(D,B)))),set(product_prod(fun(product_prod(D,C),B),fun(product_prod(D,C),B)))),aa(set(product_prod(fun(product_prod(D,C),B),fun(product_prod(D,C),B))),product_prod(set(product_prod(fun(C,fun(D,B)),fun(C,fun(D,B)))),set(product_prod(fun(product_prod(D,C),B),fun(product_prod(D,C),B)))),aa(set(product_prod(fun(C,fun(D,B)),fun(C,fun(D,B)))),fun(set(product_prod(fun(product_prod(D,C),B),fun(product_prod(D,C),B))),product_prod(set(product_prod(fun(C,fun(D,B)),fun(C,fun(D,B)))),set(product_prod(fun(product_prod(D,C),B),fun(product_prod(D,C),B))))),product_Pair(set(product_prod(fun(C,fun(D,B)),fun(C,fun(D,B)))),set(product_prod(fun(product_prod(D,C),B),fun(product_prod(D,C),B)))),bNF_Cardinal_cexp(fun(D,B),C,bNF_Cardinal_cexp(B,D,R1,R22),R33)),bNF_Cardinal_cexp(B,product_prod(D,C),R1,bNF_Cardinal_cprod(D,C,R22,R33))),bNF_Wellorder_ordIso(fun(C,fun(D,B)),fun(product_prod(D,C),B))) ) ).

% cexp_cprod
tff(fact_5354_cprod__cexp__csum__cexp__Cinfinite,axiom,
    ! [D: $tType,C: $tType,B: $tType,T2: set(product_prod(B,B)),R: set(product_prod(C,C)),S: set(product_prod(D,D))] :
      ( ( bNF_Ca4139267488887388095finite(B,T2)
        & bNF_Ca8970107618336181345der_on(B,field2(B,T2),T2) )
     => member(product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(fun(B,sum_sum(C,D)),fun(B,sum_sum(C,D))))),aa(set(product_prod(fun(B,sum_sum(C,D)),fun(B,sum_sum(C,D)))),product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(fun(B,sum_sum(C,D)),fun(B,sum_sum(C,D))))),aa(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),fun(set(product_prod(fun(B,sum_sum(C,D)),fun(B,sum_sum(C,D)))),product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(fun(B,sum_sum(C,D)),fun(B,sum_sum(C,D)))))),product_Pair(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(fun(B,sum_sum(C,D)),fun(B,sum_sum(C,D))))),bNF_Cardinal_cexp(product_prod(C,D),B,bNF_Cardinal_cprod(C,D,R,S),T2)),bNF_Cardinal_cexp(sum_sum(C,D),B,bNF_Cardinal_csum(C,D,R,S),T2)),bNF_Wellorder_ordLeq(fun(B,product_prod(C,D)),fun(B,sum_sum(C,D)))) ) ).

% cprod_cexp_csum_cexp_Cinfinite
tff(fact_5355_card__of__Field__natLeq,axiom,
    member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),bNF_Ca6860139660246222851ard_of(nat,field2(nat,bNF_Ca8665028551170535155natLeq))),bNF_Ca8665028551170535155natLeq),bNF_Wellorder_ordIso(nat,nat)) ).

% card_of_Field_natLeq
tff(fact_5356_cexp__cone,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(fun(product_unit,B),fun(product_unit,B))),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(fun(product_unit,B),fun(product_unit,B))),set(product_prod(B,B))),aa(set(product_prod(fun(product_unit,B),fun(product_unit,B))),fun(set(product_prod(B,B)),product_prod(set(product_prod(fun(product_unit,B),fun(product_unit,B))),set(product_prod(B,B)))),product_Pair(set(product_prod(fun(product_unit,B),fun(product_unit,B))),set(product_prod(B,B))),bNF_Cardinal_cexp(B,product_unit,R,bNF_Cardinal_cone)),R),bNF_Wellorder_ordIso(fun(product_unit,B),B)) ) ).

% cexp_cone
tff(fact_5357_finite__iff__ordLess__natLeq,axiom,
    ! [B: $tType,A4: set(B)] :
      ( finite_finite2(B,A4)
    <=> member(product_prod(set(product_prod(B,B)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(B,B)),set(product_prod(nat,nat))),aa(set(product_prod(B,B)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(B,B)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(B,B)),set(product_prod(nat,nat))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca8665028551170535155natLeq),bNF_We4044943003108391690rdLess(B,nat)) ) ).

% finite_iff_ordLess_natLeq
tff(fact_5358_cexp__cprod__ordLeq,axiom,
    ! [B: $tType,C: $tType,D: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),R33: set(product_prod(D,D))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R1),R1)
     => ( ( bNF_Ca4139267488887388095finite(C,R22)
          & bNF_Ca8970107618336181345der_on(C,field2(C,R22),R22) )
       => ( ( ~ member(product_prod(set(product_prod(D,D)),set(product_prod(D,D))),aa(set(product_prod(D,D)),product_prod(set(product_prod(D,D)),set(product_prod(D,D))),aa(set(product_prod(D,D)),fun(set(product_prod(D,D)),product_prod(set(product_prod(D,D)),set(product_prod(D,D)))),product_Pair(set(product_prod(D,D)),set(product_prod(D,D))),R33),bNF_Cardinal_czero(D)),bNF_Wellorder_ordIso(D,D))
            & bNF_Ca8970107618336181345der_on(D,field2(D,R33),R33) )
         => ( member(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))),R33),R22),bNF_Wellorder_ordLeq(D,C))
           => member(product_prod(set(product_prod(fun(D,fun(C,B)),fun(D,fun(C,B)))),set(product_prod(fun(C,B),fun(C,B)))),aa(set(product_prod(fun(C,B),fun(C,B))),product_prod(set(product_prod(fun(D,fun(C,B)),fun(D,fun(C,B)))),set(product_prod(fun(C,B),fun(C,B)))),aa(set(product_prod(fun(D,fun(C,B)),fun(D,fun(C,B)))),fun(set(product_prod(fun(C,B),fun(C,B))),product_prod(set(product_prod(fun(D,fun(C,B)),fun(D,fun(C,B)))),set(product_prod(fun(C,B),fun(C,B))))),product_Pair(set(product_prod(fun(D,fun(C,B)),fun(D,fun(C,B)))),set(product_prod(fun(C,B),fun(C,B)))),bNF_Cardinal_cexp(fun(C,B),D,bNF_Cardinal_cexp(B,C,R1,R22),R33)),bNF_Cardinal_cexp(B,C,R1,R22)),bNF_Wellorder_ordIso(fun(D,fun(C,B)),fun(C,B))) ) ) ) ) ).

% cexp_cprod_ordLeq
tff(fact_5359_cexp__mono_H,axiom,
    ! [C: $tType,E: $tType,B: $tType,D: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordLeq(D,E))
       => ( ( ( field2(D,P23) = bot_bot(set(D)) )
           => ( field2(E,R22) = bot_bot(set(E)) ) )
         => member(product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),aa(set(product_prod(fun(E,C),fun(E,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),aa(set(product_prod(fun(D,B),fun(D,B))),fun(set(product_prod(fun(E,C),fun(E,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C))))),product_Pair(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),bNF_Cardinal_cexp(B,D,P12,P23)),bNF_Cardinal_cexp(C,E,R1,R22)),bNF_Wellorder_ordLeq(fun(D,B),fun(E,C))) ) ) ) ).

% cexp_mono'
tff(fact_5360_cexp__mono1,axiom,
    ! [C: $tType,B: $tType,D: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
       => member(product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C)))),aa(set(product_prod(fun(D,C),fun(D,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C)))),aa(set(product_prod(fun(D,B),fun(D,B))),fun(set(product_prod(fun(D,C),fun(D,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C))))),product_Pair(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C)))),bNF_Cardinal_cexp(B,D,P12,Q3)),bNF_Cardinal_cexp(C,D,R1,Q3)),bNF_Wellorder_ordLeq(fun(D,B),fun(D,C))) ) ) ).

% cexp_mono1
tff(fact_5361_cexp__cong2,axiom,
    ! [C: $tType,D: $tType,B: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordIso(B,C))
     => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
       => ( bNF_Ca8970107618336181345der_on(B,field2(B,P23),P23)
         => member(product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(B,D),fun(B,D))),fun(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D))))),product_Pair(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),bNF_Cardinal_cexp(D,B,Q3,P23)),bNF_Cardinal_cexp(D,C,Q3,R22)),bNF_Wellorder_ordIso(fun(B,D),fun(C,D))) ) ) ) ).

% cexp_cong2
tff(fact_5362_cexp__cong1,axiom,
    ! [C: $tType,B: $tType,D: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordIso(B,C))
     => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
       => member(product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C)))),aa(set(product_prod(fun(D,C),fun(D,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C)))),aa(set(product_prod(fun(D,B),fun(D,B))),fun(set(product_prod(fun(D,C),fun(D,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C))))),product_Pair(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(D,C),fun(D,C)))),bNF_Cardinal_cexp(B,D,P12,Q3)),bNF_Cardinal_cexp(C,D,R1,Q3)),bNF_Wellorder_ordIso(fun(D,B),fun(D,C))) ) ) ).

% cexp_cong1
tff(fact_5363_cexp__cong,axiom,
    ! [C: $tType,E: $tType,B: $tType,D: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordIso(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordIso(D,E))
       => ( bNF_Ca8970107618336181345der_on(E,field2(E,R22),R22)
         => ( bNF_Ca8970107618336181345der_on(D,field2(D,P23),P23)
           => member(product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),aa(set(product_prod(fun(E,C),fun(E,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),aa(set(product_prod(fun(D,B),fun(D,B))),fun(set(product_prod(fun(E,C),fun(E,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C))))),product_Pair(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),bNF_Cardinal_cexp(B,D,P12,P23)),bNF_Cardinal_cexp(C,E,R1,R22)),bNF_Wellorder_ordIso(fun(D,B),fun(E,C))) ) ) ) ) ).

% cexp_cong
tff(fact_5364_card__of__nat,axiom,
    member(product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod(nat,nat)),set(product_prod(nat,nat)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(nat,nat))),bNF_Ca6860139660246222851ard_of(nat,top_top(set(nat)))),bNF_Ca8665028551170535155natLeq),bNF_Wellorder_ordIso(nat,nat)) ).

% card_of_nat
tff(fact_5365_cexp__mono2_H,axiom,
    ! [C: $tType,D: $tType,B: $tType,P23: set(product_prod(B,B)),R22: set(product_prod(C,C)),Q3: set(product_prod(D,D))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P23),R22),bNF_Wellorder_ordLeq(B,C))
     => ( bNF_Ca8970107618336181345der_on(D,field2(D,Q3),Q3)
       => ( ( ( field2(B,P23) = bot_bot(set(B)) )
           => ( field2(C,R22) = bot_bot(set(C)) ) )
         => member(product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),aa(set(product_prod(fun(B,D),fun(B,D))),fun(set(product_prod(fun(C,D),fun(C,D))),product_prod(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D))))),product_Pair(set(product_prod(fun(B,D),fun(B,D))),set(product_prod(fun(C,D),fun(C,D)))),bNF_Cardinal_cexp(D,B,Q3,P23)),bNF_Cardinal_cexp(D,C,Q3,R22)),bNF_Wellorder_ordLeq(fun(B,D),fun(C,D))) ) ) ) ).

% cexp_mono2'
tff(fact_5366_ordLeq__cexp1,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),Q3: set(product_prod(C,C))] :
      ( ( ~ member(product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),product_prod(set(product_prod(B,B)),set(product_prod(B,B)))),product_Pair(set(product_prod(B,B)),set(product_prod(B,B))),R),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso(B,B))
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,Q3),Q3)
       => member(product_prod(set(product_prod(C,C)),set(product_prod(fun(B,C),fun(B,C)))),aa(set(product_prod(fun(B,C),fun(B,C))),product_prod(set(product_prod(C,C)),set(product_prod(fun(B,C),fun(B,C)))),aa(set(product_prod(C,C)),fun(set(product_prod(fun(B,C),fun(B,C))),product_prod(set(product_prod(C,C)),set(product_prod(fun(B,C),fun(B,C))))),product_Pair(set(product_prod(C,C)),set(product_prod(fun(B,C),fun(B,C)))),Q3),bNF_Cardinal_cexp(C,B,Q3,R)),bNF_Wellorder_ordLeq(C,fun(B,C))) ) ) ).

% ordLeq_cexp1
tff(fact_5367_infinite__iff__natLeq__ordLeq,axiom,
    ! [B: $tType,A4: set(B)] :
      ~ ( finite_finite2(B,A4)
      <=> member(product_prod(set(product_prod(nat,nat)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod(nat,nat)),set(product_prod(B,B))),aa(set(product_prod(nat,nat)),fun(set(product_prod(B,B)),product_prod(set(product_prod(nat,nat)),set(product_prod(B,B)))),product_Pair(set(product_prod(nat,nat)),set(product_prod(B,B))),bNF_Ca8665028551170535155natLeq),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Wellorder_ordLeq(nat,B)) ) ).

% infinite_iff_natLeq_ordLeq
tff(fact_5368_cexp__mono,axiom,
    ! [F4: $tType,G2: $tType,C: $tType,E: $tType,B: $tType,D: $tType,P12: set(product_prod(B,B)),R1: set(product_prod(C,C)),P23: set(product_prod(D,D)),R22: set(product_prod(E,E))] :
      ( member(product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(set(product_prod(C,C)),product_prod(set(product_prod(B,B)),set(product_prod(C,C)))),product_Pair(set(product_prod(B,B)),set(product_prod(C,C))),P12),R1),bNF_Wellorder_ordLeq(B,C))
     => ( member(product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E))),aa(set(product_prod(D,D)),fun(set(product_prod(E,E)),product_prod(set(product_prod(D,D)),set(product_prod(E,E)))),product_Pair(set(product_prod(D,D)),set(product_prod(E,E))),P23),R22),bNF_Wellorder_ordLeq(D,E))
       => ( ( member(product_prod(set(product_prod(D,D)),set(product_prod(F4,F4))),aa(set(product_prod(F4,F4)),product_prod(set(product_prod(D,D)),set(product_prod(F4,F4))),aa(set(product_prod(D,D)),fun(set(product_prod(F4,F4)),product_prod(set(product_prod(D,D)),set(product_prod(F4,F4)))),product_Pair(set(product_prod(D,D)),set(product_prod(F4,F4))),P23),bNF_Cardinal_czero(F4)),bNF_Wellorder_ordIso(D,F4))
           => member(product_prod(set(product_prod(E,E)),set(product_prod(G2,G2))),aa(set(product_prod(G2,G2)),product_prod(set(product_prod(E,E)),set(product_prod(G2,G2))),aa(set(product_prod(E,E)),fun(set(product_prod(G2,G2)),product_prod(set(product_prod(E,E)),set(product_prod(G2,G2)))),product_Pair(set(product_prod(E,E)),set(product_prod(G2,G2))),R22),bNF_Cardinal_czero(G2)),bNF_Wellorder_ordIso(E,G2)) )
         => ( bNF_Ca8970107618336181345der_on(D,field2(D,P23),P23)
           => member(product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),aa(set(product_prod(fun(E,C),fun(E,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),aa(set(product_prod(fun(D,B),fun(D,B))),fun(set(product_prod(fun(E,C),fun(E,C))),product_prod(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C))))),product_Pair(set(product_prod(fun(D,B),fun(D,B))),set(product_prod(fun(E,C),fun(E,C)))),bNF_Cardinal_cexp(B,D,P12,P23)),bNF_Cardinal_cexp(C,E,R1,R22)),bNF_Wellorder_ordLeq(fun(D,B),fun(E,C))) ) ) ) ) ).

% cexp_mono
tff(fact_5369_ordLeq__cexp2,axiom,
    ! [B: $tType,C: $tType,Q3: set(product_prod(B,B)),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Cardinal_ctwo),Q3),bNF_Wellorder_ordLeq($o,B))
     => ( bNF_Ca8970107618336181345der_on(C,field2(C,R),R)
       => member(product_prod(set(product_prod(C,C)),set(product_prod(fun(C,B),fun(C,B)))),aa(set(product_prod(fun(C,B),fun(C,B))),product_prod(set(product_prod(C,C)),set(product_prod(fun(C,B),fun(C,B)))),aa(set(product_prod(C,C)),fun(set(product_prod(fun(C,B),fun(C,B))),product_prod(set(product_prod(C,C)),set(product_prod(fun(C,B),fun(C,B))))),product_Pair(set(product_prod(C,C)),set(product_prod(fun(C,B),fun(C,B)))),R),bNF_Cardinal_cexp(B,C,Q3,R)),bNF_Wellorder_ordLeq(C,fun(C,B))) ) ) ).

% ordLeq_cexp2
tff(fact_5370_Cfinite__cexp__Cinfinite,axiom,
    ! [B: $tType,C: $tType,S: set(product_prod(B,B)),T2: set(product_prod(C,C))] :
      ( ( bNF_Cardinal_cfinite(B,S)
        & bNF_Ca8970107618336181345der_on(B,field2(B,S),S) )
     => ( ( bNF_Ca4139267488887388095finite(C,T2)
          & bNF_Ca8970107618336181345der_on(C,field2(C,T2),T2) )
       => member(product_prod(set(product_prod(fun(C,B),fun(C,B))),set(product_prod(fun(C,$o),fun(C,$o)))),aa(set(product_prod(fun(C,$o),fun(C,$o))),product_prod(set(product_prod(fun(C,B),fun(C,B))),set(product_prod(fun(C,$o),fun(C,$o)))),aa(set(product_prod(fun(C,B),fun(C,B))),fun(set(product_prod(fun(C,$o),fun(C,$o))),product_prod(set(product_prod(fun(C,B),fun(C,B))),set(product_prod(fun(C,$o),fun(C,$o))))),product_Pair(set(product_prod(fun(C,B),fun(C,B))),set(product_prod(fun(C,$o),fun(C,$o)))),bNF_Cardinal_cexp(B,C,S,T2)),bNF_Cardinal_cexp($o,C,bNF_Cardinal_ctwo,T2)),bNF_Wellorder_ordLeq(fun(C,B),fun(C,$o))) ) ) ).

% Cfinite_cexp_Cinfinite
tff(fact_5371_cinfinite__cexp,axiom,
    ! [B: $tType,C: $tType,Q3: set(product_prod(B,B)),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Cardinal_ctwo),Q3),bNF_Wellorder_ordLeq($o,B))
     => ( ( bNF_Ca4139267488887388095finite(C,R)
          & bNF_Ca8970107618336181345der_on(C,field2(C,R),R) )
       => bNF_Ca4139267488887388095finite(fun(C,B),bNF_Cardinal_cexp(B,C,Q3,R)) ) ) ).

% cinfinite_cexp
tff(fact_5372_ctwo__Cnotzero,axiom,
    ( ~ member(product_prod(set(product_prod($o,$o)),set(product_prod($o,$o))),aa(set(product_prod($o,$o)),product_prod(set(product_prod($o,$o)),set(product_prod($o,$o))),aa(set(product_prod($o,$o)),fun(set(product_prod($o,$o)),product_prod(set(product_prod($o,$o)),set(product_prod($o,$o)))),product_Pair(set(product_prod($o,$o)),set(product_prod($o,$o))),bNF_Cardinal_ctwo),bNF_Cardinal_czero($o)),bNF_Wellorder_ordIso($o,$o))
    & bNF_Ca8970107618336181345der_on($o,field2($o,bNF_Cardinal_ctwo),bNF_Cardinal_ctwo) ) ).

% ctwo_Cnotzero
tff(fact_5373_ctwo__ordLess__natLeq,axiom,
    member(product_prod(set(product_prod($o,$o)),set(product_prod(nat,nat))),aa(set(product_prod(nat,nat)),product_prod(set(product_prod($o,$o)),set(product_prod(nat,nat))),aa(set(product_prod($o,$o)),fun(set(product_prod(nat,nat)),product_prod(set(product_prod($o,$o)),set(product_prod(nat,nat)))),product_Pair(set(product_prod($o,$o)),set(product_prod(nat,nat))),bNF_Cardinal_ctwo),bNF_Ca8665028551170535155natLeq),bNF_We4044943003108391690rdLess($o,nat)) ).

% ctwo_ordLess_natLeq
tff(fact_5374_ordLess__ctwo__cexp,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(fun(B,$o),fun(B,$o)))),aa(set(product_prod(fun(B,$o),fun(B,$o))),product_prod(set(product_prod(B,B)),set(product_prod(fun(B,$o),fun(B,$o)))),aa(set(product_prod(B,B)),fun(set(product_prod(fun(B,$o),fun(B,$o))),product_prod(set(product_prod(B,B)),set(product_prod(fun(B,$o),fun(B,$o))))),product_Pair(set(product_prod(B,B)),set(product_prod(fun(B,$o),fun(B,$o)))),R),bNF_Cardinal_cexp($o,B,bNF_Cardinal_ctwo,R)),bNF_We4044943003108391690rdLess(B,fun(B,$o))) ) ).

% ordLess_ctwo_cexp
tff(fact_5375_cprod__csum__cexp,axiom,
    ! [C: $tType,B: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C))] : member(product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(fun($o,sum_sum(B,C)),fun($o,sum_sum(B,C))))),aa(set(product_prod(fun($o,sum_sum(B,C)),fun($o,sum_sum(B,C)))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(fun($o,sum_sum(B,C)),fun($o,sum_sum(B,C))))),aa(set(product_prod(product_prod(B,C),product_prod(B,C))),fun(set(product_prod(fun($o,sum_sum(B,C)),fun($o,sum_sum(B,C)))),product_prod(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(fun($o,sum_sum(B,C)),fun($o,sum_sum(B,C)))))),product_Pair(set(product_prod(product_prod(B,C),product_prod(B,C))),set(product_prod(fun($o,sum_sum(B,C)),fun($o,sum_sum(B,C))))),bNF_Cardinal_cprod(B,C,R1,R22)),bNF_Cardinal_cexp(sum_sum(B,C),$o,bNF_Cardinal_csum(B,C,R1,R22),bNF_Cardinal_ctwo)),bNF_Wellorder_ordLeq(product_prod(B,C),fun($o,sum_sum(B,C)))) ).

% cprod_csum_cexp
tff(fact_5376_ctwo__not__czero,axiom,
    ! [B: $tType] : ~ member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Cardinal_ctwo),bNF_Cardinal_czero(B)),bNF_Wellorder_ordIso($o,B)) ).

% ctwo_not_czero
tff(fact_5377_ctwo__ordLeq__Cinfinite,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Cardinal_ctwo),R),bNF_Wellorder_ordLeq($o,B)) ) ).

% ctwo_ordLeq_Cinfinite
tff(fact_5378_ctwo__ordLess__Cinfinite,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( ( bNF_Ca4139267488887388095finite(B,R)
        & bNF_Ca8970107618336181345der_on(B,field2(B,R),R) )
     => member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Cardinal_ctwo),R),bNF_We4044943003108391690rdLess($o,B)) ) ).

% ctwo_ordLess_Cinfinite
tff(fact_5379_csum__Cfinite__cexp__Cinfinite,axiom,
    ! [C: $tType,B: $tType,D: $tType,R: set(product_prod(B,B)),S: set(product_prod(C,C)),T2: set(product_prod(D,D))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => ( ( bNF_Cardinal_cfinite(C,S)
          & bNF_Ca8970107618336181345der_on(C,field2(C,S),S) )
       => ( ( bNF_Ca4139267488887388095finite(D,T2)
            & bNF_Ca8970107618336181345der_on(D,field2(D,T2),T2) )
         => member(product_prod(set(product_prod(fun(D,sum_sum(B,C)),fun(D,sum_sum(B,C)))),set(product_prod(fun(D,sum_sum(B,$o)),fun(D,sum_sum(B,$o))))),aa(set(product_prod(fun(D,sum_sum(B,$o)),fun(D,sum_sum(B,$o)))),product_prod(set(product_prod(fun(D,sum_sum(B,C)),fun(D,sum_sum(B,C)))),set(product_prod(fun(D,sum_sum(B,$o)),fun(D,sum_sum(B,$o))))),aa(set(product_prod(fun(D,sum_sum(B,C)),fun(D,sum_sum(B,C)))),fun(set(product_prod(fun(D,sum_sum(B,$o)),fun(D,sum_sum(B,$o)))),product_prod(set(product_prod(fun(D,sum_sum(B,C)),fun(D,sum_sum(B,C)))),set(product_prod(fun(D,sum_sum(B,$o)),fun(D,sum_sum(B,$o)))))),product_Pair(set(product_prod(fun(D,sum_sum(B,C)),fun(D,sum_sum(B,C)))),set(product_prod(fun(D,sum_sum(B,$o)),fun(D,sum_sum(B,$o))))),bNF_Cardinal_cexp(sum_sum(B,C),D,bNF_Cardinal_csum(B,C,R,S),T2)),bNF_Cardinal_cexp(sum_sum(B,$o),D,bNF_Cardinal_csum(B,$o,R,bNF_Cardinal_ctwo),T2)),bNF_Wellorder_ordLeq(fun(D,sum_sum(B,C)),fun(D,sum_sum(B,$o)))) ) ) ) ).

% csum_Cfinite_cexp_Cinfinite
tff(fact_5380_Cinfinite__cexp,axiom,
    ! [B: $tType,C: $tType,Q3: set(product_prod(B,B)),R: set(product_prod(C,C))] :
      ( member(product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B))),aa(set(product_prod($o,$o)),fun(set(product_prod(B,B)),product_prod(set(product_prod($o,$o)),set(product_prod(B,B)))),product_Pair(set(product_prod($o,$o)),set(product_prod(B,B))),bNF_Cardinal_ctwo),Q3),bNF_Wellorder_ordLeq($o,B))
     => ( ( bNF_Ca4139267488887388095finite(C,R)
          & bNF_Ca8970107618336181345der_on(C,field2(C,R),R) )
       => ( bNF_Ca4139267488887388095finite(fun(C,B),bNF_Cardinal_cexp(B,C,Q3,R))
          & bNF_Ca8970107618336181345der_on(fun(C,B),field2(fun(C,B),bNF_Cardinal_cexp(B,C,Q3,R)),bNF_Cardinal_cexp(B,C,Q3,R)) ) ) ) ).

% Cinfinite_cexp
tff(fact_5381_card__of__Func__UNIV,axiom,
    ! [C: $tType,B: $tType,B5: set(C)] : member(product_prod(set(product_prod(fun(B,C),fun(B,C))),set(product_prod(fun(B,C),fun(B,C)))),aa(set(product_prod(fun(B,C),fun(B,C))),product_prod(set(product_prod(fun(B,C),fun(B,C))),set(product_prod(fun(B,C),fun(B,C)))),aa(set(product_prod(fun(B,C),fun(B,C))),fun(set(product_prod(fun(B,C),fun(B,C))),product_prod(set(product_prod(fun(B,C),fun(B,C))),set(product_prod(fun(B,C),fun(B,C))))),product_Pair(set(product_prod(fun(B,C),fun(B,C))),set(product_prod(fun(B,C),fun(B,C)))),bNF_Ca6860139660246222851ard_of(fun(B,C),bNF_Wellorder_Func(B,C,top_top(set(B)),B5))),bNF_Ca6860139660246222851ard_of(fun(B,C),aa(fun(fun(B,C),$o),set(fun(B,C)),collect(fun(B,C)),aTP_Lamp_uq(set(C),fun(fun(B,C),$o),B5)))),bNF_Wellorder_ordIso(fun(B,C),fun(B,C))) ).

% card_of_Func_UNIV
tff(fact_5382_Card__order__Pow,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( bNF_Ca8970107618336181345der_on(B,field2(B,R),R)
     => member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),R),bNF_Ca6860139660246222851ard_of(set(B),pow(B,field2(B,R)))),bNF_We4044943003108391690rdLess(B,set(B))) ) ).

% Card_order_Pow
tff(fact_5383_Func__Times__Range,axiom,
    ! [D: $tType,C: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] : member(product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D))))),aa(set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D)))),product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D))))),aa(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),fun(set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D)))),product_prod(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D)))))),product_Pair(set(product_prod(fun(B,product_prod(C,D)),fun(B,product_prod(C,D)))),set(product_prod(product_prod(fun(B,C),fun(B,D)),product_prod(fun(B,C),fun(B,D))))),bNF_Ca6860139660246222851ard_of(fun(B,product_prod(C,D)),bNF_Wellorder_Func(B,product_prod(C,D),A4,product_Sigma(C,D,B5,aTP_Lamp_mz(set(D),fun(C,set(D)),C5))))),bNF_Ca6860139660246222851ard_of(product_prod(fun(B,C),fun(B,D)),product_Sigma(fun(B,C),fun(B,D),bNF_Wellorder_Func(B,C,A4,B5),aa(set(D),fun(fun(B,C),set(fun(B,D))),aTP_Lamp_vf(set(B),fun(set(D),fun(fun(B,C),set(fun(B,D)))),A4),C5)))),bNF_Wellorder_ordIso(fun(B,product_prod(C,D)),product_prod(fun(B,C),fun(B,D)))) ).

% Func_Times_Range
tff(fact_5384_card__of__Func__Times,axiom,
    ! [D: $tType,C: $tType,B: $tType,A4: set(B),B5: set(C),C5: set(D)] : member(product_prod(set(product_prod(fun(product_prod(B,C),D),fun(product_prod(B,C),D))),set(product_prod(fun(B,fun(C,D)),fun(B,fun(C,D))))),aa(set(product_prod(fun(B,fun(C,D)),fun(B,fun(C,D)))),product_prod(set(product_prod(fun(product_prod(B,C),D),fun(product_prod(B,C),D))),set(product_prod(fun(B,fun(C,D)),fun(B,fun(C,D))))),aa(set(product_prod(fun(product_prod(B,C),D),fun(product_prod(B,C),D))),fun(set(product_prod(fun(B,fun(C,D)),fun(B,fun(C,D)))),product_prod(set(product_prod(fun(product_prod(B,C),D),fun(product_prod(B,C),D))),set(product_prod(fun(B,fun(C,D)),fun(B,fun(C,D)))))),product_Pair(set(product_prod(fun(product_prod(B,C),D),fun(product_prod(B,C),D))),set(product_prod(fun(B,fun(C,D)),fun(B,fun(C,D))))),bNF_Ca6860139660246222851ard_of(fun(product_prod(B,C),D),bNF_Wellorder_Func(product_prod(B,C),D,product_Sigma(B,C,A4,aTP_Lamp_jm(set(C),fun(B,set(C)),B5)),C5))),bNF_Ca6860139660246222851ard_of(fun(B,fun(C,D)),bNF_Wellorder_Func(B,fun(C,D),A4,bNF_Wellorder_Func(C,D,B5,C5)))),bNF_Wellorder_ordIso(fun(product_prod(B,C),D),fun(B,fun(C,D)))) ).

% card_of_Func_Times
tff(fact_5385_card__of__Pow__Func,axiom,
    ! [B: $tType,A4: set(B)] : member(product_prod(set(product_prod(set(B),set(B))),set(product_prod(fun(B,$o),fun(B,$o)))),aa(set(product_prod(fun(B,$o),fun(B,$o))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(fun(B,$o),fun(B,$o)))),aa(set(product_prod(set(B),set(B))),fun(set(product_prod(fun(B,$o),fun(B,$o))),product_prod(set(product_prod(set(B),set(B))),set(product_prod(fun(B,$o),fun(B,$o))))),product_Pair(set(product_prod(set(B),set(B))),set(product_prod(fun(B,$o),fun(B,$o)))),bNF_Ca6860139660246222851ard_of(set(B),pow(B,A4))),bNF_Ca6860139660246222851ard_of(fun(B,$o),bNF_Wellorder_Func(B,$o,A4,top_top(set($o))))),bNF_Wellorder_ordIso(set(B),fun(B,$o))) ).

% card_of_Pow_Func
tff(fact_5386_Cantors__paradox,axiom,
    ! [B: $tType,A4: set(B)] :
      ~ ? [F7: fun(B,set(B))] : aa(set(B),set(set(B)),image2(B,set(B),F7),A4) = pow(B,A4) ).

% Cantors_paradox
tff(fact_5387_inj__on__image__Pow,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,A4)
     => inj_on(set(B),set(C),image2(B,C,F),pow(B,A4)) ) ).

% inj_on_image_Pow
tff(fact_5388_card__of__Pow,axiom,
    ! [B: $tType,A4: set(B)] : member(product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),aa(set(product_prod(B,B)),fun(set(product_prod(set(B),set(B))),product_prod(set(product_prod(B,B)),set(product_prod(set(B),set(B))))),product_Pair(set(product_prod(B,B)),set(product_prod(set(B),set(B)))),bNF_Ca6860139660246222851ard_of(B,A4)),bNF_Ca6860139660246222851ard_of(set(B),pow(B,A4))),bNF_We4044943003108391690rdLess(B,set(B))) ).

% card_of_Pow
tff(fact_5389_lfp__induct2,axiom,
    ! [B: $tType,C: $tType,A3: B,B2: C,F: fun(set(product_prod(B,C)),set(product_prod(B,C))),P: fun(B,fun(C,$o))] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2),complete_lattice_lfp(set(product_prod(B,C)),F))
     => ( order_mono(set(product_prod(B,C)),set(product_prod(B,C)),F)
       => ( ! [A5: B,B3: C] :
              ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3),aa(set(product_prod(B,C)),set(product_prod(B,C)),F,aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),complete_lattice_lfp(set(product_prod(B,C)),F)),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),P)))))
             => aa(C,$o,aa(B,fun(C,$o),P,A5),B3) )
         => aa(C,$o,aa(B,fun(C,$o),P,A3),B2) ) ) ) ).

% lfp_induct2
tff(fact_5390_sort__quicksort__by__rel,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ( linorder_sort_key(B,B,aTP_Lamp_vg(B,B)) = quicksort_by_rel(B,ord_less_eq(B),nil(B)) ) ) ).

% sort_quicksort_by_rel
tff(fact_5391_Gr__def,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,C)] : bNF_Gr(B,C,A4,F) = aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,C),fun(product_prod(B,C),$o),aTP_Lamp_vh(set(B),fun(fun(B,C),fun(product_prod(B,C),$o)),A4),F)) ).

% Gr_def
tff(fact_5392_GrD2,axiom,
    ! [B: $tType,C: $tType,X2: B,Fx: C,A4: set(B),F: fun(B,C)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Fx),bNF_Gr(B,C,A4,F))
     => ( aa(B,C,F,X2) = Fx ) ) ).

% GrD2
tff(fact_5393_GrD1,axiom,
    ! [C: $tType,B: $tType,X2: B,Fx: C,A4: set(B),F: fun(B,C)] :
      ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Fx),bNF_Gr(B,C,A4,F))
     => member(B,X2,A4) ) ).

% GrD1
tff(fact_5394_sort__mergesort,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ( linorder_sort_key(B,B,aTP_Lamp_vg(B,B)) = mergesort(B) ) ) ).

% sort_mergesort
tff(fact_5395_sort__mergesort__by__rel,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ( linorder_sort_key(B,B,aTP_Lamp_vg(B,B)) = mergesort_by_rel(B,ord_less_eq(B)) ) ) ).

% sort_mergesort_by_rel
tff(fact_5396_remdup__sort__mergesort__remdups,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ( aa(fun(list(B),list(B)),fun(list(B),list(B)),aa(fun(list(B),list(B)),fun(fun(list(B),list(B)),fun(list(B),list(B))),comp(list(B),list(B),list(B)),remdups(B)),linorder_sort_key(B,B,aTP_Lamp_vg(B,B))) = mergesort_remdups(B) ) ) ).

% remdup_sort_mergesort_remdups
tff(fact_5397_prod_H__def,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ( groups1962203154675924110t_prod(B,C) = groups_comm_monoid_G(C,B,times_times(C),one_one(C)) ) ) ).

% prod'_def
tff(fact_5398_prod_Ocomm__monoid__list__set__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => groups4802862169904069756st_set(B,times_times(B),one_one(B)) ) ).

% prod.comm_monoid_list_set_axioms
tff(fact_5399_length__remdups__card,axiom,
    ! [B: $tType,L: list(B)] : aa(list(B),nat,size_size(list(B)),aa(list(B),list(B),remdups(B),L)) = finite_card(B,aa(list(B),set(B),set2(B),L)) ).

% length_remdups_card
tff(fact_5400_sum_H__def,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(C)
     => ( groups1027152243600224163dd_sum(B,C) = groups_comm_monoid_G(C,B,plus_plus(C),zero_zero(C)) ) ) ).

% sum'_def
tff(fact_5401_sum_Ocomm__monoid__list__set__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => groups4802862169904069756st_set(B,plus_plus(B),zero_zero(B)) ) ).

% sum.comm_monoid_list_set_axioms
tff(fact_5402_and_Ocomm__monoid__axioms,axiom,
    ! [B: $tType] :
      ( bit_ri3973907225187159222ations(B)
     => comm_monoid(B,bit_se5824344872417868541ns_and(B),aa(B,B,uminus_uminus(B),one_one(B))) ) ).

% and.comm_monoid_axioms
tff(fact_5403_bijective__alt,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C))] :
      ( bijective(B,C,R4)
    <=> ( single_valued(B,C,R4)
        & single_valued(C,B,converse(B,C,R4)) ) ) ).

% bijective_alt
tff(fact_5404_Heap_Osize__gen__o__map,axiom,
    ! [C: $tType,B: $tType,F: fun(C,nat),G: fun(B,C)] : aa(fun(heap_Time_Heap(B),heap_Time_Heap(C)),fun(heap_Time_Heap(B),nat),aa(fun(heap_Time_Heap(C),nat),fun(fun(heap_Time_Heap(B),heap_Time_Heap(C)),fun(heap_Time_Heap(B),nat)),comp(heap_Time_Heap(C),nat,heap_Time_Heap(B)),heap_Time_size_Heap(C,F)),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),G)) = heap_Time_size_Heap(B,aa(fun(B,C),fun(B,nat),aa(fun(C,nat),fun(fun(B,C),fun(B,nat)),comp(C,nat,B),F),G)) ).

% Heap.size_gen_o_map
tff(fact_5405_single__valued__inter1,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(B,C))] :
      ( single_valued(B,C,R4)
     => single_valued(B,C,aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),R4),S2)) ) ).

% single_valued_inter1
tff(fact_5406_single__valued__inter2,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,C)),S2: set(product_prod(B,C))] :
      ( single_valued(B,C,R4)
     => single_valued(B,C,aa(set(product_prod(B,C)),set(product_prod(B,C)),inf_inf(set(product_prod(B,C)),S2),R4)) ) ).

% single_valued_inter2
tff(fact_5407_comm__monoid_Ocomm__neutral,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,A3: B] :
      ( comm_monoid(B,F,Z2)
     => ( aa(B,B,aa(B,fun(B,B),F,A3),Z2) = A3 ) ) ).

% comm_monoid.comm_neutral
tff(fact_5408_Heap_Omap__ident,axiom,
    ! [B: $tType,T2: heap_Time_Heap(B)] : aa(heap_Time_Heap(B),heap_Time_Heap(B),aa(fun(B,B),fun(heap_Time_Heap(B),heap_Time_Heap(B)),heap_Time_map_Heap(B,B),aTP_Lamp_ay(B,B)),T2) = T2 ).

% Heap.map_ident
tff(fact_5409_Heap_Omap__id0,axiom,
    ! [B: $tType] : aa(fun(B,B),fun(heap_Time_Heap(B),heap_Time_Heap(B)),heap_Time_map_Heap(B,B),id(B)) = id(heap_Time_Heap(B)) ).

% Heap.map_id0
tff(fact_5410_Heap_Omap__id,axiom,
    ! [B: $tType,T2: heap_Time_Heap(B)] : aa(heap_Time_Heap(B),heap_Time_Heap(B),aa(fun(B,B),fun(heap_Time_Heap(B),heap_Time_Heap(B)),heap_Time_map_Heap(B,B),id(B)),T2) = T2 ).

% Heap.map_id
tff(fact_5411_Heap_Omap__comp,axiom,
    ! [C: $tType,B: $tType,D: $tType,G: fun(C,B),F: fun(D,C),V: heap_Time_Heap(D)] : aa(heap_Time_Heap(C),heap_Time_Heap(B),aa(fun(C,B),fun(heap_Time_Heap(C),heap_Time_Heap(B)),heap_Time_map_Heap(C,B),G),aa(heap_Time_Heap(D),heap_Time_Heap(C),aa(fun(D,C),fun(heap_Time_Heap(D),heap_Time_Heap(C)),heap_Time_map_Heap(D,C),F),V)) = aa(heap_Time_Heap(D),heap_Time_Heap(B),aa(fun(D,B),fun(heap_Time_Heap(D),heap_Time_Heap(B)),heap_Time_map_Heap(D,B),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),G),F)),V) ).

% Heap.map_comp
tff(fact_5412_Heap_Omap,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] : aa(heap_Time_Heap(C),heap_Time_Heap(B),aa(fun(C,B),fun(heap_Time_Heap(C),heap_Time_Heap(B)),heap_Time_map_Heap(C,B),F),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),X2)) = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),comp(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),aa(fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),map_option(product_prod(C,product_prod(heap_ext(product_unit),nat)),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_map_prod(C,B,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),F,id(product_prod(heap_ext(product_unit),nat))))),X2)) ).

% Heap.map
tff(fact_5413_single__valuedD,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,C)),X2: B,Y: C,Z2: C] :
      ( single_valued(B,C,R)
     => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Y),R)
       => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X2),Z2),R)
         => ( Y = Z2 ) ) ) ) ).

% single_valuedD
tff(fact_5414_single__valuedI,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C))] :
      ( ! [X3: B,Y4: C,Z3: C] :
          ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Y4),R)
         => ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X3),Z3),R)
           => ( Y4 = Z3 ) ) )
     => single_valued(B,C,R) ) ).

% single_valuedI
tff(fact_5415_single__valued__def,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,C))] :
      ( single_valued(B,C,R)
    <=> ! [X4: B,Y3: C] :
          ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Y3),R)
         => ! [Z4: C] :
              ( member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Z4),R)
             => ( Y3 = Z4 ) ) ) ) ).

% single_valued_def
tff(fact_5416_add_Ocomm__monoid__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => comm_monoid(B,plus_plus(B),zero_zero(B)) ) ).

% add.comm_monoid_axioms
tff(fact_5417_mult_Ocomm__monoid__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => comm_monoid(B,times_times(B),one_one(B)) ) ).

% mult.comm_monoid_axioms
tff(fact_5418_Heap_Oinj__map,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] :
      ( inj_on(B,C,F,top_top(set(B)))
     => inj_on(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),F),top_top(set(heap_Time_Heap(B)))) ) ).

% Heap.inj_map
tff(fact_5419_single__valued__confluent,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X2: B,Y: B,Z2: B] :
      ( single_valued(B,B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,R))
       => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Z2),transitive_rtrancl(B,R))
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),transitive_rtrancl(B,R))
            | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z2),Y),transitive_rtrancl(B,R)) ) ) ) ) ).

% single_valued_confluent
tff(fact_5420_single__valued__below__Id,axiom,
    ! [B: $tType,R4: set(product_prod(B,B))] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),R4),id2(B))
     => single_valued(B,B,R4) ) ).

% single_valued_below_Id
tff(fact_5421_Heap_Orec__o__map,axiom,
    ! [C: $tType,D: $tType,B: $tType,G: fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),F: fun(B,D)] : aa(fun(heap_Time_Heap(B),heap_Time_Heap(D)),fun(heap_Time_Heap(B),C),aa(fun(heap_Time_Heap(D),C),fun(fun(heap_Time_Heap(B),heap_Time_Heap(D)),fun(heap_Time_Heap(B),C)),comp(heap_Time_Heap(D),C,heap_Time_Heap(B)),aa(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(heap_Time_Heap(D),C),heap_Time_rec_Heap(D,C),G)),aa(fun(B,D),fun(heap_Time_Heap(B),heap_Time_Heap(D)),heap_Time_map_Heap(B,D),F)) = aa(fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),fun(heap_Time_Heap(B),C),heap_Time_rec_Heap(B,C),aa(fun(B,D),fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),aTP_Lamp_vi(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(B,D),fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C)),G),F)) ).

% Heap.rec_o_map
tff(fact_5422_single__valuedp__single__valued__eq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C))] :
      ( single_valuedp(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R))
    <=> single_valued(B,C,R) ) ).

% single_valuedp_single_valued_eq
tff(fact_5423_disjnt__equiv__class,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),A3: B,B2: B] :
      ( equiv_equiv(B,A4,R)
     => ( disjnt(B,image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))),image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))))
      <=> ~ member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R) ) ) ).

% disjnt_equiv_class
tff(fact_5424_equiv__class__eq__iff,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
      <=> ( ( image(B,B,R,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))) = image(B,B,R,aa(set(B),set(B),insert2(B,Y),bot_bot(set(B)))) )
          & member(B,X2,A4)
          & member(B,Y,A4) ) ) ) ).

% equiv_class_eq_iff
tff(fact_5425_eq__equiv__class__iff,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(B,X2,A4)
       => ( member(B,Y,A4)
         => ( ( image(B,B,R,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B)))) = image(B,B,R,aa(set(B),set(B),insert2(B,Y),bot_bot(set(B)))) )
          <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R) ) ) ) ) ).

% eq_equiv_class_iff
tff(fact_5426_equiv__class__eq,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),A3: B,B2: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => ( image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))) = image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))) ) ) ) ).

% equiv_class_eq
tff(fact_5427_eq__equiv__class,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B,A4: set(B)] :
      ( ( image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))) = image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B)))) )
     => ( equiv_equiv(B,A4,R)
       => ( member(B,B2,A4)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R) ) ) ) ).

% eq_equiv_class
tff(fact_5428_Heap_Orec,axiom,
    ! [B: $tType,C: $tType,F: fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),B),X2: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] : aa(heap_Time_Heap(C),B,aa(fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),B),fun(heap_Time_Heap(C),B),heap_Time_rec_Heap(C,B),F),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),X2)) = aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),B,F,X2) ).

% Heap.rec
tff(fact_5429_subset__equiv__class,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),B2: B,A3: B] :
      ( equiv_equiv(B,A4,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))),image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B)))))
       => ( member(B,B2,A4)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R) ) ) ) ).

% subset_equiv_class
tff(fact_5430_equiv__class__subset,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),A3: B,B2: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B))))),image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))) ) ) ).

% equiv_class_subset
tff(fact_5431_equiv__class__nondisjoint,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,A3: B,B2: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(B,X2,aa(set(B),set(B),inf_inf(set(B),image(B,B,R,aa(set(B),set(B),insert2(B,A3),bot_bot(set(B))))),image(B,B,R,aa(set(B),set(B),insert2(B,B2),bot_bot(set(B))))))
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R) ) ) ).

% equiv_class_nondisjoint
tff(fact_5432_proj__iff,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,X2),aa(set(B),set(B),insert2(B,Y),bot_bot(set(B))))),A4)
       => ( ( equiv_proj(B,B,R,X2) = equiv_proj(B,B,R,Y) )
        <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R) ) ) ) ).

% proj_iff
tff(fact_5433_in__quotient__imp__in__rel,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X7: set(B),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(set(B),X7,equiv_quotient(B,A4,R))
       => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,X2),aa(set(B),set(B),insert2(B,Y),bot_bot(set(B))))),X7)
         => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R) ) ) ) ).

% in_quotient_imp_in_rel
tff(fact_5434_congruent2__commuteI,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(B,B)),F: fun(B,fun(B,C))] :
      ( equiv_equiv(B,A4,R)
     => ( ! [Y4: B,Z3: B] :
            ( member(B,Y4,A4)
           => ( member(B,Z3,A4)
             => ( aa(B,C,aa(B,fun(B,C),F,Y4),Z3) = aa(B,C,aa(B,fun(B,C),F,Z3),Y4) ) ) )
       => ( ! [Y4: B,Z3: B,W3: B] :
              ( member(B,W3,A4)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
               => ( aa(B,C,aa(B,fun(B,C),F,W3),Y4) = aa(B,C,aa(B,fun(B,C),F,W3),Z3) ) ) )
         => equiv_congruent2(B,B,C,R,R,F) ) ) ) ).

% congruent2_commuteI
tff(fact_5435_quotient__eqI,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X7: set(B),Y7: set(B),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(set(B),X7,equiv_quotient(B,A4,R))
       => ( member(set(B),Y7,equiv_quotient(B,A4,R))
         => ( member(B,X2,X7)
           => ( member(B,Y,Y7)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
               => ( X7 = Y7 ) ) ) ) ) ) ) ).

% quotient_eqI
tff(fact_5436_quotient__eq__iff,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X7: set(B),Y7: set(B),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(set(B),X7,equiv_quotient(B,A4,R))
       => ( member(set(B),Y7,equiv_quotient(B,A4,R))
         => ( member(B,X2,X7)
           => ( member(B,Y,Y7)
             => ( ( X7 = Y7 )
              <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R) ) ) ) ) ) ) ).

% quotient_eq_iff
tff(fact_5437_in__quotient__imp__closed,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X7: set(B),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(set(B),X7,equiv_quotient(B,A4,R))
       => ( member(B,X2,X7)
         => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R)
           => member(B,Y,X7) ) ) ) ) ).

% in_quotient_imp_closed
tff(fact_5438_congruent2D,axiom,
    ! [B: $tType,D: $tType,C: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),F: fun(B,fun(C,D)),Y1: B,Z1: B,Y2: C,Z22: C] :
      ( equiv_congruent2(B,C,D,R1,R22,F)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y1),Z1),R1)
       => ( member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y2),Z22),R22)
         => ( aa(C,D,aa(B,fun(C,D),F,Y1),Y2) = aa(C,D,aa(B,fun(C,D),F,Z1),Z22) ) ) ) ) ).

% congruent2D
tff(fact_5439_congruent2I_H,axiom,
    ! [D: $tType,C: $tType,B: $tType,R1: set(product_prod(B,B)),R22: set(product_prod(C,C)),F: fun(B,fun(C,D))] :
      ( ! [Y12: B,Z12: B,Y22: C,Z23: C] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y12),Z12),R1)
         => ( member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y22),Z23),R22)
           => ( aa(C,D,aa(B,fun(C,D),F,Y12),Y22) = aa(C,D,aa(B,fun(C,D),F,Z12),Z23) ) ) )
     => equiv_congruent2(B,C,D,R1,R22,F) ) ).

% congruent2I'
tff(fact_5440_eq__equiv__class__iff2,axiom,
    ! [B: $tType,A4: set(B),R: set(product_prod(B,B)),X2: B,Y: B] :
      ( equiv_equiv(B,A4,R)
     => ( member(B,X2,A4)
       => ( member(B,Y,A4)
         => ( ( equiv_quotient(B,aa(set(B),set(B),insert2(B,X2),bot_bot(set(B))),R) = equiv_quotient(B,aa(set(B),set(B),insert2(B,Y),bot_bot(set(B))),R) )
          <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),R) ) ) ) ) ).

% eq_equiv_class_iff2
tff(fact_5441_congruent2I,axiom,
    ! [D: $tType,C: $tType,B: $tType,A17: set(B),R1: set(product_prod(B,B)),A25: set(C),R22: set(product_prod(C,C)),F: fun(B,fun(C,D))] :
      ( equiv_equiv(B,A17,R1)
     => ( equiv_equiv(C,A25,R22)
       => ( ! [Y4: B,Z3: B,W3: C] :
              ( member(C,W3,A25)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R1)
               => ( aa(C,D,aa(B,fun(C,D),F,Y4),W3) = aa(C,D,aa(B,fun(C,D),F,Z3),W3) ) ) )
         => ( ! [Y4: C,Z3: C,W3: B] :
                ( member(B,W3,A17)
               => ( member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Y4),Z3),R22)
                 => ( aa(C,D,aa(B,fun(C,D),F,W3),Y4) = aa(C,D,aa(B,fun(C,D),F,W3),Z3) ) ) )
           => equiv_congruent2(B,C,D,R1,R22,F) ) ) ) ) ).

% congruent2I
tff(fact_5442_UN__equiv__class__inject,axiom,
    ! [C: $tType,B: $tType,A4: set(B),R: set(product_prod(B,B)),F: fun(B,set(C)),X7: set(B),Y7: set(B)] :
      ( equiv_equiv(B,A4,R)
     => ( equiv_congruent(B,set(C),R,F)
       => ( ( aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(B),set(set(C)),image2(B,set(C),F),X7)) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(B),set(set(C)),image2(B,set(C),F),Y7)) )
         => ( member(set(B),X7,equiv_quotient(B,A4,R))
           => ( member(set(B),Y7,equiv_quotient(B,A4,R))
             => ( ! [X3: B,Y4: B] :
                    ( member(B,X3,A4)
                   => ( member(B,Y4,A4)
                     => ( ( aa(B,set(C),F,X3) = aa(B,set(C),F,Y4) )
                       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X3),Y4),R) ) ) )
               => ( X7 = Y7 ) ) ) ) ) ) ) ).

% UN_equiv_class_inject
tff(fact_5443_equivp__equiv,axiom,
    ! [B: $tType,A4: set(product_prod(B,B))] :
      ( equiv_equiv(B,top_top(set(B)),A4)
    <=> equiv_equivp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),A4)) ) ).

% equivp_equiv
tff(fact_5444_prod__mset__def,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ( comm_m9189036328036947845d_mset(B) = comm_monoid_F(B,times_times(B),one_one(B)) ) ) ).

% prod_mset_def
tff(fact_5445_congruentI,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),F: fun(B,C)] :
      ( ! [Y4: B,Z3: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),Z3),R)
         => ( aa(B,C,F,Y4) = aa(B,C,F,Z3) ) )
     => equiv_congruent(B,C,R,F) ) ).

% congruentI
tff(fact_5446_congruentD,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,B)),F: fun(B,C),Y: B,Z2: B] :
      ( equiv_congruent(B,C,R,F)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y),Z2),R)
       => ( aa(B,C,F,Y) = aa(B,C,F,Z2) ) ) ) ).

% congruentD
tff(fact_5447_sum__mset__def,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ( comm_m7189776963980413722m_mset(B) = comm_monoid_F(B,plus_plus(B),zero_zero(B)) ) ) ).

% sum_mset_def
tff(fact_5448_or__num_Opelims,axiom,
    ! [X2: num,Xa: num,Y: num] :
      ( ( bit_un6697907153464112080or_num(X2,Xa) = Y )
     => ( aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),X2),Xa))
       => ( ( ( X2 = one2 )
           => ( ( Xa = one2 )
             => ( ( Y = one2 )
               => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),one2)) ) ) )
         => ( ( ( X2 = one2 )
             => ! [N3: num] :
                  ( ( Xa = aa(num,num,bit0,N3) )
                 => ( ( Y = aa(num,num,bit1,N3) )
                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit0,N3))) ) ) )
           => ( ( ( X2 = one2 )
               => ! [N3: num] :
                    ( ( Xa = aa(num,num,bit1,N3) )
                   => ( ( Y = aa(num,num,bit1,N3) )
                     => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),one2),aa(num,num,bit1,N3))) ) ) )
             => ( ! [M4: num] :
                    ( ( X2 = aa(num,num,bit0,M4) )
                   => ( ( Xa = one2 )
                     => ( ( Y = aa(num,num,bit1,M4) )
                       => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),one2)) ) ) )
               => ( ! [M4: num] :
                      ( ( X2 = aa(num,num,bit0,M4) )
                     => ! [N3: num] :
                          ( ( Xa = aa(num,num,bit0,N3) )
                         => ( ( Y = aa(num,num,bit0,bit_un6697907153464112080or_num(M4,N3)) )
                           => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit0,N3))) ) ) )
                 => ( ! [M4: num] :
                        ( ( X2 = aa(num,num,bit0,M4) )
                       => ! [N3: num] :
                            ( ( Xa = aa(num,num,bit1,N3) )
                           => ( ( Y = aa(num,num,bit1,bit_un6697907153464112080or_num(M4,N3)) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit0,M4)),aa(num,num,bit1,N3))) ) ) )
                   => ( ! [M4: num] :
                          ( ( X2 = aa(num,num,bit1,M4) )
                         => ( ( Xa = one2 )
                           => ( ( Y = aa(num,num,bit1,M4) )
                             => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),one2)) ) ) )
                     => ( ! [M4: num] :
                            ( ( X2 = aa(num,num,bit1,M4) )
                           => ! [N3: num] :
                                ( ( Xa = aa(num,num,bit0,N3) )
                               => ( ( Y = aa(num,num,bit1,bit_un6697907153464112080or_num(M4,N3)) )
                                 => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit0,N3))) ) ) )
                       => ~ ! [M4: num] :
                              ( ( X2 = aa(num,num,bit1,M4) )
                             => ! [N3: num] :
                                  ( ( Xa = aa(num,num,bit1,N3) )
                                 => ( ( Y = aa(num,num,bit1,bit_un6697907153464112080or_num(M4,N3)) )
                                   => ~ aa(product_prod(num,num),$o,accp(product_prod(num,num),bit_un4773296044027857193um_rel),aa(num,product_prod(num,num),aa(num,fun(num,product_prod(num,num)),product_Pair(num,num),aa(num,num,bit1,M4)),aa(num,num,bit1,N3))) ) ) ) ) ) ) ) ) ) ) ) ) ) ).

% or_num.pelims
tff(fact_5449_Heap_Oset,axiom,
    ! [B: $tType,X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] : heap_Time_set_Heap(B,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2)) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),set(set(B)),image2(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(B),aTP_Lamp_vj(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(B))),aa(set(heap_ext(product_unit)),set(option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),image2(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),X2),top_top(set(heap_ext(product_unit)))))) ).

% Heap.set
tff(fact_5450_under__incr,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B,B2: B] :
      ( trans(B,R)
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),order_under(B,R,A3)),order_under(B,R,B2)) ) ) ).

% under_incr
tff(fact_5451_Heap_Oset__intros,axiom,
    ! [B: $tType,Y: option(product_prod(B,product_prod(heap_ext(product_unit),nat))),X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),Ya: product_prod(B,product_prod(heap_ext(product_unit),nat)),Yb2: B] :
      ( member(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Y,aa(set(heap_ext(product_unit)),set(option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),image2(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),X2),top_top(set(heap_ext(product_unit)))))
     => ( member(product_prod(B,product_prod(heap_ext(product_unit),nat)),Ya,aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(product_prod(B,product_prod(heap_ext(product_unit),nat))),set_option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Y))
       => ( member(B,Yb2,aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),set(B),basic_fsts(B,product_prod(heap_ext(product_unit),nat)),Ya))
         => member(B,Yb2,heap_Time_set_Heap(B,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2))) ) ) ) ).

% Heap.set_intros
tff(fact_5452_Heap_Oset__cases,axiom,
    ! [B: $tType,E2: B,A3: heap_Time_Heap(B)] :
      ( member(B,E2,heap_Time_set_Heap(B,A3))
     => ~ ! [Z3: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] :
            ( ( A3 = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),Z3) )
           => ! [Xa4: option(product_prod(B,product_prod(heap_ext(product_unit),nat)))] :
                ( member(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Xa4,aa(set(heap_ext(product_unit)),set(option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),image2(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Z3),top_top(set(heap_ext(product_unit)))))
               => ! [Xb3: product_prod(B,product_prod(heap_ext(product_unit),nat))] :
                    ( member(product_prod(B,product_prod(heap_ext(product_unit),nat)),Xb3,aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(product_prod(B,product_prod(heap_ext(product_unit),nat))),set_option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Xa4))
                   => ~ member(B,E2,aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),set(B),basic_fsts(B,product_prod(heap_ext(product_unit),nat)),Xb3)) ) ) ) ) ).

% Heap.set_cases
tff(fact_5453_under__def,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),A3: B] : order_under(B,R,A3) = aa(fun(B,$o),set(B),collect(B),aa(B,fun(B,$o),aTP_Lamp_sl(set(product_prod(B,B)),fun(B,fun(B,$o)),R),A3)) ).

% under_def
tff(fact_5454_Heap_Oinj__map__strong,axiom,
    ! [C: $tType,B: $tType,X2: heap_Time_Heap(B),Xa: heap_Time_Heap(B),F: fun(B,C),Fa: fun(B,C)] :
      ( ! [Z3: B,Za: B] :
          ( member(B,Z3,heap_Time_set_Heap(B,X2))
         => ( member(B,Za,heap_Time_set_Heap(B,Xa))
           => ( ( aa(B,C,F,Z3) = aa(B,C,Fa,Za) )
             => ( Z3 = Za ) ) ) )
     => ( ( aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),F),X2) = aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),Fa),Xa) )
       => ( X2 = Xa ) ) ) ).

% Heap.inj_map_strong
tff(fact_5455_Heap_Omap__cong0,axiom,
    ! [C: $tType,B: $tType,X2: heap_Time_Heap(B),F: fun(B,C),G: fun(B,C)] :
      ( ! [Z3: B] :
          ( member(B,Z3,heap_Time_set_Heap(B,X2))
         => ( aa(B,C,F,Z3) = aa(B,C,G,Z3) ) )
     => ( aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),F),X2) = aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),G),X2) ) ) ).

% Heap.map_cong0
tff(fact_5456_Heap_Omap__cong,axiom,
    ! [C: $tType,B: $tType,X2: heap_Time_Heap(B),Ya: heap_Time_Heap(B),F: fun(B,C),G: fun(B,C)] :
      ( ( X2 = Ya )
     => ( ! [Z3: B] :
            ( member(B,Z3,heap_Time_set_Heap(B,Ya))
           => ( aa(B,C,F,Z3) = aa(B,C,G,Z3) ) )
       => ( aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),F),X2) = aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),G),Ya) ) ) ) ).

% Heap.map_cong
tff(fact_5457_Heap_Oset__map,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),V: heap_Time_Heap(C)] : heap_Time_set_Heap(B,aa(heap_Time_Heap(C),heap_Time_Heap(B),aa(fun(C,B),fun(heap_Time_Heap(C),heap_Time_Heap(B)),heap_Time_map_Heap(C,B),F),V)) = aa(set(C),set(B),image2(C,B,F),heap_Time_set_Heap(C,V)) ).

% Heap.set_map
tff(fact_5458_Heap_Orel__Grp,axiom,
    ! [C: $tType,B: $tType,A4: set(B),F: fun(B,C)] : aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),bNF_Grp(B,C,A4,F)) = bNF_Grp(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(heap_Time_Heap(B),$o),set(heap_Time_Heap(B)),collect(heap_Time_Heap(B)),aTP_Lamp_vk(set(B),fun(heap_Time_Heap(B),$o),A4)),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),F)) ).

% Heap.rel_Grp
tff(fact_5459_Heap_Orel__compp__Grp,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(C,$o))] : aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4) = relcompp(heap_Time_Heap(B),heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(C),conversep(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(B),bNF_Grp(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(B),aa(fun(heap_Time_Heap(product_prod(B,C)),$o),set(heap_Time_Heap(product_prod(B,C))),collect(heap_Time_Heap(product_prod(B,C))),aTP_Lamp_vl(fun(B,fun(C,$o)),fun(heap_Time_Heap(product_prod(B,C)),$o),R4)),aa(fun(product_prod(B,C),B),fun(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(B)),heap_Time_map_Heap(product_prod(B,C),B),product_fst(B,C)))),bNF_Grp(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(C),aa(fun(heap_Time_Heap(product_prod(B,C)),$o),set(heap_Time_Heap(product_prod(B,C))),collect(heap_Time_Heap(product_prod(B,C))),aTP_Lamp_vl(fun(B,fun(C,$o)),fun(heap_Time_Heap(product_prod(B,C)),$o),R4)),aa(fun(product_prod(B,C),C),fun(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(C)),heap_Time_map_Heap(product_prod(B,C),C),product_snd(B,C)))) ).

% Heap.rel_compp_Grp
tff(fact_5460_Heap_Oin__rel,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),A3: heap_Time_Heap(B),B2: heap_Time_Heap(C)] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),A3),B2)
    <=> ? [Z4: heap_Time_Heap(product_prod(B,C))] :
          ( member(heap_Time_Heap(product_prod(B,C)),Z4,aa(fun(heap_Time_Heap(product_prod(B,C)),$o),set(heap_Time_Heap(product_prod(B,C))),collect(heap_Time_Heap(product_prod(B,C))),aTP_Lamp_vl(fun(B,fun(C,$o)),fun(heap_Time_Heap(product_prod(B,C)),$o),R4)))
          & ( aa(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(B),aa(fun(product_prod(B,C),B),fun(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(B)),heap_Time_map_Heap(product_prod(B,C),B),product_fst(B,C)),Z4) = A3 )
          & ( aa(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(C),aa(fun(product_prod(B,C),C),fun(heap_Time_Heap(product_prod(B,C)),heap_Time_Heap(C)),heap_Time_map_Heap(product_prod(B,C),C),product_snd(B,C)),Z4) = B2 ) ) ) ).

% Heap.in_rel
tff(fact_5461_Heap_Orel__cong,axiom,
    ! [B: $tType,C: $tType,X2: heap_Time_Heap(B),Ya: heap_Time_Heap(B),Y: heap_Time_Heap(C),Xa: heap_Time_Heap(C),R4: fun(B,fun(C,$o)),Ra2: fun(B,fun(C,$o))] :
      ( ( X2 = Ya )
     => ( ( Y = Xa )
       => ( ! [Z3: B,Yb: C] :
              ( member(B,Z3,heap_Time_set_Heap(B,Ya))
             => ( member(C,Yb,heap_Time_set_Heap(C,Xa))
               => ( aa(C,$o,aa(B,fun(C,$o),R4,Z3),Yb)
                <=> aa(C,$o,aa(B,fun(C,$o),Ra2,Z3),Yb) ) ) )
         => ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),X2),Y)
          <=> aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),Ra2),Ya),Xa) ) ) ) ) ).

% Heap.rel_cong
tff(fact_5462_Heap_Orel__mono__strong,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: heap_Time_Heap(B),Y: heap_Time_Heap(C),Ra2: fun(B,fun(C,$o))] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),X2),Y)
     => ( ! [Z3: B,Yb: C] :
            ( member(B,Z3,heap_Time_set_Heap(B,X2))
           => ( member(C,Yb,heap_Time_set_Heap(C,Y))
             => ( aa(C,$o,aa(B,fun(C,$o),R4,Z3),Yb)
               => aa(C,$o,aa(B,fun(C,$o),Ra2,Z3),Yb) ) ) )
       => aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),Ra2),X2),Y) ) ) ).

% Heap.rel_mono_strong
tff(fact_5463_Heap_Orel__refl__strong,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B),Ra2: fun(B,fun(B,$o))] :
      ( ! [Z3: B] :
          ( member(B,Z3,heap_Time_set_Heap(B,X2))
         => aa(B,$o,aa(B,fun(B,$o),Ra2,Z3),Z3) )
     => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),Ra2),X2),X2) ) ).

% Heap.rel_refl_strong
tff(fact_5464_Heap_Orel__map_I2_J,axiom,
    ! [B: $tType,C: $tType,D: $tType,Sa: fun(B,fun(C,$o)),X2: heap_Time_Heap(B),G: fun(D,C),Y: heap_Time_Heap(D)] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),Sa),X2),aa(heap_Time_Heap(D),heap_Time_Heap(C),aa(fun(D,C),fun(heap_Time_Heap(D),heap_Time_Heap(C)),heap_Time_map_Heap(D,C),G),Y))
    <=> aa(heap_Time_Heap(D),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o),aa(fun(B,fun(D,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o)),heap_Time_rel_Heap(B,D),aa(fun(D,C),fun(B,fun(D,$o)),aTP_Lamp_ua(fun(B,fun(C,$o)),fun(fun(D,C),fun(B,fun(D,$o))),Sa),G)),X2),Y) ) ).

% Heap.rel_map(2)
tff(fact_5465_Heap_Orel__map_I1_J,axiom,
    ! [D: $tType,B: $tType,C: $tType,Sb: fun(B,fun(C,$o)),I: fun(D,B),X2: heap_Time_Heap(D),Y: heap_Time_Heap(C)] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),Sb),aa(heap_Time_Heap(D),heap_Time_Heap(B),aa(fun(D,B),fun(heap_Time_Heap(D),heap_Time_Heap(B)),heap_Time_map_Heap(D,B),I),X2)),Y)
    <=> aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(D),fun(heap_Time_Heap(C),$o),aa(fun(D,fun(C,$o)),fun(heap_Time_Heap(D),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(D,C),aa(fun(D,B),fun(D,fun(C,$o)),aTP_Lamp_tz(fun(B,fun(C,$o)),fun(fun(D,B),fun(D,fun(C,$o))),Sb),I)),X2),Y) ) ).

% Heap.rel_map(1)
tff(fact_5466_Heap_Orel__mono,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(C,$o)),Ra2: fun(B,fun(C,$o))] :
      ( aa(fun(B,fun(C,$o)),$o,aa(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),$o),ord_less_eq(fun(B,fun(C,$o))),R4),Ra2)
     => aa(fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),$o,aa(fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),fun(fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),$o),ord_less_eq(fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o))),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4)),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),Ra2)) ) ).

% Heap.rel_mono
tff(fact_5467_Heap_Orel__transp,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o))] :
      ( transp(B,R4)
     => transp(heap_Time_Heap(B),aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),R4)) ) ).

% Heap.rel_transp
tff(fact_5468_Heap_Orel__refl,axiom,
    ! [B: $tType,Ra2: fun(B,fun(B,$o)),X2: heap_Time_Heap(B)] :
      ( ! [X3: B] : aa(B,$o,aa(B,fun(B,$o),Ra2,X3),X3)
     => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),Ra2),X2),X2) ) ).

% Heap.rel_refl
tff(fact_5469_Heap_Orel__eq,axiom,
    ! [B: $tType] : aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),fequal(B)) = fequal(heap_Time_Heap(B)) ).

% Heap.rel_eq
tff(fact_5470_Heap_Orel__conversep,axiom,
    ! [B: $tType,C: $tType,R4: fun(C,fun(B,$o))] : aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),conversep(C,B,R4)) = conversep(heap_Time_Heap(C),heap_Time_Heap(B),aa(fun(C,fun(B,$o)),fun(heap_Time_Heap(C),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(C,B),R4)) ).

% Heap.rel_conversep
tff(fact_5471_Heap_Orel__flip,axiom,
    ! [C: $tType,B: $tType,R4: fun(C,fun(B,$o)),A3: heap_Time_Heap(B),B2: heap_Time_Heap(C)] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),conversep(C,B,R4)),A3),B2)
    <=> aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(C),fun(heap_Time_Heap(B),$o),aa(fun(C,fun(B,$o)),fun(heap_Time_Heap(C),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(C,B),R4),B2),A3) ) ).

% Heap.rel_flip
tff(fact_5472_Heap_Orel__compp,axiom,
    ! [B: $tType,C: $tType,D: $tType,R4: fun(B,fun(D,$o)),S2: fun(D,fun(C,$o))] : aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),relcompp(B,D,C,R4,S2)) = relcompp(heap_Time_Heap(B),heap_Time_Heap(D),heap_Time_Heap(C),aa(fun(B,fun(D,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o)),heap_Time_rel_Heap(B,D),R4),aa(fun(D,fun(C,$o)),fun(heap_Time_Heap(D),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(D,C),S2)) ).

% Heap.rel_compp
tff(fact_5473_Heap_Orel__transfer,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,Sa: fun(B,fun(D,$o)),Sc: fun(C,fun(E,$o))] : aa(fun(fun(D,fun(E,$o)),fun(heap_Time_Heap(D),fun(heap_Time_Heap(E),$o))),$o,aa(fun(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o))),fun(fun(fun(D,fun(E,$o)),fun(heap_Time_Heap(D),fun(heap_Time_Heap(E),$o))),$o),bNF_rel_fun(fun(B,fun(C,$o)),fun(D,fun(E,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),fun(heap_Time_Heap(D),fun(heap_Time_Heap(E),$o)),bNF_rel_fun(B,D,fun(C,$o),fun(E,$o),Sa,bNF_rel_fun(C,E,$o,$o,Sc,fequal($o))),bNF_rel_fun(heap_Time_Heap(B),heap_Time_Heap(D),fun(heap_Time_Heap(C),$o),fun(heap_Time_Heap(E),$o),aa(fun(B,fun(D,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o)),heap_Time_rel_Heap(B,D),Sa),bNF_rel_fun(heap_Time_Heap(C),heap_Time_Heap(E),$o,$o,aa(fun(C,fun(E,$o)),fun(heap_Time_Heap(C),fun(heap_Time_Heap(E),$o)),heap_Time_rel_Heap(C,E),Sc),fequal($o)))),heap_Time_rel_Heap(B,C)),heap_Time_rel_Heap(D,E)) ).

% Heap.rel_transfer
tff(fact_5474_Heap_Omap__transfer,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,Rb2: fun(B,fun(D,$o)),Sd: fun(C,fun(E,$o))] : aa(fun(fun(D,E),fun(heap_Time_Heap(D),heap_Time_Heap(E))),$o,aa(fun(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C))),fun(fun(fun(D,E),fun(heap_Time_Heap(D),heap_Time_Heap(E))),$o),bNF_rel_fun(fun(B,C),fun(D,E),fun(heap_Time_Heap(B),heap_Time_Heap(C)),fun(heap_Time_Heap(D),heap_Time_Heap(E)),bNF_rel_fun(B,D,C,E,Rb2,Sd),bNF_rel_fun(heap_Time_Heap(B),heap_Time_Heap(D),heap_Time_Heap(C),heap_Time_Heap(E),aa(fun(B,fun(D,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o)),heap_Time_rel_Heap(B,D),Rb2),aa(fun(C,fun(E,$o)),fun(heap_Time_Heap(C),fun(heap_Time_Heap(E),$o)),heap_Time_rel_Heap(C,E),Sd))),heap_Time_map_Heap(B,C)),heap_Time_map_Heap(D,E)) ).

% Heap.map_transfer
tff(fact_5475_those_Osimps_I2_J,axiom,
    ! [B: $tType,X2: option(B),Xsa: list(option(B))] : those(B,aa(list(option(B)),list(option(B)),aa(option(B),fun(list(option(B)),list(option(B))),cons(option(B)),X2),Xsa)) = aa(option(B),option(list(B)),aa(fun(B,option(list(B))),fun(option(B),option(list(B))),aa(option(list(B)),fun(fun(B,option(list(B))),fun(option(B),option(list(B)))),case_option(option(list(B)),B),none(list(B))),aTP_Lamp_vm(list(option(B)),fun(B,option(list(B))),Xsa)),X2) ).

% those.simps(2)
tff(fact_5476_Quotient__natural,axiom,
    quotient(nat,code_natural,fequal(nat),code_natural_of_nat,code_nat_of_natural,code_cr_natural) ).

% Quotient_natural
tff(fact_5477_Quotient__integer,axiom,
    quotient(int,code_integer,fequal(int),code_integer_of_int,code_int_of_integer,code_cr_integer) ).

% Quotient_integer
tff(fact_5478_Heap_OQuotient,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(B,$o)),Abs: fun(B,C),Rep: fun(C,B),T5: fun(B,fun(C,$o))] :
      ( quotient(B,C,R4,Abs,Rep,T5)
     => quotient(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),R4),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),Abs),aa(fun(C,B),fun(heap_Time_Heap(C),heap_Time_Heap(B)),heap_Time_map_Heap(C,B),Rep),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),T5)) ) ).

% Heap.Quotient
tff(fact_5479_option_OQuotient,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(B,$o)),Abs: fun(B,C),Rep: fun(C,B),T5: fun(B,fun(C,$o))] :
      ( quotient(B,C,R4,Abs,Rep,T5)
     => quotient(option(B),option(C),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),R4),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),Abs),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),Rep),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),T5)) ) ).

% option.Quotient
tff(fact_5480_Quotient__compose,axiom,
    ! [B: $tType,D: $tType,C: $tType,R12: fun(B,fun(B,$o)),Abs1: fun(B,C),Rep1: fun(C,B),T1: fun(B,fun(C,$o)),R23: fun(C,fun(C,$o)),Abs22: fun(C,D),Rep22: fun(D,C),T22: fun(C,fun(D,$o))] :
      ( quotient(B,C,R12,Abs1,Rep1,T1)
     => ( quotient(C,D,R23,Abs22,Rep22,T22)
       => quotient(B,D,relcompp(B,C,B,T1,relcompp(C,C,B,R23,conversep(B,C,T1))),aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),Abs22),Abs1),aa(fun(D,C),fun(D,B),aa(fun(C,B),fun(fun(D,C),fun(D,B)),comp(C,B,D),Rep1),Rep22),relcompp(B,C,D,T1,T22)) ) ) ).

% Quotient_compose
tff(fact_5481_Heap_Opred__transfer,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(fun(fun(C,$o),fun(heap_Time_Heap(C),$o)),$o,aa(fun(fun(B,$o),fun(heap_Time_Heap(B),$o)),fun(fun(fun(C,$o),fun(heap_Time_Heap(C),$o)),$o),bNF_rel_fun(fun(B,$o),fun(C,$o),fun(heap_Time_Heap(B),$o),fun(heap_Time_Heap(C),$o),bNF_rel_fun(B,C,$o,$o,R4,fequal($o)),bNF_rel_fun(heap_Time_Heap(B),heap_Time_Heap(C),$o,$o,aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),fequal($o))),heap_Time_pred_Heap(B)),heap_Time_pred_Heap(C)) ).

% Heap.pred_transfer
tff(fact_5482_Heap_Orec__transfer,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,R4: fun(B,fun(D,$o)),S2: fun(C,fun(E,$o))] : aa(fun(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),E),fun(heap_Time_Heap(D),E)),$o,aa(fun(fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),fun(heap_Time_Heap(B),C)),fun(fun(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),E),fun(heap_Time_Heap(D),E)),$o),bNF_rel_fun(fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),E),fun(heap_Time_Heap(B),C),fun(heap_Time_Heap(D),E),bNF_rel_fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C,E,bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(D,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(D,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(D,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(D,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,D,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),S2),bNF_rel_fun(heap_Time_Heap(B),heap_Time_Heap(D),C,E,aa(fun(B,fun(D,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o)),heap_Time_rel_Heap(B,D),R4),S2)),heap_Time_rec_Heap(B,C)),heap_Time_rec_Heap(D,E)) ).

% Heap.rec_transfer
tff(fact_5483_rel__prod__inject,axiom,
    ! [C: $tType,B: $tType,D: $tType,E: $tType,R12: fun(B,fun(C,$o)),R23: fun(D,fun(E,$o)),A3: B,B2: D,C2: C,D3: E] :
      ( aa(product_prod(C,E),$o,aa(product_prod(B,D),fun(product_prod(C,E),$o),basic_rel_prod(B,C,D,E,R12,R23),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A3),B2)),aa(E,product_prod(C,E),aa(C,fun(E,product_prod(C,E)),product_Pair(C,E),C2),D3))
    <=> ( aa(C,$o,aa(B,fun(C,$o),R12,A3),C2)
        & aa(E,$o,aa(D,fun(E,$o),R23,B2),D3) ) ) ).

% rel_prod_inject
tff(fact_5484_Heap_Opred__mono,axiom,
    ! [B: $tType,P: fun(B,$o),Pa: fun(B,$o)] :
      ( aa(fun(B,$o),$o,aa(fun(B,$o),fun(fun(B,$o),$o),ord_less_eq(fun(B,$o)),P),Pa)
     => aa(fun(heap_Time_Heap(B),$o),$o,aa(fun(heap_Time_Heap(B),$o),fun(fun(heap_Time_Heap(B),$o),$o),ord_less_eq(fun(heap_Time_Heap(B),$o)),aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P)),aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),Pa)) ) ).

% Heap.pred_mono
tff(fact_5485_rel__prod_Ointros,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,R12: fun(B,fun(C,$o)),A3: B,B2: C,R23: fun(D,fun(E,$o)),C2: D,D3: E] :
      ( aa(C,$o,aa(B,fun(C,$o),R12,A3),B2)
     => ( aa(E,$o,aa(D,fun(E,$o),R23,C2),D3)
       => aa(product_prod(C,E),$o,aa(product_prod(B,D),fun(product_prod(C,E),$o),basic_rel_prod(B,C,D,E,R12,R23),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A3),C2)),aa(E,product_prod(C,E),aa(C,fun(E,product_prod(C,E)),product_Pair(C,E),B2),D3)) ) ) ).

% rel_prod.intros
tff(fact_5486_rel__prod_Osimps,axiom,
    ! [C: $tType,B: $tType,D: $tType,E: $tType,R12: fun(B,fun(C,$o)),R23: fun(D,fun(E,$o)),A1: product_prod(B,D),A22: product_prod(C,E)] :
      ( aa(product_prod(C,E),$o,aa(product_prod(B,D),fun(product_prod(C,E),$o),basic_rel_prod(B,C,D,E,R12,R23),A1),A22)
    <=> ? [A7: B,B7: C,C4: D,D5: E] :
          ( ( A1 = aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A7),C4) )
          & ( A22 = aa(E,product_prod(C,E),aa(C,fun(E,product_prod(C,E)),product_Pair(C,E),B7),D5) )
          & aa(C,$o,aa(B,fun(C,$o),R12,A7),B7)
          & aa(E,$o,aa(D,fun(E,$o),R23,C4),D5) ) ) ).

% rel_prod.simps
tff(fact_5487_rel__prod_Ocases,axiom,
    ! [C: $tType,B: $tType,D: $tType,E: $tType,R12: fun(B,fun(C,$o)),R23: fun(D,fun(E,$o)),A1: product_prod(B,D),A22: product_prod(C,E)] :
      ( aa(product_prod(C,E),$o,aa(product_prod(B,D),fun(product_prod(C,E),$o),basic_rel_prod(B,C,D,E,R12,R23),A1),A22)
     => ~ ! [A5: B,B3: C,C3: D] :
            ( ( A1 = aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),A5),C3) )
           => ! [D2: E] :
                ( ( A22 = aa(E,product_prod(C,E),aa(C,fun(E,product_prod(C,E)),product_Pair(C,E),B3),D2) )
               => ( aa(C,$o,aa(B,fun(C,$o),R12,A5),B3)
                 => ~ aa(E,$o,aa(D,fun(E,$o),R23,C3),D2) ) ) ) ) ).

% rel_prod.cases
tff(fact_5488_Heap_Opred__True,axiom,
    ! [B: $tType,X: heap_Time_Heap(B)] : aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),aTP_Lamp_af(B,$o)),X) ).

% Heap.pred_True
tff(fact_5489_Heap_Opred__mono__strong,axiom,
    ! [B: $tType,P: fun(B,$o),X2: heap_Time_Heap(B),Pa: fun(B,$o)] :
      ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P),X2)
     => ( ! [Z3: B] :
            ( member(B,Z3,heap_Time_set_Heap(B,X2))
           => ( aa(B,$o,P,Z3)
             => aa(B,$o,Pa,Z3) ) )
       => aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),Pa),X2) ) ) ).

% Heap.pred_mono_strong
tff(fact_5490_Heap_Opred__cong,axiom,
    ! [B: $tType,X2: heap_Time_Heap(B),Ya: heap_Time_Heap(B),P: fun(B,$o),Pa: fun(B,$o)] :
      ( ( X2 = Ya )
     => ( ! [Z3: B] :
            ( member(B,Z3,heap_Time_set_Heap(B,Ya))
           => ( aa(B,$o,P,Z3)
            <=> aa(B,$o,Pa,Z3) ) )
       => ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P),X2)
        <=> aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),Pa),Ya) ) ) ) ).

% Heap.pred_cong
tff(fact_5491_Heap_Octr__transfer,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o))] : aa(fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C)),$o,aa(fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B)),fun(fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C)),$o),bNF_rel_fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap(C),bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(C,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,C,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4)),heap_Time_Heap2(B)),heap_Time_Heap2(C)) ).

% Heap.ctr_transfer
tff(fact_5492_Heap_Orel__intros,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),Y: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] :
      ( aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o),bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(C,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,C,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),X2),Y)
     => aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2)),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),Y)) ) ).

% Heap.rel_intros
tff(fact_5493_Heap_Orel__inject,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),Y: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),X2)),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),Y))
    <=> aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o),bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(C,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,C,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),X2),Y) ) ).

% Heap.rel_inject
tff(fact_5494_Heap_Orel__induct,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: heap_Time_Heap(B),Y: heap_Time_Heap(C),Q: fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o))] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),X2),Y)
     => ( ! [A5: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),B3: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] :
            ( aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o),bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(C,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,C,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),A5),B3)
           => aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),Q,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),A5)),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),B3)) )
       => aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),Q,X2),Y) ) ) ).

% Heap.rel_induct
tff(fact_5495_Heap_Orel__cases,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),A3: heap_Time_Heap(B),B2: heap_Time_Heap(C)] :
      ( aa(heap_Time_Heap(C),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4),A3),B2)
     => ~ ! [Xa4: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] :
            ( ( A3 = aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),Xa4) )
           => ! [Ya2: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] :
                ( ( B2 = aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),Ya2) )
               => ~ aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),$o),bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(C,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,C,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),Xa4),Ya2) ) ) ) ).

% Heap.rel_cases
tff(fact_5496_Heap_Omap__cong__pred,axiom,
    ! [C: $tType,B: $tType,X2: heap_Time_Heap(B),Ya: heap_Time_Heap(B),F: fun(B,C),G: fun(B,C)] :
      ( ( X2 = Ya )
     => ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),aa(fun(B,C),fun(B,$o),aTP_Lamp_uf(fun(B,C),fun(fun(B,C),fun(B,$o)),F),G)),Ya)
       => ( aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),F),X2) = aa(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,C),fun(heap_Time_Heap(B),heap_Time_Heap(C)),heap_Time_map_Heap(B,C),G),Ya) ) ) ) ).

% Heap.map_cong_pred
tff(fact_5497_Heap_Orel__eq__onp,axiom,
    ! [B: $tType,P: fun(B,$o)] : aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),bNF_eq_onp(B,P)) = bNF_eq_onp(heap_Time_Heap(B),aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P)) ).

% Heap.rel_eq_onp
tff(fact_5498_Heap_Opred__rel,axiom,
    ! [B: $tType,P: fun(B,$o),X2: heap_Time_Heap(B)] :
      ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P),X2)
    <=> aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),bNF_eq_onp(B,P)),X2),X2) ) ).

% Heap.pred_rel
tff(fact_5499_Heap_Opred__set,axiom,
    ! [B: $tType,P: fun(B,$o),X: heap_Time_Heap(B)] :
      ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P),X)
    <=> ! [Xa2: B] :
          ( member(B,Xa2,heap_Time_set_Heap(B,X))
         => aa(B,$o,P,Xa2) ) ) ).

% Heap.pred_set
tff(fact_5500_Pair__transfer,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,A4: fun(B,fun(C,$o)),B5: fun(D,fun(E,$o))] : aa(fun(C,fun(E,product_prod(C,E))),$o,aa(fun(B,fun(D,product_prod(B,D))),fun(fun(C,fun(E,product_prod(C,E))),$o),bNF_rel_fun(B,C,fun(D,product_prod(B,D)),fun(E,product_prod(C,E)),A4,bNF_rel_fun(D,E,product_prod(B,D),product_prod(C,E),B5,basic_rel_prod(B,C,D,E,A4,B5))),product_Pair(B,D)),product_Pair(C,E)) ).

% Pair_transfer
tff(fact_5501_Heap_Opred__map,axiom,
    ! [B: $tType,C: $tType,Q: fun(B,$o),F: fun(C,B),X2: heap_Time_Heap(C)] :
      ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),Q),aa(heap_Time_Heap(C),heap_Time_Heap(B),aa(fun(C,B),fun(heap_Time_Heap(C),heap_Time_Heap(B)),heap_Time_map_Heap(C,B),F),X2))
    <=> aa(heap_Time_Heap(C),$o,aa(fun(C,$o),fun(heap_Time_Heap(C),$o),heap_Time_pred_Heap(C),aa(fun(C,B),fun(C,$o),aa(fun(B,$o),fun(fun(C,B),fun(C,$o)),comp(B,$o,C),Q),F)),X2) ) ).

% Heap.pred_map
tff(fact_5502_Heap_Ocase__transfer,axiom,
    ! [B: $tType,C: $tType,E: $tType,D: $tType,R4: fun(B,fun(D,$o)),S2: fun(C,fun(E,$o))] : aa(fun(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),E),fun(heap_Time_Heap(D),E)),$o,aa(fun(fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),fun(heap_Time_Heap(B),C)),fun(fun(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),E),fun(heap_Time_Heap(D),E)),$o),bNF_rel_fun(fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),E),fun(heap_Time_Heap(B),C),fun(heap_Time_Heap(D),E),bNF_rel_fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C,E,bNF_rel_fun(heap_ext(product_unit),heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(D,product_prod(heap_ext(product_unit),nat))),fequal(heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),fun(product_prod(D,product_prod(heap_ext(product_unit),nat)),$o)),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(D,product_prod(heap_ext(product_unit),nat))),$o)),rel_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(D,product_prod(heap_ext(product_unit),nat))),basic_rel_prod(B,D,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),R4,fequal(product_prod(heap_ext(product_unit),nat))))),S2),bNF_rel_fun(heap_Time_Heap(B),heap_Time_Heap(D),C,E,aa(fun(B,fun(D,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(D),$o)),heap_Time_rel_Heap(B,D),R4),S2)),heap_Time_case_Heap(B,C)),heap_Time_case_Heap(D,E)) ).

% Heap.case_transfer
tff(fact_5503_sndOp__def,axiom,
    ! [B: $tType,C: $tType,D: $tType,P: fun(D,fun(B,$o)),Q: fun(B,fun(C,$o)),Ac: product_prod(D,C)] : bNF_sndOp(D,B,C,P,Q,Ac) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),bNF_pick_middlep(D,B,C,P,Q,aa(product_prod(D,C),D,product_fst(D,C),Ac),aa(product_prod(D,C),C,product_snd(D,C),Ac))),aa(product_prod(D,C),C,product_snd(D,C),Ac)) ).

% sndOp_def
tff(fact_5504_fstOp__def,axiom,
    ! [C: $tType,D: $tType,B: $tType,P: fun(B,fun(C,$o)),Q: fun(C,fun(D,$o)),Ac: product_prod(B,D)] : bNF_fstOp(B,C,D,P,Q,Ac) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(product_prod(B,D),B,product_fst(B,D),Ac)),bNF_pick_middlep(B,C,D,P,Q,aa(product_prod(B,D),B,product_fst(B,D),Ac),aa(product_prod(B,D),D,product_snd(B,D),Ac))) ).

% fstOp_def
tff(fact_5505_Heap_Ocase__distrib,axiom,
    ! [C: $tType,B: $tType,D: $tType,Ha: fun(C,B),F: fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),Heap: heap_Time_Heap(D)] : aa(C,B,Ha,aa(heap_Time_Heap(D),C,aa(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(heap_Time_Heap(D),C),heap_Time_case_Heap(D,C),F),Heap)) = aa(heap_Time_Heap(D),B,aa(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),B),fun(heap_Time_Heap(D),B),heap_Time_case_Heap(D,B),aa(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),B),aTP_Lamp_vn(fun(C,B),fun(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),B)),Ha),F)),Heap) ).

% Heap.case_distrib
tff(fact_5506_Heap_Ocase,axiom,
    ! [B: $tType,C: $tType,F: fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),B),X2: fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))] : aa(heap_Time_Heap(C),B,aa(fun(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),B),fun(heap_Time_Heap(C),B),heap_Time_case_Heap(C,B),F),aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),X2)) = aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),B,F,X2) ).

% Heap.case
tff(fact_5507_trancl__def,axiom,
    ! [B: $tType,X: set(product_prod(B,B))] : transitive_trancl(B,X) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),transitive_tranclp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),X)))) ).

% trancl_def
tff(fact_5508_Nitpick_Otranclp__unfold,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),A3: B,B2: B] :
      ( aa(B,$o,aa(B,fun(B,$o),transitive_tranclp(B,R),A3),B2)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),transitive_trancl(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% Nitpick.tranclp_unfold
tff(fact_5509_reflp__refl__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( reflp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R))
    <=> refl_on(B,top_top(set(B)),R) ) ).

% reflp_refl_eq
tff(fact_5510_tranclp__induct2,axiom,
    ! [B: $tType,C: $tType,R: fun(product_prod(B,C),fun(product_prod(B,C),$o)),Ax: B,Ay: C,Bx: B,By: C,P: fun(B,fun(C,$o))] :
      ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_tranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By))
     => ( ! [A5: B,B3: C] :
            ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),R,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3))
           => aa(C,$o,aa(B,fun(C,$o),P,A5),B3) )
       => ( ! [A5: B,B3: C,Aa2: B,Ba: C] :
              ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_tranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3))
             => ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),R,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba))
               => ( aa(C,$o,aa(B,fun(C,$o),P,A5),B3)
                 => aa(C,$o,aa(B,fun(C,$o),P,Aa2),Ba) ) ) )
         => aa(C,$o,aa(B,fun(C,$o),P,Bx),By) ) ) ) ).

% tranclp_induct2
tff(fact_5511_Heap_Orel__reflp,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o))] :
      ( reflp(B,R4)
     => reflp(heap_Time_Heap(B),aa(fun(B,fun(B,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o)),heap_Time_rel_Heap(B,B),R4)) ) ).

% Heap.rel_reflp
tff(fact_5512_option_Orel__reflp,axiom,
    ! [B: $tType,R4: fun(B,fun(B,$o))] :
      ( reflp(B,R4)
     => reflp(option(B),aa(fun(B,fun(B,$o)),fun(option(B),fun(option(B),$o)),rel_option(B,B),R4)) ) ).

% option.rel_reflp
tff(fact_5513_tranclp__trancl__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X: B,Xa3: B] :
      ( aa(B,$o,aa(B,fun(B,$o),transitive_tranclp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R)),X),Xa3)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa3),transitive_trancl(B,R)) ) ).

% tranclp_trancl_eq
tff(fact_5514_Lcm__fin__1__iff,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A4: set(B)] :
          ( ( aa(set(B),B,semiring_gcd_Lcm_fin(B),A4) = one_one(B) )
        <=> ( ! [X4: B] :
                ( member(B,X4,A4)
               => dvd_dvd(B,X4,one_one(B)) )
            & finite_finite2(B,A4) ) ) ) ).

% Lcm_fin_1_iff
tff(fact_5515_heap__interpretation,axiom,
    ! [B: $tType] : partia7178651479351089652itions(heap_Time_Heap(B),heap_Time_Heap_ord(B),heap_Time_Heap_lub(B)) ).

% heap_interpretation
tff(fact_5516_old_Orec__bool__def,axiom,
    ! [B: $tType,X: B,Xa3: B,Xb2: $o] : product_rec_bool(B,X,Xa3,(Xb2)) = the(B,product_rec_set_bool(B,X,Xa3,(Xb2))) ).

% old.rec_bool_def
tff(fact_5517_old_Obool_Osimps_I6_J,axiom,
    ! [B: $tType,F1: B,F22: B] : product_rec_bool(B,F1,F22,$false) = F22 ).

% old.bool.simps(6)
tff(fact_5518_old_Obool_Osimps_I5_J,axiom,
    ! [B: $tType,F1: B,F22: B] : product_rec_bool(B,F1,F22,$true) = F1 ).

% old.bool.simps(5)
tff(fact_5519_Lcm__fin_Oempty,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ( aa(set(B),B,semiring_gcd_Lcm_fin(B),bot_bot(set(B))) = one_one(B) ) ) ).

% Lcm_fin.empty
tff(fact_5520_is__unit__Lcm__fin__iff,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A4: set(B)] :
          ( dvd_dvd(B,aa(set(B),B,semiring_gcd_Lcm_fin(B),A4),one_one(B))
        <=> ( aa(set(B),B,semiring_gcd_Lcm_fin(B),A4) = one_one(B) ) ) ) ).

% is_unit_Lcm_fin_iff
tff(fact_5521_Lcm__fin_Oeq__fold,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A4: set(B)] :
          aa(set(B),B,semiring_gcd_Lcm_fin(B),A4) = $ite(finite_finite2(B,A4),finite_fold(B,B,gcd_lcm(B),one_one(B),A4),zero_zero(B)) ) ).

% Lcm_fin.eq_fold
tff(fact_5522_Lcm__fin__def,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ( semiring_gcd_Lcm_fin(B) = bounde2362111253966948842tice_F(B,gcd_lcm(B),one_one(B),zero_zero(B)) ) ) ).

% Lcm_fin_def
tff(fact_5523_fun_Opred__map,axiom,
    ! [C: $tType,D: $tType,B: $tType,Q: fun(C,$o),F: fun(D,C),X2: fun(B,D)] :
      ( basic_pred_fun(B,C,aTP_Lamp_af(B,$o),Q,aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),F),X2))
    <=> basic_pred_fun(B,D,aTP_Lamp_af(B,$o),aa(fun(D,C),fun(D,$o),aa(fun(C,$o),fun(fun(D,C),fun(D,$o)),comp(C,$o,D),Q),F),X2) ) ).

% fun.pred_map
tff(fact_5524_lcm__eq__1__iff,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,aa(B,fun(B,B),gcd_lcm(B),A3),B2) = one_one(B) )
        <=> ( dvd_dvd(B,A3,one_one(B))
            & dvd_dvd(B,B2,one_one(B)) ) ) ) ).

% lcm_eq_1_iff
tff(fact_5525_unit__factor__lcm,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B] :
          unit_f5069060285200089521factor(B,aa(B,B,aa(B,fun(B,B),gcd_lcm(B),A3),B2)) = $ite(
            ( ( A3 = zero_zero(B) )
            | ( B2 = zero_zero(B) ) ),
            zero_zero(B),
            one_one(B) ) ) ).

% unit_factor_lcm
tff(fact_5526_fun_Omap__cong__pred,axiom,
    ! [D: $tType,C: $tType,B: $tType,X2: fun(B,C),Ya: fun(B,C),F: fun(C,D),G: fun(C,D)] :
      ( ( X2 = Ya )
     => ( basic_pred_fun(B,C,aTP_Lamp_af(B,$o),aa(fun(C,D),fun(C,$o),aTP_Lamp_vo(fun(C,D),fun(fun(C,D),fun(C,$o)),F),G),Ya)
       => ( aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),F),X2) = aa(fun(B,C),fun(B,D),aa(fun(C,D),fun(fun(B,C),fun(B,D)),comp(C,D,B),G),Ya) ) ) ) ).

% fun.map_cong_pred
tff(fact_5527_lcm__mult__unit2,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_lcm(B),B2),aa(B,B,aa(B,fun(B,B),times_times(B),C2),A3)) = aa(B,B,aa(B,fun(B,B),gcd_lcm(B),B2),C2) ) ) ) ).

% lcm_mult_unit2
tff(fact_5528_lcm__mult__unit1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_lcm(B),aa(B,B,aa(B,fun(B,B),times_times(B),B2),A3)),C2) = aa(B,B,aa(B,fun(B,B),gcd_lcm(B),B2),C2) ) ) ) ).

% lcm_mult_unit1
tff(fact_5529_lcm__div__unit1,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_lcm(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),B2),A3)),C2) = aa(B,B,aa(B,fun(B,B),gcd_lcm(B),B2),C2) ) ) ) ).

% lcm_div_unit1
tff(fact_5530_lcm__div__unit2,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B,B2: B,C2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,aa(B,fun(B,B),gcd_lcm(B),B2),aa(B,B,aa(B,fun(B,B),divide_divide(B),C2),A3)) = aa(B,B,aa(B,fun(B,B),gcd_lcm(B),B2),C2) ) ) ) ).

% lcm_div_unit2
tff(fact_5531_Lcm__nat__def,axiom,
    ! [M2: set(nat)] :
      gcd_Lcm(nat,M2) = $ite(finite_finite2(nat,M2),lattic5214292709420241887eutr_F(nat,gcd_lcm(nat),one_one(nat),M2),zero_zero(nat)) ).

% Lcm_nat_def
tff(fact_5532_Heap_Opred__inject,axiom,
    ! [B: $tType,P: fun(B,$o),A3: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] :
      ( aa(heap_Time_Heap(B),$o,aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),P),aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_Heap2(B),A3))
    <=> basic_pred_fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_vp(heap_ext(product_unit),$o),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),$o),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),$o),pred_option(product_prod(B,product_prod(heap_ext(product_unit),nat))),basic_pred_prod(B,product_prod(heap_ext(product_unit),nat),P,top_top(fun(product_prod(heap_ext(product_unit),nat),$o)))),A3) ) ).

% Heap.pred_inject
tff(fact_5533_Lcm__fin_Oset__eq__fold,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [Xsa: list(B)] : aa(set(B),B,semiring_gcd_Lcm_fin(B),aa(list(B),set(B),set2(B),Xsa)) = aa(B,B,fold(B,B,gcd_lcm(B),Xsa),one_one(B)) ) ).

% Lcm_fin.set_eq_fold
tff(fact_5534_pred__prod__inject,axiom,
    ! [B: $tType,C: $tType,P13: fun(B,$o),P24: fun(C,$o),A3: B,B2: C] :
      ( aa(product_prod(B,C),$o,basic_pred_prod(B,C,P13,P24),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2))
    <=> ( aa(B,$o,P13,A3)
        & aa(C,$o,P24,B2) ) ) ).

% pred_prod_inject
tff(fact_5535_fold__append,axiom,
    ! [B: $tType,C: $tType,F: fun(C,fun(B,B)),Xsa: list(C),Ys: list(C)] : fold(C,B,F,aa(list(C),list(C),aa(list(C),fun(list(C),list(C)),append(C),Xsa),Ys)) = aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),fold(C,B,F,Ys)),fold(C,B,F,Xsa)) ).

% fold_append
tff(fact_5536_pred__prod__split,axiom,
    ! [B: $tType,C: $tType,P: fun($o,$o),Q: fun(B,$o),R4: fun(C,$o),Xy: product_prod(B,C)] :
      ( aa($o,$o,P,aa(product_prod(B,C),$o,basic_pred_prod(B,C,Q,R4),Xy))
    <=> ! [X4: B,Y3: C] :
          ( ( Xy = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Y3) )
         => aa($o,$o,P,
              ( aa(B,$o,Q,X4)
              & aa(C,$o,R4,Y3) )) ) ) ).

% pred_prod_split
tff(fact_5537_pred__prod_Ocases,axiom,
    ! [B: $tType,C: $tType,P13: fun(B,$o),P24: fun(C,$o),A3: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,basic_pred_prod(B,C,P13,P24),A3)
     => ~ ! [A5: B,B3: C] :
            ( ( A3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3) )
           => ( aa(B,$o,P13,A5)
             => ~ aa(C,$o,P24,B3) ) ) ) ).

% pred_prod.cases
tff(fact_5538_pred__prod_Osimps,axiom,
    ! [B: $tType,C: $tType,P13: fun(B,$o),P24: fun(C,$o),A3: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,basic_pred_prod(B,C,P13,P24),A3)
    <=> ? [A7: B,B7: C] :
          ( ( A3 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A7),B7) )
          & aa(B,$o,P13,A7)
          & aa(C,$o,P24,B7) ) ) ).

% pred_prod.simps
tff(fact_5539_pred__prod_Ointros,axiom,
    ! [B: $tType,C: $tType,P13: fun(B,$o),A3: B,P24: fun(C,$o),B2: C] :
      ( aa(B,$o,P13,A3)
     => ( aa(C,$o,P24,B2)
       => aa(product_prod(B,C),$o,basic_pred_prod(B,C,P13,P24),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A3),B2)) ) ) ).

% pred_prod.intros
tff(fact_5540_fold__Cons,axiom,
    ! [B: $tType,C: $tType,F: fun(C,fun(B,B)),X2: C,Xsa: list(C)] : fold(C,B,F,aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),X2),Xsa)) = aa(fun(B,B),fun(B,B),aa(fun(B,B),fun(fun(B,B),fun(B,B)),comp(B,B,B),fold(C,B,F,Xsa)),aa(C,fun(B,B),F,X2)) ).

% fold_Cons
tff(fact_5541_fold__commute__apply,axiom,
    ! [B: $tType,D: $tType,C: $tType,Xsa: list(B),Ha: fun(C,D),G: fun(B,fun(C,C)),F: fun(B,fun(D,D)),S: C] :
      ( ! [X3: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( aa(fun(C,C),fun(C,D),aa(fun(C,D),fun(fun(C,C),fun(C,D)),comp(C,D,C),Ha),aa(B,fun(C,C),G,X3)) = aa(fun(C,D),fun(C,D),aa(fun(D,D),fun(fun(C,D),fun(C,D)),comp(D,D,C),aa(B,fun(D,D),F,X3)),Ha) ) )
     => ( aa(C,D,Ha,aa(C,C,fold(B,C,G,Xsa),S)) = aa(D,D,fold(B,D,F,Xsa),aa(C,D,Ha,S)) ) ) ).

% fold_commute_apply
tff(fact_5542_fold__commute,axiom,
    ! [B: $tType,D: $tType,C: $tType,Xsa: list(B),Ha: fun(C,D),G: fun(B,fun(C,C)),F: fun(B,fun(D,D))] :
      ( ! [X3: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( aa(fun(C,C),fun(C,D),aa(fun(C,D),fun(fun(C,C),fun(C,D)),comp(C,D,C),Ha),aa(B,fun(C,C),G,X3)) = aa(fun(C,D),fun(C,D),aa(fun(D,D),fun(fun(C,D),fun(C,D)),comp(D,D,C),aa(B,fun(D,D),F,X3)),Ha) ) )
     => ( aa(fun(C,C),fun(C,D),aa(fun(C,D),fun(fun(C,C),fun(C,D)),comp(C,D,C),Ha),fold(B,C,G,Xsa)) = aa(fun(C,D),fun(C,D),aa(fun(D,D),fun(fun(C,D),fun(C,D)),comp(D,D,C),fold(B,D,F,Xsa)),Ha) ) ) ).

% fold_commute
tff(fact_5543_Lcm__nat__set__eq__fold,axiom,
    ! [Xsa: list(nat)] : gcd_Lcm(nat,aa(list(nat),set(nat),set2(nat),Xsa)) = aa(nat,nat,fold(nat,nat,gcd_lcm(nat),Xsa),one_one(nat)) ).

% Lcm_nat_set_eq_fold
tff(fact_5544_fold__multiset__equiv,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),F: fun(B,fun(C,C)),Ys: list(B)] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( member(B,Y4,aa(list(B),set(B),set2(B),Xsa))
           => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,Y4)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y4)),aa(B,fun(C,C),F,X3)) ) ) )
     => ( ( mset(B,Xsa) = mset(B,Ys) )
       => ( fold(B,C,F,Xsa) = fold(B,C,F,Ys) ) ) ) ).

% fold_multiset_equiv
tff(fact_5545_fold__rev,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),F: fun(B,fun(C,C))] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( member(B,Y4,aa(list(B),set(B),set2(B),Xsa))
           => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y4)),aa(B,fun(C,C),F,X3)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,Y4)) ) ) )
     => ( fold(B,C,F,rev(B,Xsa)) = fold(B,C,F,Xsa) ) ) ).

% fold_rev
tff(fact_5546_foldr__fold,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),F: fun(B,fun(C,C))] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( member(B,Y4,aa(list(B),set(B),set2(B),Xsa))
           => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y4)),aa(B,fun(C,C),F,X3)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,Y4)) ) ) )
     => ( foldr(B,C,F,Xsa) = fold(B,C,F,Xsa) ) ) ).

% foldr_fold
tff(fact_5547_fold__plus__sum__list__rev,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => ! [Xsa: list(B)] : fold(B,B,plus_plus(B),Xsa) = aa(B,fun(B,B),plus_plus(B),aa(list(B),B,groups8242544230860333062m_list(B),rev(B,Xsa))) ) ).

% fold_plus_sum_list_rev
tff(fact_5548_fold__remove1__split,axiom,
    ! [C: $tType,B: $tType,Xsa: list(B),F: fun(B,fun(C,C)),X2: B] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,aa(list(B),set(B),set2(B),Xsa))
         => ( member(B,Y4,aa(list(B),set(B),set2(B),Xsa))
           => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,Y4)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y4)),aa(B,fun(C,C),F,X3)) ) ) )
     => ( member(B,X2,aa(list(B),set(B),set2(B),Xsa))
       => ( fold(B,C,F,Xsa) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),fold(B,C,F,remove1(B,X2,Xsa))),aa(B,fun(C,C),F,X2)) ) ) ) ).

% fold_remove1_split
tff(fact_5549_Lcm__set__eq__fold,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [Xsa: list(B)] : gcd_Lcm(B,aa(list(B),set(B),set2(B),Xsa)) = aa(B,B,fold(B,B,gcd_lcm(B),Xsa),one_one(B)) ) ).

% Lcm_set_eq_fold
tff(fact_5550_subset__mset_Omax__add__distrib__left,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B),Z2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),max(multiset(B),subseteq_mset(B),X2,Y)),Z2) = max(multiset(B),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Z2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Y),Z2)) ).

% subset_mset.max_add_distrib_left
tff(fact_5551_subset__mset_Omax__add__distrib__right,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B),Z2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),max(multiset(B),subseteq_mset(B),Y,Z2)) = max(multiset(B),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Y),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Z2)) ).

% subset_mset.max_add_distrib_right
tff(fact_5552_prod__list_Ocomm__monoid__list__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => groups1828464146339083142d_list(B,times_times(B),one_one(B)) ) ).

% prod_list.comm_monoid_list_axioms
tff(fact_5553_sum__list_Ocomm__monoid__list__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => groups1828464146339083142d_list(B,plus_plus(B),zero_zero(B)) ) ).

% sum_list.comm_monoid_list_axioms
tff(fact_5554_lazI,axiom,
    ! [B: $tType,C: $tType,A3: list(B),B2: list(C),P: fun(B,fun(C,$o))] :
      ( ( aa(list(B),nat,size_size(list(B)),A3) = aa(list(C),nat,size_size(list(C)),B2) )
     => ( ! [I2: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I2),aa(list(C),nat,size_size(list(C)),B2))
           => aa(C,$o,aa(B,fun(C,$o),P,aa(nat,B,nth(B,A3),I2)),aa(nat,C,nth(C,B2),I2)) )
       => list_all_zip(B,C,P,A3,B2) ) ) ).

% lazI
tff(fact_5555_list__all__zip__alt,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),As2: list(B),Bs2: list(C)] :
      ( list_all_zip(B,C,P,As2,Bs2)
    <=> ( ( aa(list(B),nat,size_size(list(B)),As2) = aa(list(C),nat,size_size(list(C)),Bs2) )
        & ! [I3: nat] :
            ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),As2))
           => aa(C,$o,aa(B,fun(C,$o),P,aa(nat,B,nth(B,As2),I3)),aa(nat,C,nth(C,Bs2),I3)) ) ) ) ).

% list_all_zip_alt
tff(fact_5556_is__none__bind,axiom,
    ! [B: $tType,C: $tType,F: option(C),G: fun(C,option(B))] :
      ( is_none(B,aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),F),G))
    <=> ( is_none(C,F)
        | is_none(B,aa(C,option(B),G,aa(option(C),C,the2(C),F))) ) ) ).

% is_none_bind
tff(fact_5557_laz__conj,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),Q: fun(B,fun(C,$o)),A3: list(B),B2: list(C)] :
      ( list_all_zip(B,C,aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aTP_Lamp_vq(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),P),Q),A3,B2)
    <=> ( list_all_zip(B,C,P,A3,B2)
        & list_all_zip(B,C,Q,A3,B2) ) ) ).

% laz_conj
tff(fact_5558_is__none__code_I2_J,axiom,
    ! [B: $tType,X2: B] : ~ is_none(B,aa(B,option(B),some(B),X2)) ).

% is_none_code(2)
tff(fact_5559_is__none__code_I1_J,axiom,
    ! [B: $tType] : is_none(B,none(B)) ).

% is_none_code(1)
tff(fact_5560_is__none__map__option,axiom,
    ! [B: $tType,C: $tType,F: fun(C,B),X2: option(C)] :
      ( is_none(B,aa(option(C),option(B),aa(fun(C,B),fun(option(C),option(B)),map_option(C,B),F),X2))
    <=> is_none(C,X2) ) ).

% is_none_map_option
tff(fact_5561_laz__weak__Pb,axiom,
    ! [B: $tType,C: $tType,P: fun(C,$o),A4: list(B),B5: list(C)] :
      ( list_all_zip(B,C,aTP_Lamp_vr(fun(C,$o),fun(B,fun(C,$o)),P),A4,B5)
    <=> ( ( aa(list(B),nat,size_size(list(B)),A4) = aa(list(C),nat,size_size(list(C)),B5) )
        & ! [X4: C] :
            ( member(C,X4,aa(list(C),set(C),set2(C),B5))
           => aa(C,$o,P,X4) ) ) ) ).

% laz_weak_Pb
tff(fact_5562_laz__weak__Pa,axiom,
    ! [C: $tType,B: $tType,P: fun(B,$o),A4: list(B),B5: list(C)] :
      ( list_all_zip(B,C,aTP_Lamp_vs(fun(B,$o),fun(B,fun(C,$o)),P),A4,B5)
    <=> ( ( aa(list(B),nat,size_size(list(B)),A4) = aa(list(C),nat,size_size(list(C)),B5) )
        & ! [X4: B] :
            ( member(B,X4,aa(list(B),set(B),set2(B),A4))
           => aa(B,$o,P,X4) ) ) ) ).

% laz_weak_Pa
tff(fact_5563_list__all__zip_Osimps_I1_J,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o))] : list_all_zip(B,C,P,nil(B),nil(C)) ).

% list_all_zip.simps(1)
tff(fact_5564_laz__eq,axiom,
    ! [B: $tType,A3: list(B),B2: list(B)] :
      ( list_all_zip(B,B,fequal(B),A3,B2)
    <=> ( A3 = B2 ) ) ).

% laz_eq
tff(fact_5565_laz__len,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),A3: list(B),B2: list(C)] :
      ( list_all_zip(B,C,P,A3,B2)
     => ( aa(list(B),nat,size_size(list(B)),A3) = aa(list(C),nat,size_size(list(C)),B2) ) ) ).

% laz_len
tff(fact_5566_laz__swap__ex,axiom,
    ! [C: $tType,B: $tType,D: $tType,P: fun(B,fun(C,fun(D,$o))),A4: list(B),B5: list(C)] :
      ( list_all_zip(B,C,aTP_Lamp_vt(fun(B,fun(C,fun(D,$o))),fun(B,fun(C,$o)),P),A4,B5)
     => ~ ! [C8: list(D)] :
            ( list_all_zip(B,D,aTP_Lamp_vu(fun(B,fun(C,fun(D,$o))),fun(B,fun(D,$o)),P),A4,C8)
           => ~ list_all_zip(C,D,aTP_Lamp_vv(fun(B,fun(C,fun(D,$o))),fun(C,fun(D,$o)),P),B5,C8) ) ) ).

% laz_swap_ex
tff(fact_5567_is__none__simps_I2_J,axiom,
    ! [B: $tType,X2: B] : ~ is_none(B,aa(B,option(B),some(B),X2)) ).

% is_none_simps(2)
tff(fact_5568_list__all__zip__map2,axiom,
    ! [B: $tType,C: $tType,D: $tType,P: fun(B,fun(C,$o)),As2: list(B),F: fun(D,C),Bs2: list(D)] :
      ( list_all_zip(B,C,P,As2,aa(list(D),list(C),map(D,C,F),Bs2))
    <=> list_all_zip(B,D,aa(fun(D,C),fun(B,fun(D,$o)),aTP_Lamp_ua(fun(B,fun(C,$o)),fun(fun(D,C),fun(B,fun(D,$o))),P),F),As2,Bs2) ) ).

% list_all_zip_map2
tff(fact_5569_list__all__zip__map1,axiom,
    ! [D: $tType,B: $tType,C: $tType,P: fun(B,fun(C,$o)),F: fun(D,B),As2: list(D),Bs2: list(C)] :
      ( list_all_zip(B,C,P,aa(list(D),list(B),map(D,B,F),As2),Bs2)
    <=> list_all_zip(D,C,aa(fun(D,B),fun(D,fun(C,$o)),aTP_Lamp_tz(fun(B,fun(C,$o)),fun(fun(D,B),fun(D,fun(C,$o))),P),F),As2,Bs2) ) ).

% list_all_zip_map1
tff(fact_5570_is__none__simps_I1_J,axiom,
    ! [B: $tType] : is_none(B,none(B)) ).

% is_none_simps(1)
tff(fact_5571_Option_Ois__none__def,axiom,
    ! [B: $tType,X2: option(B)] :
      ( is_none(B,X2)
    <=> ( X2 = none(B) ) ) ).

% Option.is_none_def
tff(fact_5572_list__all__zip_Osimps_I2_J,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),A3: B,As2: list(B),B2: C,Bs2: list(C)] :
      ( list_all_zip(B,C,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A3),As2),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B2),Bs2))
    <=> ( aa(C,$o,aa(B,fun(C,$o),P,A3),B2)
        & list_all_zip(B,C,P,As2,Bs2) ) ) ).

% list_all_zip.simps(2)
tff(fact_5573_list__all__zip_Oelims_I3_J,axiom,
    ! [B: $tType,C: $tType,X2: fun(B,fun(C,$o)),Xa: list(B),Xb: list(C)] :
      ( ~ list_all_zip(B,C,X2,Xa,Xb)
     => ( ! [A5: B,As: list(B)] :
            ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
           => ! [B3: C,Bs: list(C)] :
                ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs) )
               => ( aa(C,$o,aa(B,fun(C,$o),X2,A5),B3)
                  & list_all_zip(B,C,X2,As,Bs) ) ) )
       => ( ( ? [V4: B,Va: list(B)] : Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)
           => ( Xb != nil(C) ) )
         => ~ ( ( Xa = nil(B) )
             => ! [V4: C,Va: list(C)] : Xb != aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va) ) ) ) ) ).

% list_all_zip.elims(3)
tff(fact_5574_list__all__zip_Oelims_I2_J,axiom,
    ! [B: $tType,C: $tType,X2: fun(B,fun(C,$o)),Xa: list(B),Xb: list(C)] :
      ( list_all_zip(B,C,X2,Xa,Xb)
     => ( ( ( Xa = nil(B) )
         => ( Xb != nil(C) ) )
       => ~ ! [A5: B,As: list(B)] :
              ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
             => ! [B3: C,Bs: list(C)] :
                  ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs) )
                 => ~ ( aa(C,$o,aa(B,fun(C,$o),X2,A5),B3)
                      & list_all_zip(B,C,X2,As,Bs) ) ) ) ) ) ).

% list_all_zip.elims(2)
tff(fact_5575_list__all__zip_Oelims_I1_J,axiom,
    ! [C: $tType,B: $tType,X2: fun(B,fun(C,$o)),Xa: list(B),Xb: list(C),Y: $o] :
      ( ( list_all_zip(B,C,X2,Xa,Xb)
      <=> (Y) )
     => ( ( ( Xa = nil(B) )
         => ( ( Xb = nil(C) )
           => ~ (Y) ) )
       => ( ! [A5: B,As: list(B)] :
              ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
             => ! [B3: C,Bs: list(C)] :
                  ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs) )
                 => ( (Y)
                  <=> ~ ( aa(C,$o,aa(B,fun(C,$o),X2,A5),B3)
                        & list_all_zip(B,C,X2,As,Bs) ) ) ) )
         => ( ( ? [V4: B,Va: list(B)] : Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)
             => ( ( Xb = nil(C) )
               => (Y) ) )
           => ~ ( ( Xa = nil(B) )
               => ( ? [V4: C,Va: list(C)] : Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va)
                 => (Y) ) ) ) ) ) ) ).

% list_all_zip.elims(1)
tff(fact_5576_list__all__zip_Osimps_I4_J,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),V: C,Va2: list(C)] : ~ list_all_zip(B,C,P,nil(B),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V),Va2)) ).

% list_all_zip.simps(4)
tff(fact_5577_list__all__zip_Osimps_I3_J,axiom,
    ! [B: $tType,C: $tType,P: fun(B,fun(C,$o)),V: B,Va2: list(B)] : ~ list_all_zip(B,C,P,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V),Va2),nil(C)) ).

% list_all_zip.simps(3)
tff(fact_5578_the__map__option,axiom,
    ! [C: $tType,B: $tType,X2: option(B),F: fun(B,C)] :
      ( ~ is_none(B,X2)
     => ( aa(option(C),C,the2(C),aa(option(B),option(C),aa(fun(B,C),fun(option(B),option(C)),map_option(B,C),F),X2)) = aa(B,C,F,aa(option(B),B,the2(B),X2)) ) ) ).

% the_map_option
tff(fact_5579_rel__optionI,axiom,
    ! [B: $tType,C: $tType,X2: option(B),Y: option(C),P: fun(B,fun(C,$o))] :
      ( ( is_none(B,X2)
      <=> is_none(C,Y) )
     => ( ( ~ is_none(B,X2)
         => ( ~ is_none(C,Y)
           => aa(C,$o,aa(B,fun(C,$o),P,aa(option(B),B,the2(B),X2)),aa(option(C),C,the2(C),Y)) ) )
       => aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),P),X2),Y) ) ) ).

% rel_optionI
tff(fact_5580_rel__option__unfold,axiom,
    ! [B: $tType,C: $tType,R4: fun(B,fun(C,$o)),X2: option(B),Y: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4),X2),Y)
    <=> ( ( is_none(B,X2)
        <=> is_none(C,Y) )
        & ( ~ is_none(B,X2)
         => ( ~ is_none(C,Y)
           => aa(C,$o,aa(B,fun(C,$o),R4,aa(option(B),B,the2(B),X2)),aa(option(C),C,the2(C),Y)) ) ) ) ) ).

% rel_option_unfold
tff(fact_5581_list__all__zip_Opelims_I1_J,axiom,
    ! [B: $tType,C: $tType,X2: fun(B,fun(C,$o)),Xa: list(B),Xb: list(C),Y: $o] :
      ( ( list_all_zip(B,C,X2,Xa,Xb)
      <=> (Y) )
     => ( aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xa),Xb)))
       => ( ( ( Xa = nil(B) )
           => ( ( Xb = nil(C) )
             => ( (Y)
               => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),nil(C)))) ) ) )
         => ( ! [A5: B,As: list(B)] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
               => ! [B3: C,Bs: list(C)] :
                    ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs) )
                   => ( ( (Y)
                      <=> ( aa(C,$o,aa(B,fun(C,$o),X2,A5),B3)
                          & list_all_zip(B,C,X2,As,Bs) ) )
                     => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs)))) ) ) )
           => ( ! [V4: B,Va: list(B)] :
                  ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
                 => ( ( Xb = nil(C) )
                   => ( ~ (Y)
                     => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)),nil(C)))) ) ) )
             => ~ ( ( Xa = nil(B) )
                 => ! [V4: C,Va: list(C)] :
                      ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va) )
                     => ( ~ (Y)
                       => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va)))) ) ) ) ) ) ) ) ) ).

% list_all_zip.pelims(1)
tff(fact_5582_list__all__zip_Opelims_I2_J,axiom,
    ! [B: $tType,C: $tType,X2: fun(B,fun(C,$o)),Xa: list(B),Xb: list(C)] :
      ( list_all_zip(B,C,X2,Xa,Xb)
     => ( aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xa),Xb)))
       => ( ( ( Xa = nil(B) )
           => ( ( Xb = nil(C) )
             => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),nil(C)))) ) )
         => ~ ! [A5: B,As: list(B)] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
               => ! [B3: C,Bs: list(C)] :
                    ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs) )
                   => ( aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs))))
                     => ~ ( aa(C,$o,aa(B,fun(C,$o),X2,A5),B3)
                          & list_all_zip(B,C,X2,As,Bs) ) ) ) ) ) ) ) ).

% list_all_zip.pelims(2)
tff(fact_5583_list__all__zip_Opelims_I3_J,axiom,
    ! [B: $tType,C: $tType,X2: fun(B,fun(C,$o)),Xa: list(B),Xb: list(C)] :
      ( ~ list_all_zip(B,C,X2,Xa,Xb)
     => ( aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),Xa),Xb)))
       => ( ! [A5: B,As: list(B)] :
              ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As) )
             => ! [B3: C,Bs: list(C)] :
                  ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs) )
                 => ( aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A5),As)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),B3),Bs))))
                   => ( aa(C,$o,aa(B,fun(C,$o),X2,A5),B3)
                      & list_all_zip(B,C,X2,As,Bs) ) ) ) )
         => ( ! [V4: B,Va: list(B)] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va) )
               => ( ( Xb = nil(C) )
                 => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),V4),Va)),nil(C)))) ) )
           => ~ ( ( Xa = nil(B) )
               => ! [V4: C,Va: list(C)] :
                    ( ( Xb = aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va) )
                   => ~ aa(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),$o,accp(product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),list_all_zip_rel(B,C)),aa(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C))),aa(fun(B,fun(C,$o)),fun(product_prod(list(B),list(C)),product_prod(fun(B,fun(C,$o)),product_prod(list(B),list(C)))),product_Pair(fun(B,fun(C,$o)),product_prod(list(B),list(C))),X2),aa(list(C),product_prod(list(B),list(C)),aa(list(B),fun(list(C),product_prod(list(B),list(C))),product_Pair(list(B),list(C)),nil(B)),aa(list(C),list(C),aa(C,fun(list(C),list(C)),cons(C),V4),Va)))) ) ) ) ) ) ) ).

% list_all_zip.pelims(3)
tff(fact_5584_plus__multiset_Otransfer,axiom,
    ! [B: $tType] : aa(fun(multiset(B),fun(multiset(B),multiset(B))),$o,aa(fun(fun(B,nat),fun(fun(B,nat),fun(B,nat))),fun(fun(multiset(B),fun(multiset(B),multiset(B))),$o),bNF_rel_fun(fun(B,nat),multiset(B),fun(fun(B,nat),fun(B,nat)),fun(multiset(B),multiset(B)),pcr_multiset(B,B,fequal(B)),bNF_rel_fun(fun(B,nat),multiset(B),fun(B,nat),multiset(B),pcr_multiset(B,B,fequal(B)),pcr_multiset(B,B,fequal(B)))),aTP_Lamp_tq(fun(B,nat),fun(fun(B,nat),fun(B,nat)))),plus_plus(multiset(B))) ).

% plus_multiset.transfer
tff(fact_5585_map__option__o__case__sum,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,F: fun(E,D),G: fun(B,option(E)),Ha: fun(C,option(E))] : aa(fun(sum_sum(B,C),option(E)),fun(sum_sum(B,C),option(D)),aa(fun(option(E),option(D)),fun(fun(sum_sum(B,C),option(E)),fun(sum_sum(B,C),option(D))),comp(option(E),option(D),sum_sum(B,C)),aa(fun(E,D),fun(option(E),option(D)),map_option(E,D),F)),sum_case_sum(B,option(E),C,G,Ha)) = sum_case_sum(B,option(D),C,aa(fun(B,option(E)),fun(B,option(D)),aa(fun(option(E),option(D)),fun(fun(B,option(E)),fun(B,option(D))),comp(option(E),option(D),B),aa(fun(E,D),fun(option(E),option(D)),map_option(E,D),F)),G),aa(fun(C,option(E)),fun(C,option(D)),aa(fun(option(E),option(D)),fun(fun(C,option(E)),fun(C,option(D))),comp(option(E),option(D),C),aa(fun(E,D),fun(option(E),option(D)),map_option(E,D),F)),Ha)) ).

% map_option_o_case_sum
tff(fact_5586_semilattice__set_Oeq__fold_H,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),A4: set(B)] :
      ( lattic149705377957585745ce_set(B,F)
     => ( lattic1715443433743089157tice_F(B,F,A4) = aa(option(B),B,the2(B),finite_fold(B,option(B),aTP_Lamp_vw(fun(B,fun(B,B)),fun(B,fun(option(B),option(B))),F),none(B),A4)) ) ) ).

% semilattice_set.eq_fold'
tff(fact_5587_o__case__sum,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,Ha: fun(E,D),F: fun(B,E),G: fun(C,E)] : aa(fun(sum_sum(B,C),E),fun(sum_sum(B,C),D),aa(fun(E,D),fun(fun(sum_sum(B,C),E),fun(sum_sum(B,C),D)),comp(E,D,sum_sum(B,C)),Ha),sum_case_sum(B,E,C,F,G)) = sum_case_sum(B,D,C,aa(fun(B,E),fun(B,D),aa(fun(E,D),fun(fun(B,E),fun(B,D)),comp(E,D,B),Ha),F),aa(fun(C,E),fun(C,D),aa(fun(E,D),fun(fun(C,E),fun(C,D)),comp(E,D,C),Ha),G)) ).

% o_case_sum
tff(fact_5588_semilattice__set_Oinfinite,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),A4: set(B)] :
      ( lattic149705377957585745ce_set(B,F)
     => ( ~ finite_finite2(B,A4)
       => ( lattic1715443433743089157tice_F(B,F,A4) = aa(option(B),B,the2(B),none(B)) ) ) ) ).

% semilattice_set.infinite
tff(fact_5589_group_Oaxioms_I2_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( group(B,F,Z2,Inverse)
     => group_axioms(B,F,Z2,Inverse) ) ).

% group.axioms(2)
tff(fact_5590_normalize__div,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(B,B,normal6383669964737779283malize(B),A3)),A3) = aa(B,B,aa(B,fun(B,B),divide_divide(B),one_one(B)),unit_f5069060285200089521factor(B,A3)) ) ).

% normalize_div
tff(fact_5591_strict__mono__inv,axiom,
    ! [B: $tType,C: $tType] :
      ( ( linorder(C)
        & linorder(B) )
     => ! [F: fun(B,C),G: fun(C,B)] :
          ( order_strict_mono(B,C,F)
         => ( ( aa(set(B),set(C),image2(B,C,F),top_top(set(B))) = top_top(set(C)) )
           => ( ! [X3: B] : aa(C,B,G,aa(B,C,F,X3)) = X3
             => order_strict_mono(C,B,G) ) ) ) ) ).

% strict_mono_inv
tff(fact_5592_gcd_Onormalize__bottom,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ( aa(B,B,normal6383669964737779283malize(B),one_one(B)) = one_one(B) ) ) ).

% gcd.normalize_bottom
tff(fact_5593_normalize__1,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ( aa(B,B,normal6383669964737779283malize(B),one_one(B)) = one_one(B) ) ) ).

% normalize_1
tff(fact_5594_lcm_Otop__left__normalize,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),gcd_lcm(B),one_one(B)),A3) = aa(B,B,normal6383669964737779283malize(B),A3) ) ).

% lcm.top_left_normalize
tff(fact_5595_lcm_Otop__right__normalize,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => ! [A3: B] : aa(B,B,aa(B,fun(B,B),gcd_lcm(B),A3),one_one(B)) = aa(B,B,normal6383669964737779283malize(B),A3) ) ).

% lcm.top_right_normalize
tff(fact_5596_normalize__mult__unit__right,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [B2: B,A3: B] :
          ( dvd_dvd(B,B2,one_one(B))
         => ( aa(B,B,normal6383669964737779283malize(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,B,normal6383669964737779283malize(B),A3) ) ) ) ).

% normalize_mult_unit_right
tff(fact_5597_normalize__mult__unit__left,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B,B2: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,normal6383669964737779283malize(B),aa(B,B,aa(B,fun(B,B),times_times(B),A3),B2)) = aa(B,B,normal6383669964737779283malize(B),B2) ) ) ) ).

% normalize_mult_unit_left
tff(fact_5598_unit__factor__normalize,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( unit_f5069060285200089521factor(B,aa(B,B,normal6383669964737779283malize(B),A3)) = one_one(B) ) ) ) ).

% unit_factor_normalize
tff(fact_5599_normalize__unit__factor,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] :
          ( ( A3 != zero_zero(B) )
         => ( aa(B,B,normal6383669964737779283malize(B),unit_f5069060285200089521factor(B,A3)) = one_one(B) ) ) ) ).

% normalize_unit_factor
tff(fact_5600_associated__unit,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B,B2: B] :
          ( ( aa(B,B,normal6383669964737779283malize(B),A3) = aa(B,B,normal6383669964737779283malize(B),B2) )
         => ( dvd_dvd(B,A3,one_one(B))
           => dvd_dvd(B,B2,one_one(B)) ) ) ) ).

% associated_unit
tff(fact_5601_normalize__1__iff,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] :
          ( ( aa(B,B,normal6383669964737779283malize(B),A3) = one_one(B) )
        <=> dvd_dvd(B,A3,one_one(B)) ) ) ).

% normalize_1_iff
tff(fact_5602_is__unit__normalize,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] :
          ( dvd_dvd(B,A3,one_one(B))
         => ( aa(B,B,normal6383669964737779283malize(B),A3) = one_one(B) ) ) ) ).

% is_unit_normalize
tff(fact_5603_normalize__idem__imp__is__unit__iff,axiom,
    ! [B: $tType] :
      ( normal8620421768224518004emidom(B)
     => ! [A3: B] :
          ( ( aa(B,B,normal6383669964737779283malize(B),A3) = A3 )
         => ( dvd_dvd(B,A3,one_one(B))
          <=> ( A3 = one_one(B) ) ) ) ) ).

% normalize_idem_imp_is_unit_iff
tff(fact_5604_group__axioms__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( group_axioms(B,F,Z2,Inverse)
    <=> ( ! [A7: B] : aa(B,B,aa(B,fun(B,B),F,Z2),A7) = A7
        & ! [A7: B] : aa(B,B,aa(B,fun(B,B),F,aa(B,B,Inverse,A7)),A7) = Z2 ) ) ).

% group_axioms_def
tff(fact_5605_group__axioms_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( ! [A5: B] : aa(B,B,aa(B,fun(B,B),F,Z2),A5) = A5
     => ( ! [A5: B] : aa(B,B,aa(B,fun(B,B),F,aa(B,B,Inverse,A5)),A5) = Z2
       => group_axioms(B,F,Z2,Inverse) ) ) ).

% group_axioms.intro
tff(fact_5606_strict__mono__imp__inj__on,axiom,
    ! [C: $tType,B: $tType] :
      ( ( linorder(B)
        & order(C) )
     => ! [F: fun(B,C),A4: set(B)] :
          ( order_strict_mono(B,C,F)
         => inj_on(B,C,F,A4) ) ) ).

% strict_mono_imp_inj_on
tff(fact_5607_Lcm__fin_Obounded__quasi__semilattice__set__axioms,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => bounde6485984586167503788ce_set(B,gcd_lcm(B),one_one(B),zero_zero(B),normal6383669964737779283malize(B)) ) ).

% Lcm_fin.bounded_quasi_semilattice_set_axioms
tff(fact_5608_Gcd__fin_Obounded__quasi__semilattice__set__axioms,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => bounde6485984586167503788ce_set(B,gcd_gcd(B),zero_zero(B),one_one(B),normal6383669964737779283malize(B)) ) ).

% Gcd_fin.bounded_quasi_semilattice_set_axioms
tff(fact_5609_lcm_Obounded__quasi__semilattice__axioms,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => bounde8507323023520639062attice(B,gcd_lcm(B),one_one(B),zero_zero(B),normal6383669964737779283malize(B)) ) ).

% lcm.bounded_quasi_semilattice_axioms
tff(fact_5610_gcd_Obounded__quasi__semilattice__axioms,axiom,
    ! [B: $tType] :
      ( semiring_gcd(B)
     => bounde8507323023520639062attice(B,gcd_gcd(B),zero_zero(B),one_one(B),normal6383669964737779283malize(B)) ) ).

% gcd.bounded_quasi_semilattice_axioms
tff(fact_5611_group__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( group(B,F,Z2,Inverse)
    <=> ( semigroup(B,F)
        & group_axioms(B,F,Z2,Inverse) ) ) ).

% group_def
tff(fact_5612_group_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( semigroup(B,F)
     => ( group_axioms(B,F,Z2,Inverse)
       => group(B,F,Z2,Inverse) ) ) ).

% group.intro
tff(fact_5613_Predicate_Oiterate__upto_Opsimps,axiom,
    ! [B: $tType,F: fun(code_natural,B),N: code_natural,M: code_natural] :
      ( aa(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),$o,accp(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),iterate_upto_rel(B)),aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),aa(fun(code_natural,B),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,B),product_prod(code_natural,code_natural)),F),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),N),M)))
     => ( iterate_upto(B,F,N,M) = seq2(B,aa(code_natural,fun(product_unit,seq(B)),aa(code_natural,fun(code_natural,fun(product_unit,seq(B))),aTP_Lamp_vx(fun(code_natural,B),fun(code_natural,fun(code_natural,fun(product_unit,seq(B)))),F),N),M)) ) ) ).

% Predicate.iterate_upto.psimps
tff(fact_5614_group_Oaxioms_I1_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,Inverse: fun(B,B)] :
      ( group(B,F,Z2,Inverse)
     => semigroup(B,F) ) ).

% group.axioms(1)
tff(fact_5615_monoid_Oaxioms_I1_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( monoid(B,F,Z2)
     => semigroup(B,F) ) ).

% monoid.axioms(1)
tff(fact_5616_semigroup__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( semigroup(B,F)
    <=> ! [A7: B,B7: B,C4: B] : aa(B,B,aa(B,fun(B,B),F,aa(B,B,aa(B,fun(B,B),F,A7),B7)),C4) = aa(B,B,aa(B,fun(B,B),F,A7),aa(B,B,aa(B,fun(B,B),F,B7),C4)) ) ).

% semigroup_def
tff(fact_5617_semigroup_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( ! [A5: B,B3: B,C3: B] : aa(B,B,aa(B,fun(B,B),F,aa(B,B,aa(B,fun(B,B),F,A5),B3)),C3) = aa(B,B,aa(B,fun(B,B),F,A5),aa(B,B,aa(B,fun(B,B),F,B3),C3))
     => semigroup(B,F) ) ).

% semigroup.intro
tff(fact_5618_semigroup_Oassoc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),A3: B,B2: B,C2: B] :
      ( semigroup(B,F)
     => ( aa(B,B,aa(B,fun(B,B),F,aa(B,B,aa(B,fun(B,B),F,A3),B2)),C2) = aa(B,B,aa(B,fun(B,B),F,A3),aa(B,B,aa(B,fun(B,B),F,B2),C2)) ) ) ).

% semigroup.assoc
tff(fact_5619_mult_Osemigroup__axioms,axiom,
    ! [B: $tType] :
      ( semigroup_mult(B)
     => semigroup(B,times_times(B)) ) ).

% mult.semigroup_axioms
tff(fact_5620_Predicate_Oiterate__upto_Osimps,axiom,
    ! [B: $tType,F: fun(code_natural,B),N: code_natural,M: code_natural] : iterate_upto(B,F,N,M) = seq2(B,aa(code_natural,fun(product_unit,seq(B)),aa(code_natural,fun(code_natural,fun(product_unit,seq(B))),aTP_Lamp_vx(fun(code_natural,B),fun(code_natural,fun(code_natural,fun(product_unit,seq(B)))),F),N),M)) ).

% Predicate.iterate_upto.simps
tff(fact_5621_Predicate_Oiterate__upto_Oelims,axiom,
    ! [B: $tType,X2: fun(code_natural,B),Xa: code_natural,Xb: code_natural,Y: pred(B)] :
      ( ( iterate_upto(B,X2,Xa,Xb) = Y )
     => ( Y = seq2(B,aa(code_natural,fun(product_unit,seq(B)),aa(code_natural,fun(code_natural,fun(product_unit,seq(B))),aTP_Lamp_vx(fun(code_natural,B),fun(code_natural,fun(code_natural,fun(product_unit,seq(B)))),X2),Xa),Xb)) ) ) ).

% Predicate.iterate_upto.elims
tff(fact_5622_add_Osemigroup__axioms,axiom,
    ! [B: $tType] :
      ( semigroup_add(B)
     => semigroup(B,plus_plus(B)) ) ).

% add.semigroup_axioms
tff(fact_5623_Predicate_Oiterate__upto_Opelims,axiom,
    ! [B: $tType,X2: fun(code_natural,B),Xa: code_natural,Xb: code_natural,Y: pred(B)] :
      ( ( iterate_upto(B,X2,Xa,Xb) = Y )
     => ( aa(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),$o,accp(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),iterate_upto_rel(B)),aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),aa(fun(code_natural,B),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,B),product_prod(code_natural,code_natural)),X2),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),Xa),Xb)))
       => ~ ( ( Y = seq2(B,aa(code_natural,fun(product_unit,seq(B)),aa(code_natural,fun(code_natural,fun(product_unit,seq(B))),aTP_Lamp_vx(fun(code_natural,B),fun(code_natural,fun(code_natural,fun(product_unit,seq(B)))),X2),Xa),Xb)) )
           => ~ aa(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),$o,accp(product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),iterate_upto_rel(B)),aa(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural)),aa(fun(code_natural,B),fun(product_prod(code_natural,code_natural),product_prod(fun(code_natural,B),product_prod(code_natural,code_natural))),product_Pair(fun(code_natural,B),product_prod(code_natural,code_natural)),X2),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),Xa),Xb))) ) ) ) ).

% Predicate.iterate_upto.pelims
tff(fact_5624_Random__Pred_Oiterate__upto__def,axiom,
    ! [B: $tType,F: fun(code_natural,B),N: code_natural,M: code_natural] : random_iterate_upto(B,F,N,M) = aa(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),product_Pair(pred(B),product_prod(code_natural,code_natural)),iterate_upto(B,F,N,M)) ).

% Random_Pred.iterate_upto_def
tff(fact_5625_monoid_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( semigroup(B,F)
     => ( monoid_axioms(B,F,Z2)
       => monoid(B,F,Z2) ) ) ).

% monoid.intro
tff(fact_5626_monoid__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( monoid(B,F,Z2)
    <=> ( semigroup(B,F)
        & monoid_axioms(B,F,Z2) ) ) ).

% monoid_def
tff(fact_5627_monoid__axioms_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( ! [A5: B] : aa(B,B,aa(B,fun(B,B),F,Z2),A5) = A5
     => ( ! [A5: B] : aa(B,B,aa(B,fun(B,B),F,A5),Z2) = A5
       => monoid_axioms(B,F,Z2) ) ) ).

% monoid_axioms.intro
tff(fact_5628_monoid__axioms__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( monoid_axioms(B,F,Z2)
    <=> ( ! [A7: B] : aa(B,B,aa(B,fun(B,B),F,Z2),A7) = A7
        & ! [A7: B] : aa(B,B,aa(B,fun(B,B),F,A7),Z2) = A7 ) ) ).

% monoid_axioms_def
tff(fact_5629_monoid_Oaxioms_I2_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( monoid(B,F,Z2)
     => monoid_axioms(B,F,Z2) ) ).

% monoid.axioms(2)
tff(fact_5630_mod__h__bot__normalize,axiom,
    ! [B: $tType,Ha: heap_ext(product_unit),P: assn] :
      ( syntax7388354845996824322omatch(B,heap_ext(product_unit),undefined(B),Ha)
     => ( rep_assn(P,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)),Ha),bot_bot(set(nat))))
      <=> rep_assn(P,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_5631_image__bind,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(C,B),A4: set(D),G: fun(D,set(C))] : aa(set(C),set(B),image2(C,B,F),bind3(D,C,A4,G)) = bind3(D,B,A4,aa(fun(D,set(C)),fun(D,set(B)),aa(fun(set(C),set(B)),fun(fun(D,set(C)),fun(D,set(B))),comp(set(C),set(B),D),image2(C,B,F)),G)) ).

% image_bind
tff(fact_5632_pure__assn__raw_Ocases,axiom,
    ! [B: $tType,C: $tType,X2: product_prod($o,product_prod(B,set(C)))] :
      ~ ! [B3: $o,H: B,As: set(C)] : X2 != aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(B3)),aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As)) ).

% pure_assn_raw.cases
tff(fact_5633_mod__h__bot__iff_I7_J,axiom,
    ! [P: assn,Q: assn,Ha: heap_ext(product_unit)] :
      ( rep_assn(aa(assn,assn,aa(assn,fun(assn,assn),sup_sup(assn),P),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)),Ha),bot_bot(set(nat))))
    <=> ( rep_assn(P,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)),Ha),bot_bot(set(nat))))
        | 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)),Ha),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_iff(7)
tff(fact_5634_mod__h__bot__iff_I5_J,axiom,
    ! [P: assn,Q: assn,Ha: heap_ext(product_unit)] :
      ( rep_assn(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),P),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)),Ha),bot_bot(set(nat))))
    <=> ( rep_assn(P,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)),Ha),bot_bot(set(nat))))
        & 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)),Ha),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_iff(5)
tff(fact_5635_mod__h__bot__iff_I6_J,axiom,
    ! [P: assn,Q: assn,Ha: heap_ext(product_unit)] :
      ( rep_assn(aa(assn,assn,inf_inf(assn,P),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)),Ha),bot_bot(set(nat))))
    <=> ( rep_assn(P,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)),Ha),bot_bot(set(nat))))
        & 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)),Ha),bot_bot(set(nat)))) ) ) ).

% mod_h_bot_iff(6)
tff(fact_5636_mod__h__bot__iff_I2_J,axiom,
    ! [Ha: heap_ext(product_unit)] : 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)),Ha),bot_bot(set(nat)))) ).

% mod_h_bot_iff(2)
tff(fact_5637_times__assn__raw_Ocases,axiom,
    ! [X2: 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))))] :
      ~ ! [P4: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q7: fun(product_prod(heap_ext(product_unit),set(nat)),$o),H: heap_ext(product_unit),As: set(nat)] : X2 != 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)))),P4),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))),Q7),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),As))) ).

% times_assn_raw.cases
tff(fact_5638_sngr__assn__raw_Ocases,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))] :
          ~ ! [R2: ref(B),X3: B,H: heap_ext(product_unit),As: set(nat)] : X2 != aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),R2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,product_prod(heap_ext(product_unit),set(nat))),X3),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),As))) ) ).

% sngr_assn_raw.cases
tff(fact_5639_snga__assn__raw_Ocases,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))] :
          ~ ! [R2: array(B),X3: list(B),H: heap_ext(product_unit),As: set(nat)] : X2 != aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),R2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),product_prod(heap_ext(product_unit),set(nat))),X3),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),As))) ) ).

% snga_assn_raw.cases
tff(fact_5640_one__assn__raw_Ocases,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ~ ! [H: heap_ext(product_unit),As: 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)),H),As) ).

% one_assn_raw.cases
tff(fact_5641_mod__star__conv,axiom,
    ! [A4: assn,B5: assn,Ha: product_prod(heap_ext(product_unit),set(nat))] :
      ( rep_assn(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),A4),B5),Ha)
    <=> ? [Hr: heap_ext(product_unit),As1: set(nat),As22: set(nat)] :
          ( ( Ha = 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),inf_inf(set(nat),As1),As22) = bot_bot(set(nat)) )
          & 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))
          & rep_assn(B5,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_5642_star__assnI,axiom,
    ! [P: assn,Ha: heap_ext(product_unit),As2: set(nat),Q: assn,As4: set(nat)] :
      ( rep_assn(P,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)),Ha),As2))
     => ( 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)),Ha),As4))
       => ( ( aa(set(nat),set(nat),inf_inf(set(nat),As2),As4) = bot_bot(set(nat)) )
         => rep_assn(aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),P),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)),Ha),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As4))) ) ) ) ).

% star_assnI
tff(fact_5643_mod__emp__simp,axiom,
    ! [Ha: heap_ext(product_unit)] : 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)),Ha),bot_bot(set(nat)))) ).

% mod_emp_simp
tff(fact_5644_mod__h__bot__indep,axiom,
    ! [P: assn,Ha: heap_ext(product_unit),H2: heap_ext(product_unit)] :
      ( rep_assn(P,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)),Ha),bot_bot(set(nat))))
    <=> rep_assn(P,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),bot_bot(set(nat)))) ) ).

% mod_h_bot_indep
tff(fact_5645_bind__image,axiom,
    ! [B: $tType,C: $tType,D: $tType,F: fun(D,C),A4: set(D),G: fun(C,set(B))] : bind3(C,B,aa(set(D),set(C),image2(D,C,F),A4),G) = bind3(D,B,A4,aa(fun(D,C),fun(D,set(B)),aa(fun(C,set(B)),fun(fun(D,C),fun(D,set(B))),comp(C,set(B),D),G),F)) ).

% bind_image
tff(fact_5646_mod__h__bot__iff_I3_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [P3: ref(B),X2: B,Ha: heap_ext(product_unit)] : ~ rep_assn(sngr_assn(B,P3,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)),Ha),bot_bot(set(nat)))) ) ).

% mod_h_bot_iff(3)
tff(fact_5647_mod__h__bot__iff_I4_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Q3: array(B),Y: list(B),Ha: heap_ext(product_unit)] : ~ rep_assn(snga_assn(B,Q3,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)),Ha),bot_bot(set(nat)))) ) ).

% mod_h_bot_iff(4)
tff(fact_5648_times__assn__raw_Osimps,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Ha: heap_ext(product_unit),As2: set(nat)] :
      ( times_assn_raw(P,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)),Ha),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),inf_inf(set(nat),As1),As22) = bot_bot(set(nat)) )
          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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)),Ha),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)),Ha),As22)) ) ) ).

% times_assn_raw.simps
tff(fact_5649_times__assn__raw_Oelims_I3_J,axiom,
    ! [X2: 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))] :
      ( ~ times_assn_raw(X2,Xa,Xb)
     => ~ ! [H: 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)),H),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),inf_inf(set(nat),As12),As23) = bot_bot(set(nat)) )
                & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),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)),H),As23)) ) ) ) ).

% times_assn_raw.elims(3)
tff(fact_5650_times__assn__raw_Oelims_I2_J,axiom,
    ! [X2: 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))] :
      ( times_assn_raw(X2,Xa,Xb)
     => ~ ! [H: 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)),H),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),inf_inf(set(nat),As13),As24) = bot_bot(set(nat)) )
                  & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),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)),H),As24)) ) ) ) ).

% times_assn_raw.elims(2)
tff(fact_5651_times__assn__raw_Oelims_I1_J,axiom,
    ! [X2: 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] :
      ( ( times_assn_raw(X2,Xa,Xb)
      <=> (Y) )
     => ~ ! [H: 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)),H),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),inf_inf(set(nat),As1),As22) = bot_bot(set(nat)) )
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),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)),H),As22)) ) ) ) ) ).

% times_assn_raw.elims(1)
tff(fact_5652_times__assn__raw_Opelims_I1_J,axiom,
    ! [X2: 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] :
      ( ( times_assn_raw(X2,Xa,Xb)
      <=> (Y) )
     => ( aa(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,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)))),X2),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)))
       => ~ ! [H: 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)),H),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),inf_inf(set(nat),As1),As22) = bot_bot(set(nat)) )
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),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)),H),As22)) ) )
               => ~ aa(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,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)))),X2),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)),H),As)))) ) ) ) ) ).

% times_assn_raw.pelims(1)
tff(fact_5653_times__assn__raw_Opelims_I2_J,axiom,
    ! [X2: 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))] :
      ( times_assn_raw(X2,Xa,Xb)
     => ( aa(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,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)))),X2),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)))
       => ~ ! [H: 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)),H),As) )
             => ( aa(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,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)))),X2),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)),H),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),inf_inf(set(nat),As13),As24) = bot_bot(set(nat)) )
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),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)),H),As24)) ) ) ) ) ) ).

% times_assn_raw.pelims(2)
tff(fact_5654_times__assn__raw_Opelims_I3_J,axiom,
    ! [X2: 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))] :
      ( ~ times_assn_raw(X2,Xa,Xb)
     => ( aa(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,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)))),X2),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)))
       => ~ ! [H: 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)),H),As) )
             => ( aa(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,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)))),X2),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)),H),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),inf_inf(set(nat),As12),As23) = bot_bot(set(nat)) )
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),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)),H),As23)) ) ) ) ) ) ).

% times_assn_raw.pelims(3)
tff(fact_5655_mod__h__bot__iff_I8_J,axiom,
    ! [B: $tType,R4: fun(B,assn),Ha: heap_ext(product_unit)] :
      ( rep_assn(ex_assn(B,R4),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)),Ha),bot_bot(set(nat))))
    <=> ? [X4: B] : rep_assn(aa(B,assn,R4,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)),Ha),bot_bot(set(nat)))) ) ).

% mod_h_bot_iff(8)
tff(fact_5656_make__rule,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,F: fun(nat,B)] : hoare_hoare_triple(array(B),one_one(assn),array_make(B,N,F),aa(fun(nat,B),fun(array(B),assn),aTP_Lamp_vy(nat,fun(fun(nat,B),fun(array(B),assn)),N),F)) ) ).

% make_rule
tff(fact_5657_mod__h__bot__iff_I1_J,axiom,
    ! [B2: $o,Ha: heap_ext(product_unit)] :
      ( 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)),Ha),bot_bot(set(nat))))
    <=> (B2) ) ).

% mod_h_bot_iff(1)
tff(fact_5658_bind__rule,axiom,
    ! [B: $tType,C: $tType,P: assn,F: heap_Time_Heap(B),R4: fun(B,assn),G: fun(B,heap_Time_Heap(C)),Q: fun(C,assn)] :
      ( hoare_hoare_triple(B,P,F,R4)
     => ( ! [X3: B] : hoare_hoare_triple(C,aa(B,assn,R4,X3),aa(B,heap_Time_Heap(C),G,X3),Q)
       => hoare_hoare_triple(C,P,heap_Time_bind(B,C,F,G),Q) ) ) ).

% bind_rule
tff(fact_5659_raise__iff,axiom,
    ! [B: $tType,P: assn,S: list(char),Q: fun(B,assn)] :
      ( hoare_hoare_triple(B,P,heap_Time_raise(B,S),Q)
    <=> ( P = bot_bot(assn) ) ) ).

% raise_iff
tff(fact_5660_raise__rule,axiom,
    ! [B: $tType,S: list(char),Q: fun(B,assn)] : hoare_hoare_triple(B,bot_bot(assn),heap_Time_raise(B,S),Q) ).

% raise_rule
tff(fact_5661_bind__rule_H,axiom,
    ! [B: $tType,C: $tType,D: $tType,P: assn,F: heap_Time_Heap(C),R4: fun(C,assn),G: fun(C,heap_Time_Heap(D)),Q: fun(D,assn)] :
      ( ! [R2: B] : hoare_hoare_triple(C,P,F,aa(fun(C,assn),fun(C,assn),aTP_Lamp_vz(assn,fun(fun(C,assn),fun(C,assn)),P),R4))
     => ( ! [X3: C] : hoare_hoare_triple(D,aa(assn,assn,aa(assn,fun(assn,assn),times_times(assn),aa(C,assn,R4,X3)),P),aa(C,heap_Time_Heap(D),G,X3),Q)
       => hoare_hoare_triple(D,P,heap_Time_bind(C,D,F,G),Q) ) ) ).

% bind_rule'
tff(fact_5662_case__prod__rule,axiom,
    ! [B: $tType,C: $tType,D: $tType,X2: product_prod(B,C),P: assn,F: fun(B,fun(C,heap_Time_Heap(D))),Q: fun(D,assn)] :
      ( ! [A5: B,B3: C] :
          ( ( X2 = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3) )
         => hoare_hoare_triple(D,P,aa(C,heap_Time_Heap(D),aa(B,fun(C,heap_Time_Heap(D)),F,A5),B3),Q) )
     => hoare_hoare_triple(D,P,aa(product_prod(B,C),heap_Time_Heap(D),aa(fun(B,fun(C,heap_Time_Heap(D))),fun(product_prod(B,C),heap_Time_Heap(D)),product_case_prod(B,C,heap_Time_Heap(D)),F),X2),Q) ) ).

% case_prod_rule
tff(fact_5663_hoare__triple__success,axiom,
    ! [B: $tType,P: assn,C2: heap_Time_Heap(B),Q: fun(B,assn),Ha: heap_ext(product_unit),As2: set(nat)] :
      ( hoare_hoare_triple(B,P,C2,Q)
     => ( rep_assn(P,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)),Ha),As2))
       => heap_Time_success(B,C2,Ha) ) ) ).

% hoare_triple_success
tff(fact_5664_case__option__rule,axiom,
    ! [B: $tType,C: $tType,V: option(B),P: assn,Fn: heap_Time_Heap(C),Q: fun(C,assn),Fs: fun(B,heap_Time_Heap(C))] :
      ( ( ( V = none(B) )
       => hoare_hoare_triple(C,P,Fn,Q) )
     => ( ! [X3: B] :
            ( ( V = aa(B,option(B),some(B),X3) )
           => hoare_hoare_triple(C,P,aa(B,heap_Time_Heap(C),Fs,X3),Q) )
       => hoare_hoare_triple(C,P,aa(option(B),heap_Time_Heap(C),aa(fun(B,heap_Time_Heap(C)),fun(option(B),heap_Time_Heap(C)),aa(heap_Time_Heap(C),fun(fun(B,heap_Time_Heap(C)),fun(option(B),heap_Time_Heap(C))),case_option(heap_Time_Heap(C),B),Fn),Fs),V),Q) ) ) ).

% case_option_rule
tff(fact_5665_of__list__rule,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B)] : hoare_hoare_triple(array(B),one_one(assn),array_of_list(B,Xsa),aTP_Lamp_wa(list(B),fun(array(B),assn),Xsa)) ) ).

% of_list_rule
tff(fact_5666_new__rule,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [N: nat,X2: B] : hoare_hoare_triple(array(B),one_one(assn),aa(B,heap_Time_Heap(array(B)),aa(nat,fun(B,heap_Time_Heap(array(B))),array_new(B),N),X2),aa(B,fun(array(B),assn),aTP_Lamp_wb(nat,fun(B,fun(array(B),assn)),N),X2)) ) ).

% new_rule
tff(fact_5667_hoare__triple__effect,axiom,
    ! [B: $tType,P: assn,C2: heap_Time_Heap(B),Q: fun(B,assn),Ha: heap_ext(product_unit),As2: set(nat)] :
      ( hoare_hoare_triple(B,P,C2,Q)
     => ( rep_assn(P,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)),Ha),As2))
       => ? [H4: heap_ext(product_unit),R2: B,T6: nat] :
            ( heap_Time_effect(B,C2,Ha,H4,R2,T6)
            & rep_assn(aa(B,assn,Q,R2),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),hoare_new_addrs(Ha,As2,H4))) ) ) ) ).

% hoare_triple_effect
tff(fact_5668_hoare__triple__def,axiom,
    ! [B: $tType,P: assn,C2: heap_Time_Heap(B),Q: fun(B,assn)] :
      ( hoare_hoare_triple(B,P,C2,Q)
    <=> ! [H6: heap_ext(product_unit),As5: set(nat)] :
          ( rep_assn(P,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),As5))
         => ? [R5: B,H7: heap_ext(product_unit)] :
              ( ? [T7: nat] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),H6) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R5),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H7),T7)))
              & rep_assn(aa(B,assn,Q,R5),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),hoare_new_addrs(H6,As5,H7)))
              & relH(aa(fun(nat,$o),set(nat),collect(nat),aa(set(nat),fun(nat,$o),aTP_Lamp_wc(heap_ext(product_unit),fun(set(nat),fun(nat,$o)),H6),As5)),H6,H7)
              & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),lim(product_unit,H6)),lim(product_unit,H7)) ) ) ) ).

% hoare_triple_def
tff(fact_5669_hoare__tripleI,axiom,
    ! [B: $tType,P: assn,C2: heap_Time_Heap(B),Q: fun(B,assn)] :
      ( ! [H: heap_ext(product_unit),As: set(nat)] :
          ( rep_assn(P,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),As))
         => ? [R14: B,H8: heap_ext(product_unit),T8: nat] :
              ( ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),H) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R14),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H8),T8))) )
              & rep_assn(aa(B,assn,Q,R14),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)),H8),hoare_new_addrs(H,As,H8)))
              & relH(aa(fun(nat,$o),set(nat),collect(nat),aa(set(nat),fun(nat,$o),aTP_Lamp_wc(heap_ext(product_unit),fun(set(nat),fun(nat,$o)),H),As)),H,H8)
              & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),lim(product_unit,H)),lim(product_unit,H8)) ) )
     => hoare_hoare_triple(B,P,C2,Q) ) ).

% hoare_tripleI
tff(fact_5670_mod__relH,axiom,
    ! [As2: set(nat),Ha: heap_ext(product_unit),H2: heap_ext(product_unit),P: assn] :
      ( relH(As2,Ha,H2)
     => ( rep_assn(P,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)),Ha),As2))
      <=> rep_assn(P,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),As2)) ) ) ).

% mod_relH
tff(fact_5671_hoare__tripleE,axiom,
    ! [B: $tType,P: assn,C2: heap_Time_Heap(B),Q: fun(B,assn),Ha: heap_ext(product_unit),As2: set(nat)] :
      ( hoare_hoare_triple(B,P,C2,Q)
     => ( rep_assn(P,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)),Ha),As2))
       => ~ ! [R2: B,H4: heap_ext(product_unit)] :
              ( ? [T6: nat] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),C2),Ha) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),R2),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),H4),T6)))
             => ( rep_assn(aa(B,assn,Q,R2),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),hoare_new_addrs(Ha,As2,H4)))
               => ( relH(aa(fun(nat,$o),set(nat),collect(nat),aa(set(nat),fun(nat,$o),aTP_Lamp_wc(heap_ext(product_unit),fun(set(nat),fun(nat,$o)),Ha),As2)),Ha,H4)
                 => ~ aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),lim(product_unit,Ha)),lim(product_unit,H4)) ) ) ) ) ) ).

% hoare_tripleE
tff(fact_5672_Array__Time_Oalloc__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Xsa: list(B),Ha: heap_ext(product_unit)] :
          array_alloc(B,Xsa,Ha) = $let(
            l: nat,
            l:= lim(product_unit,Ha),
            $let(
              r: array(B),
              r:= array2(B,l),
              aa(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),heap_ext(product_unit))),product_Pair(array(B),heap_ext(product_unit)),r),aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,r,Xsa),lim_update(product_unit,aTP_Lamp_wd(nat,fun(nat,nat),l),Ha))) ) ) ) ).

% Array_Time.alloc_def
tff(fact_5673_snga__assn__raw_Opelims_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: array(B),Xa: list(B),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( snga_assn_raw(B,X2,Xa,Xb)
          <=> (Y) )
         => ( aa(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(B)),aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H: 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)),H),As) )
                 => ( ( (Y)
                    <=> ( ( array_get(B,H,X2) = Xa )
                        & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,X2)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,X2)),lim(product_unit,H)) ) )
                   => ~ aa(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(B)),aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),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)),H),As)))) ) ) ) ) ) ).

% snga_assn_raw.pelims(1)
tff(fact_5674_snga__assn__raw_Opelims_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: array(B),Xa: list(B),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( snga_assn_raw(B,X2,Xa,Xb)
         => ( aa(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(B)),aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H: 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)),H),As) )
                 => ( aa(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(B)),aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),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)),H),As))))
                   => ~ ( ( array_get(B,H,X2) = Xa )
                        & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,X2)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,X2)),lim(product_unit,H)) ) ) ) ) ) ) ).

% snga_assn_raw.pelims(2)
tff(fact_5675_Array__Time_Opresent__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B)] :
          ( aa(array(B),$o,array_present(B,Ha),A3)
        <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,A3)),lim(product_unit,Ha)) ) ) ).

% Array_Time.present_def
tff(fact_5676_snga__assn__raw_Osimps,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: array(B),X2: list(B),Ha: heap_ext(product_unit),As2: set(nat)] :
          ( snga_assn_raw(B,R,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)),Ha),As2))
        <=> ( ( array_get(B,Ha,R) = X2 )
            & ( As2 = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,R)),bot_bot(set(nat))) )
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,R)),lim(product_unit,Ha)) ) ) ) ).

% snga_assn_raw.simps
tff(fact_5677_snga__assn__raw_Oelims_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: array(B),Xa: list(B),Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( snga_assn_raw(B,X2,Xa,Xb)
          <=> (Y) )
         => ~ ! [H: 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)),H),As) )
               => ( (Y)
                <=> ~ ( ( array_get(B,H,X2) = Xa )
                      & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,X2)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,X2)),lim(product_unit,H)) ) ) ) ) ) ).

% snga_assn_raw.elims(1)
tff(fact_5678_snga__assn__raw_Oelims_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: array(B),Xa: list(B),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( snga_assn_raw(B,X2,Xa,Xb)
         => ~ ! [H: 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)),H),As) )
               => ~ ( ( array_get(B,H,X2) = Xa )
                    & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,X2)),bot_bot(set(nat))) )
                    & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,X2)),lim(product_unit,H)) ) ) ) ) ).

% snga_assn_raw.elims(2)
tff(fact_5679_snga__assn__raw_Oelims_I3_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: array(B),Xa: list(B),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ snga_assn_raw(B,X2,Xa,Xb)
         => ~ ! [H: 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)),H),As) )
               => ( ( array_get(B,H,X2) = Xa )
                  & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,X2)),bot_bot(set(nat))) )
                  & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,X2)),lim(product_unit,H)) ) ) ) ) ).

% snga_assn_raw.elims(3)
tff(fact_5680_snga__assn__raw_Opelims_I3_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: array(B),Xa: list(B),Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ snga_assn_raw(B,X2,Xa,Xb)
         => ( aa(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(B)),aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H: 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)),H),As) )
                 => ( aa(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),snga_assn_raw_rel(B)),aa(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),aa(array(B),fun(product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),product_prod(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))))),product_Pair(array(B),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat))),aa(list(B),fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(list(B),product_prod(heap_ext(product_unit),set(nat)))),product_Pair(list(B),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)),H),As))))
                   => ( ( array_get(B,H,X2) = Xa )
                      & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_array(B,X2)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_array(B,X2)),lim(product_unit,H)) ) ) ) ) ) ) ).

% snga_assn_raw.pelims(3)
tff(fact_5681_relH__set__array,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: array(B),As2: set(nat),Ha: heap_ext(product_unit),X2: list(B)] :
          ( ~ member(nat,addr_of_array(B,R),As2)
         => ( 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)),Ha),As2))
           => relH(As2,Ha,aa(heap_ext(product_unit),heap_ext(product_unit),array_set(B,R,X2),Ha)) ) ) ) ).

% relH_set_array
tff(fact_5682_sngr__assn__raw_Opelims_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: ref(B),Xa: B,Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( sngr_assn_raw(B,X2,Xa,Xb)
          <=> (Y) )
         => ( aa(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(B)),aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H: 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)),H),As) )
                 => ( ( (Y)
                    <=> ( ( ref_get(B,H,X2) = Xa )
                        & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,X2)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,X2)),lim(product_unit,H)) ) )
                   => ~ aa(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(B)),aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,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)),H),As)))) ) ) ) ) ) ).

% sngr_assn_raw.pelims(1)
tff(fact_5683_sngr__assn__raw_Opelims_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: ref(B),Xa: B,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( sngr_assn_raw(B,X2,Xa,Xb)
         => ( aa(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(B)),aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H: 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)),H),As) )
                 => ( aa(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(B)),aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,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)),H),As))))
                   => ~ ( ( ref_get(B,H,X2) = Xa )
                        & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,X2)),bot_bot(set(nat))) )
                        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,X2)),lim(product_unit,H)) ) ) ) ) ) ) ).

% sngr_assn_raw.pelims(2)
tff(fact_5684_in__range__empty,axiom,
    ! [Ha: heap_ext(product_unit)] : 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)),Ha),bot_bot(set(nat)))) ).

% in_range_empty
tff(fact_5685_in__range__dist__union,axiom,
    ! [Ha: heap_ext(product_unit),As2: set(nat),As4: set(nat)] :
      ( 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)),Ha),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As4)))
    <=> ( 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)),Ha),As2))
        & 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)),Ha),As4)) ) ) ).

% in_range_dist_union
tff(fact_5686_relH__set__ref,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),As2: set(nat),Ha: heap_ext(product_unit),X2: B] :
          ( ~ member(nat,addr_of_ref(B,R),As2)
         => ( 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)),Ha),As2))
           => relH(As2,Ha,ref_set(B,R,X2,Ha)) ) ) ) ).

% relH_set_ref
tff(fact_5687_relH__refl,axiom,
    ! [Ha: heap_ext(product_unit),As2: set(nat)] :
      ( 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)),Ha),As2))
     => relH(As2,Ha,Ha) ) ).

% relH_refl
tff(fact_5688_relH__in__rangeI_I1_J,axiom,
    ! [As2: set(nat),Ha: heap_ext(product_unit),H2: heap_ext(product_unit)] :
      ( relH(As2,Ha,H2)
     => 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)),Ha),As2)) ) ).

% relH_in_rangeI(1)
tff(fact_5689_relH__in__rangeI_I2_J,axiom,
    ! [As2: set(nat),Ha: heap_ext(product_unit),H2: heap_ext(product_unit)] :
      ( relH(As2,Ha,H2)
     => 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),As2)) ) ).

% relH_in_rangeI(2)
tff(fact_5690_in__range__subset,axiom,
    ! [As2: set(nat),As4: set(nat),Ha: heap_ext(product_unit)] :
      ( aa(set(nat),$o,aa(set(nat),fun(set(nat),$o),ord_less_eq(set(nat)),As2),As4)
     => ( 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)),Ha),As4))
       => 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)),Ha),As2)) ) ) ).

% in_range_subset
tff(fact_5691_in__range_Oelims_I3_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ in_range(X2)
     => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
           => ! [X3: nat] :
                ( member(nat,X3,As)
               => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X3),lim(product_unit,H)) ) ) ) ).

% in_range.elims(3)
tff(fact_5692_in__range_Oelims_I2_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( in_range(X2)
     => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
           => ~ ! [X: nat] :
                  ( member(nat,X,As)
                 => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X),lim(product_unit,H)) ) ) ) ).

% in_range.elims(2)
tff(fact_5693_in__range_Oelims_I1_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( in_range(X2)
      <=> (Y) )
     => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
           => ( (Y)
            <=> ~ ! [X4: nat] :
                    ( member(nat,X4,As)
                   => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),lim(product_unit,H)) ) ) ) ) ).

% in_range.elims(1)
tff(fact_5694_in__range_Osimps,axiom,
    ! [Ha: heap_ext(product_unit),As2: set(nat)] :
      ( 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)),Ha),As2))
    <=> ! [X4: nat] :
          ( member(nat,X4,As2)
         => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),lim(product_unit,Ha)) ) ) ).

% in_range.simps
tff(fact_5695_sngr__assn__raw_Oelims_I3_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: ref(B),Xa: B,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ sngr_assn_raw(B,X2,Xa,Xb)
         => ~ ! [H: 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)),H),As) )
               => ( ( ref_get(B,H,X2) = Xa )
                  & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,X2)),bot_bot(set(nat))) )
                  & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,X2)),lim(product_unit,H)) ) ) ) ) ).

% sngr_assn_raw.elims(3)
tff(fact_5696_sngr__assn__raw_Oelims_I2_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: ref(B),Xa: B,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( sngr_assn_raw(B,X2,Xa,Xb)
         => ~ ! [H: 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)),H),As) )
               => ~ ( ( ref_get(B,H,X2) = Xa )
                    & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,X2)),bot_bot(set(nat))) )
                    & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,X2)),lim(product_unit,H)) ) ) ) ) ).

% sngr_assn_raw.elims(2)
tff(fact_5697_sngr__assn__raw_Oelims_I1_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: ref(B),Xa: B,Xb: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
          ( ( sngr_assn_raw(B,X2,Xa,Xb)
          <=> (Y) )
         => ~ ! [H: 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)),H),As) )
               => ( (Y)
                <=> ~ ( ( ref_get(B,H,X2) = Xa )
                      & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,X2)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,X2)),lim(product_unit,H)) ) ) ) ) ) ).

% sngr_assn_raw.elims(1)
tff(fact_5698_sngr__assn__raw_Osimps,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),X2: B,Ha: heap_ext(product_unit),As2: set(nat)] :
          ( sngr_assn_raw(B,R,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)),Ha),As2))
        <=> ( ( ref_get(B,Ha,R) = X2 )
            & ( As2 = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,R)),bot_bot(set(nat))) )
            & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,R)),lim(product_unit,Ha)) ) ) ) ).

% sngr_assn_raw.simps
tff(fact_5699_sngr__assn__raw_Opelims_I3_J,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: ref(B),Xa: B,Xb: product_prod(heap_ext(product_unit),set(nat))] :
          ( ~ sngr_assn_raw(B,X2,Xa,Xb)
         => ( aa(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(B)),aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,product_prod(heap_ext(product_unit),set(nat))),Xa),Xb)))
           => ~ ! [H: 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)),H),As) )
                 => ( aa(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),$o,accp(product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),sngr_assn_raw_rel(B)),aa(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),aa(ref(B),fun(product_prod(B,product_prod(heap_ext(product_unit),set(nat))),product_prod(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat))))),product_Pair(ref(B),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),X2),aa(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat))),aa(B,fun(product_prod(heap_ext(product_unit),set(nat)),product_prod(B,product_prod(heap_ext(product_unit),set(nat)))),product_Pair(B,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)),H),As))))
                   => ( ( ref_get(B,H,X2) = Xa )
                      & ( As = aa(set(nat),set(nat),insert2(nat,addr_of_ref(B,X2)),bot_bot(set(nat))) )
                      & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),addr_of_ref(B,X2)),lim(product_unit,H)) ) ) ) ) ) ) ).

% sngr_assn_raw.pelims(3)
tff(fact_5700_wand__assnI,axiom,
    ! [Ha: heap_ext(product_unit),As2: set(nat),Q: assn,R4: assn] :
      ( 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)),Ha),As2))
     => ( ! [H4: heap_ext(product_unit),As6: set(nat)] :
            ( ( aa(set(nat),set(nat),inf_inf(set(nat),As2),As6) = bot_bot(set(nat)) )
           => ( relH(As2,Ha,H4)
             => ( 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))
               => ( 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)),H4),As6))
                 => rep_assn(R4,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),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As2),As6))) ) ) ) )
       => rep_assn(wand_assn(Q,R4),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)),Ha),As2)) ) ) ).

% wand_assnI
tff(fact_5701_wand__raw_Osimps,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Q: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Ha: heap_ext(product_unit),As2: set(nat)] :
      ( wand_raw(P,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)),Ha),As2))
    <=> ( 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)),Ha),As2))
        & ! [H7: heap_ext(product_unit),As7: set(nat)] :
            ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As2),As7) = bot_bot(set(nat)) )
              & relH(As2,Ha,H7)
              & 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,P,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_5702_wand__raw_Oelims_I1_J,axiom,
    ! [X2: 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] :
      ( ( wand_raw(X2,Xa,Xb)
      <=> (Y) )
     => ~ ! [H: 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)),H),As) )
           => ( (Y)
            <=> ~ ( 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),As))
                  & ! [H7: heap_ext(product_unit),As7: set(nat)] :
                      ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As),As7) = bot_bot(set(nat)) )
                        & relH(As,H,H7)
                        & 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,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)),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_5703_wand__raw_Oelims_I3_J,axiom,
    ! [X2: 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))] :
      ( ~ wand_raw(X2,Xa,Xb)
     => ~ ! [H: 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)),H),As) )
           => ( 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),As))
              & ! [H4: heap_ext(product_unit),As6: set(nat)] :
                  ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As),As6) = bot_bot(set(nat)) )
                    & relH(As,H,H4)
                    & 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),As))
                    & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H4),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)),H4),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As6))) ) ) ) ) ).

% wand_raw.elims(3)
tff(fact_5704_wand__raw_Oelims_I2_J,axiom,
    ! [X2: 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))] :
      ( wand_raw(X2,Xa,Xb)
     => ~ ! [H: 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)),H),As) )
           => ~ ( 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),As))
                & ! [H8: heap_ext(product_unit),As8: set(nat)] :
                    ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As),As8) = bot_bot(set(nat)) )
                      & relH(As,H,H8)
                      & 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)),H8),As))
                      & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H8),As8)) )
                   => 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)),H8),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As8))) ) ) ) ) ).

% wand_raw.elims(2)
tff(fact_5705_wand__raw_Opelims_I3_J,axiom,
    ! [X2: 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))] :
      ( ~ wand_raw(X2,Xa,Xb)
     => ( aa(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,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)))),X2),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)))
       => ~ ! [H: 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)),H),As) )
             => ( aa(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,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)))),X2),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)),H),As))))
               => ( 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),As))
                  & ! [H4: heap_ext(product_unit),As6: set(nat)] :
                      ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As),As6) = bot_bot(set(nat)) )
                        & relH(As,H,H4)
                        & 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),As))
                        & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H4),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)),H4),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As6))) ) ) ) ) ) ) ).

% wand_raw.pelims(3)
tff(fact_5706_wand__raw_Opelims_I2_J,axiom,
    ! [X2: 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))] :
      ( wand_raw(X2,Xa,Xb)
     => ( aa(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,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)))),X2),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)))
       => ~ ! [H: 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)),H),As) )
             => ( aa(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,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)))),X2),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)),H),As))))
               => ~ ( 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),As))
                    & ! [H8: heap_ext(product_unit),As8: set(nat)] :
                        ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As),As8) = bot_bot(set(nat)) )
                          & relH(As,H,H8)
                          & 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)),H8),As))
                          & aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H8),As8)) )
                       => 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)),H8),aa(set(nat),set(nat),aa(set(nat),fun(set(nat),set(nat)),sup_sup(set(nat)),As),As8))) ) ) ) ) ) ) ).

% wand_raw.pelims(2)
tff(fact_5707_wand__raw_Opelims_I1_J,axiom,
    ! [X2: 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] :
      ( ( wand_raw(X2,Xa,Xb)
      <=> (Y) )
     => ( aa(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,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)))),X2),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)))
       => ~ ! [H: 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)),H),As) )
             => ( ( (Y)
                <=> ( 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),As))
                    & ! [H7: heap_ext(product_unit),As7: set(nat)] :
                        ( ( ( aa(set(nat),set(nat),inf_inf(set(nat),As),As7) = bot_bot(set(nat)) )
                          & relH(As,H,H7)
                          & 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,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)),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))) ) ) )
               => ~ aa(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,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)))),X2),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)),H),As)))) ) ) ) ) ).

% wand_raw.pelims(1)
tff(fact_5708_in__range_Opelims_I3_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ in_range(X2)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel),X2)
       => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
             => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),As))
               => ! [X3: nat] :
                    ( member(nat,X3,As)
                   => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X3),lim(product_unit,H)) ) ) ) ) ) ).

% in_range.pelims(3)
tff(fact_5709_in__range_Opelims_I2_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( in_range(X2)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel),X2)
       => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
             => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),As))
               => ~ ! [X: nat] :
                      ( member(nat,X,As)
                     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X),lim(product_unit,H)) ) ) ) ) ) ).

% in_range.pelims(2)
tff(fact_5710_in__range_Opelims_I1_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( in_range(X2)
      <=> (Y) )
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,accp(product_prod(heap_ext(product_unit),set(nat)),in_range_rel),X2)
       => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
             => ( ( (Y)
                <=> ! [X4: nat] :
                      ( member(nat,X4,As)
                     => aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),X4),lim(product_unit,H)) ) )
               => ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),As)) ) ) ) ) ).

% in_range.pelims(1)
tff(fact_5711_Ref__Time_Oalloc__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [X2: B,Ha: heap_ext(product_unit)] :
          ref_alloc(B,X2,Ha) = $let(
            l: nat,
            l:= lim(product_unit,Ha),
            $let(
              r: ref(B),
              r:= ref2(B,l),
              aa(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit)),aa(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit))),product_Pair(ref(B),heap_ext(product_unit)),r),ref_set(B,r,X2,lim_update(product_unit,aTP_Lamp_wd(nat,fun(nat,nat),l),Ha))) ) ) ) ).

% Ref_Time.alloc_def
tff(fact_5712_pure__assn__raw_Osimps,axiom,
    ! [C: $tType,B: $tType,B2: $o,Ha: B,As2: set(C)] :
      ( pure_assn_raw(B,C,(B2),aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),Ha),As2))
    <=> ( ( As2 = bot_bot(set(C)) )
        & (B2) ) ) ).

% pure_assn_raw.simps
tff(fact_5713_pure__assn__raw_Oelims_I1_J,axiom,
    ! [C: $tType,B: $tType,X2: $o,Xa: product_prod(B,set(C)),Y: $o] :
      ( ( pure_assn_raw(B,C,(X2),Xa)
      <=> (Y) )
     => ~ ! [H: B,As: set(C)] :
            ( ( Xa = aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As) )
           => ( (Y)
            <=> ~ ( ( As = bot_bot(set(C)) )
                  & (X2) ) ) ) ) ).

% pure_assn_raw.elims(1)
tff(fact_5714_pure__assn__raw_Oelims_I3_J,axiom,
    ! [C: $tType,B: $tType,X2: $o,Xa: product_prod(B,set(C))] :
      ( ~ pure_assn_raw(B,C,(X2),Xa)
     => ~ ! [H: B,As: set(C)] :
            ( ( Xa = aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As) )
           => ( ( As = bot_bot(set(C)) )
              & (X2) ) ) ) ).

% pure_assn_raw.elims(3)
tff(fact_5715_pure__assn__raw_Oelims_I2_J,axiom,
    ! [C: $tType,B: $tType,X2: $o,Xa: product_prod(B,set(C))] :
      ( pure_assn_raw(B,C,(X2),Xa)
     => ~ ! [H: B,As: set(C)] :
            ( ( Xa = aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As) )
           => ~ ( ( As = bot_bot(set(C)) )
                & (X2) ) ) ) ).

% pure_assn_raw.elims(2)
tff(fact_5716_pure__assn__raw_Opelims_I3_J,axiom,
    ! [C: $tType,B: $tType,X2: $o,Xa: product_prod(B,set(C))] :
      ( ~ pure_assn_raw(B,C,(X2),Xa)
     => ( aa(product_prod($o,product_prod(B,set(C))),$o,accp(product_prod($o,product_prod(B,set(C))),pure_assn_raw_rel(B,C)),aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(X2)),Xa))
       => ~ ! [H: B,As: set(C)] :
              ( ( Xa = aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As) )
             => ( aa(product_prod($o,product_prod(B,set(C))),$o,accp(product_prod($o,product_prod(B,set(C))),pure_assn_raw_rel(B,C)),aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(X2)),aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As)))
               => ( ( As = bot_bot(set(C)) )
                  & (X2) ) ) ) ) ) ).

% pure_assn_raw.pelims(3)
tff(fact_5717_pure__assn__raw_Opelims_I2_J,axiom,
    ! [C: $tType,B: $tType,X2: $o,Xa: product_prod(B,set(C))] :
      ( pure_assn_raw(B,C,(X2),Xa)
     => ( aa(product_prod($o,product_prod(B,set(C))),$o,accp(product_prod($o,product_prod(B,set(C))),pure_assn_raw_rel(B,C)),aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(X2)),Xa))
       => ~ ! [H: B,As: set(C)] :
              ( ( Xa = aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As) )
             => ( aa(product_prod($o,product_prod(B,set(C))),$o,accp(product_prod($o,product_prod(B,set(C))),pure_assn_raw_rel(B,C)),aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(X2)),aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As)))
               => ~ ( ( As = bot_bot(set(C)) )
                    & (X2) ) ) ) ) ) ).

% pure_assn_raw.pelims(2)
tff(fact_5718_pure__assn__raw_Opelims_I1_J,axiom,
    ! [B: $tType,C: $tType,X2: $o,Xa: product_prod(B,set(C)),Y: $o] :
      ( ( pure_assn_raw(B,C,(X2),Xa)
      <=> (Y) )
     => ( aa(product_prod($o,product_prod(B,set(C))),$o,accp(product_prod($o,product_prod(B,set(C))),pure_assn_raw_rel(B,C)),aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(X2)),Xa))
       => ~ ! [H: B,As: set(C)] :
              ( ( Xa = aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As) )
             => ( ( (Y)
                <=> ( ( As = bot_bot(set(C)) )
                    & (X2) ) )
               => ~ aa(product_prod($o,product_prod(B,set(C))),$o,accp(product_prod($o,product_prod(B,set(C))),pure_assn_raw_rel(B,C)),aa(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C))),aa($o,fun(product_prod(B,set(C)),product_prod($o,product_prod(B,set(C)))),product_Pair($o,product_prod(B,set(C))),(X2)),aa(set(C),product_prod(B,set(C)),aa(B,fun(set(C),product_prod(B,set(C))),product_Pair(B,set(C)),H),As))) ) ) ) ) ).

% pure_assn_raw.pelims(1)
tff(fact_5719_effect__refI,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),H2: heap_ext(product_unit),V: B,Ha: heap_ext(product_unit),N: nat] :
          ( ( aa(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit)),aa(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit))),product_Pair(ref(B),heap_ext(product_unit)),R),H2) = ref_alloc(B,V,Ha) )
         => ( ( N = one_one(nat) )
           => heap_Time_effect(ref(B),ref_ref(B,V),Ha,H2,R,N) ) ) ) ).

% effect_refI
tff(fact_5720_ref__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [V: B] : ref_ref(B,V) = heap_Time_heap(ref(B),aTP_Lamp_wf(B,fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),V)) ) ).

% ref_def
tff(fact_5721_execute__ref,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [V: B,Ha: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(ref(B)),fun(heap_ext(product_unit),option(product_prod(ref(B),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(ref(B)),ref_ref(B,V)),Ha) = aa(product_prod(ref(B),product_prod(heap_ext(product_unit),nat)),option(product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),some(product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),aa(product_prod(ref(B),heap_ext(product_unit)),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)),aa(fun(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(ref(B),heap_ext(product_unit)),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(ref(B),heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_we(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))))),ref_alloc(B,V,Ha))) ) ).

% execute_ref
tff(fact_5722_effect__refE,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [V: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: ref(B),N: nat] :
          ( heap_Time_effect(ref(B),ref_ref(B,V),Ha,H2,R,N)
         => ~ ( ( ref_get(B,H2,R) = V )
             => ( ref_present(B,H2,R)
               => ( ~ ref_present(B,Ha,R)
                 => ( N != one_one(nat) ) ) ) ) ) ) ).

% effect_refE
tff(fact_5723_next__fresh,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),H2: heap_ext(product_unit),X2: B,Ha: heap_ext(product_unit)] :
          ( ( aa(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit)),aa(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit))),product_Pair(ref(B),heap_ext(product_unit)),R),H2) = ref_alloc(B,X2,Ha) )
         => ~ ref_present(B,Ha,R) ) ) ).

% next_fresh
tff(fact_5724_next__present,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [R: ref(B),H2: heap_ext(product_unit),X2: B,Ha: heap_ext(product_unit)] :
          ( ( aa(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit)),aa(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),heap_ext(product_unit))),product_Pair(ref(B),heap_ext(product_unit)),R),H2) = ref_alloc(B,X2,Ha) )
         => ref_present(B,H2,R) ) ) ).

% next_present
tff(fact_5725_one__assn__raw_Oelims_I3_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ one_assn_raw(X2)
     => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
           => ( As = bot_bot(set(nat)) ) ) ) ).

% one_assn_raw.elims(3)
tff(fact_5726_one__assn__raw_Oelims_I2_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( one_assn_raw(X2)
     => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
           => ( As != bot_bot(set(nat)) ) ) ) ).

% one_assn_raw.elims(2)
tff(fact_5727_one__assn__raw_Oelims_I1_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( one_assn_raw(X2)
      <=> (Y) )
     => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
           => ( (Y)
            <=> ( As != bot_bot(set(nat)) ) ) ) ) ).

% one_assn_raw.elims(1)
tff(fact_5728_one__assn__raw_Osimps,axiom,
    ! [Ha: heap_ext(product_unit),As2: set(nat)] :
      ( 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)),Ha),As2))
    <=> ( As2 = bot_bot(set(nat)) ) ) ).

% one_assn_raw.simps
tff(fact_5729_one__assn__raw_Opelims_I3_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( ~ one_assn_raw(X2)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel),X2)
       => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
             => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),As))
               => ( As = bot_bot(set(nat)) ) ) ) ) ) ).

% one_assn_raw.pelims(3)
tff(fact_5730_one__assn__raw_Opelims_I2_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat))] :
      ( one_assn_raw(X2)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel),X2)
       => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
             => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),As))
               => ( As != bot_bot(set(nat)) ) ) ) ) ) ).

% one_assn_raw.pelims(2)
tff(fact_5731_one__assn__raw_Opelims_I1_J,axiom,
    ! [X2: product_prod(heap_ext(product_unit),set(nat)),Y: $o] :
      ( ( one_assn_raw(X2)
      <=> (Y) )
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,accp(product_prod(heap_ext(product_unit),set(nat)),one_assn_raw_rel),X2)
       => ~ ! [H: heap_ext(product_unit),As: 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)),H),As) )
             => ( ( (Y)
                <=> ( As = bot_bot(set(nat)) ) )
               => ~ aa(product_prod(heap_ext(product_unit),set(nat)),$o,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)),H),As)) ) ) ) ) ).

% one_assn_raw.pelims(1)
tff(fact_5732_proper__iff,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o),As2: set(nat),Ha: heap_ext(product_unit),H2: heap_ext(product_unit)] :
      ( proper(P)
     => ( relH(As2,Ha,H2)
       => ( 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),As2))
         => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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)),Ha),As2))
          <=> aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As2)) ) ) ) ) ).

% proper_iff
tff(fact_5733_proper__def,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( proper(P)
    <=> ! [H6: heap_ext(product_unit),H7: heap_ext(product_unit),As5: set(nat)] :
          ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As5))
           => 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),As5)) )
          & ( ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As5))
              & relH(As5,H6,H7)
              & 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),As5)) )
           => aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As5)) ) ) ) ).

% proper_def
tff(fact_5734_properD2,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Ha: heap_ext(product_unit),As2: set(nat),H2: heap_ext(product_unit)] :
      ( proper(P)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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)),Ha),As2))
       => ( relH(As2,Ha,H2)
         => ( 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),As2))
           => aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As2)) ) ) ) ) ).

% properD2
tff(fact_5735_properD1,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o),Ha: heap_ext(product_unit),As2: set(nat)] :
      ( proper(P)
     => ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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)),Ha),As2))
       => 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)),Ha),As2)) ) ) ).

% properD1
tff(fact_5736_properI,axiom,
    ! [P: fun(product_prod(heap_ext(product_unit),set(nat)),$o)] :
      ( ! [As: set(nat),H: heap_ext(product_unit)] :
          ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As))
         => 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),As)) )
     => ( ! [As: set(nat),H: heap_ext(product_unit),H4: heap_ext(product_unit)] :
            ( aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As))
           => ( relH(As,H,H4)
             => ( 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),As))
               => aa(product_prod(heap_ext(product_unit),set(nat)),$o,P,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),As)) ) ) )
       => proper(P) ) ) ).

% properI
tff(fact_5737_Array__Time_Onoteq__def,axiom,
    ! [B: $tType,C: $tType] :
      ( ( heap(C)
        & heap(B) )
     => ! [R: array(B),S: array(C)] :
          ( array_noteq(B,C,R,S)
        <=> ( ( typerep_typerep(B,type2(B)) != typerep_typerep(C,type2(C)) )
            | ( addr_of_array(B,R) != addr_of_array(C,S) ) ) ) ) ).

% Array_Time.noteq_def
tff(fact_5738_comm__monoid__mset_Ounion,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M2: multiset(B),N5: multiset(B)] :
      ( comm_monoid_mset(B,F,Z2)
     => ( aa(multiset(B),B,comm_monoid_F(B,F,Z2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(B,B,aa(B,fun(B,B),F,aa(multiset(B),B,comm_monoid_F(B,F,Z2),M2)),aa(multiset(B),B,comm_monoid_F(B,F,Z2),N5)) ) ) ).

% comm_monoid_mset.union
tff(fact_5739_prod__list_Omonoid__list__axioms,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => groups_monoid_list(B,times_times(B),one_one(B)) ) ).

% prod_list.monoid_list_axioms
tff(fact_5740_sum__mset_Ocomm__monoid__mset__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => comm_monoid_mset(B,plus_plus(B),zero_zero(B)) ) ).

% sum_mset.comm_monoid_mset_axioms
tff(fact_5741_prod__mset_Ocomm__monoid__mset__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => comm_monoid_mset(B,times_times(B),one_one(B)) ) ).

% prod_mset.comm_monoid_mset_axioms
tff(fact_5742_sum__list_Omonoid__list__axioms,axiom,
    ! [B: $tType] :
      ( monoid_add(B)
     => groups_monoid_list(B,plus_plus(B),zero_zero(B)) ) ).

% sum_list.monoid_list_axioms
tff(fact_5743_Array__Time_Oset__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [A3: array(B),X2: list(B)] : array_set(B,A3,X2) = arrays_update(product_unit,aa(list(B),fun(fun(typerep,fun(nat,list(nat))),fun(typerep,fun(nat,list(nat)))),aTP_Lamp_wg(array(B),fun(list(B),fun(fun(typerep,fun(nat,list(nat))),fun(typerep,fun(nat,list(nat))))),A3),X2)) ) ).

% Array_Time.set_def
tff(fact_5744_Array__Time_Oget__def,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Ha: heap_ext(product_unit),A3: array(B)] : array_get(B,Ha,A3) = aa(list(nat),list(B),map(nat,B,from_nat(B)),arrays(product_unit,Ha,typerep_typerep(B,type2(B)),addr_of_array(B,A3))) ) ).

% Array_Time.get_def
tff(fact_5745_Int_Osub__code_I8_J,axiom,
    ! [M: num,N: num] : sub(aa(num,num,bit1,M),aa(num,num,bit0,N)) = aa(int,int,aa(int,fun(int,int),plus_plus(int),dup(sub(M,N))),one_one(int)) ).

% Int.sub_code(8)
tff(fact_5746_Int_Odup__def,axiom,
    ! [K: int] : dup(K) = aa(int,int,aa(int,fun(int,int),plus_plus(int),K),K) ).

% Int.dup_def
tff(fact_5747_relH__def,axiom,
    ! [As2: set(nat),Ha: heap_ext(product_unit),H2: heap_ext(product_unit)] :
      ( relH(As2,Ha,H2)
    <=> ( 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)),Ha),As2))
        & 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),As2))
        & ! [T7: typerep,X4: nat] :
            ( member(nat,X4,As2)
           => ( ( refs(product_unit,Ha,T7,X4) = refs(product_unit,H2,T7,X4) )
              & ( arrays(product_unit,Ha,T7,X4) = arrays(product_unit,H2,T7,X4) ) ) ) ) ) ).

% relH_def
tff(fact_5748_case__sum__o__map__sum__id,axiom,
    ! [B: $tType,C: $tType,D: $tType,G: fun(C,B),F: fun(D,B),X2: sum_sum(D,C)] : aa(sum_sum(D,C),B,aa(fun(sum_sum(D,C),sum_sum(B,C)),fun(sum_sum(D,C),B),aa(fun(sum_sum(B,C),B),fun(fun(sum_sum(D,C),sum_sum(B,C)),fun(sum_sum(D,C),B)),comp(sum_sum(B,C),B,sum_sum(D,C)),sum_case_sum(B,B,C,id(B),G)),sum_map_sum(D,B,C,C,F,id(C))),X2) = aa(sum_sum(D,C),B,sum_case_sum(D,B,C,aa(fun(D,D),fun(D,B),aa(fun(D,B),fun(fun(D,D),fun(D,B)),comp(D,B,D),F),id(D)),G),X2) ).

% case_sum_o_map_sum_id
tff(fact_5749_comm__monoid_Oaxioms_I2_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( comm_monoid(B,F,Z2)
     => comm_monoid_axioms(B,F,Z2) ) ).

% comm_monoid.axioms(2)
tff(fact_5750_sum_Omap__comp,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,G2: $tType,F4: $tType,G1: fun(D,B),G22: fun(E,C),F1: fun(F4,D),F22: fun(G2,E),V: sum_sum(F4,G2)] : aa(sum_sum(D,E),sum_sum(B,C),sum_map_sum(D,B,E,C,G1,G22),aa(sum_sum(F4,G2),sum_sum(D,E),sum_map_sum(F4,D,G2,E,F1,F22),V)) = aa(sum_sum(F4,G2),sum_sum(B,C),sum_map_sum(F4,B,G2,C,aa(fun(F4,D),fun(F4,B),aa(fun(D,B),fun(fun(F4,D),fun(F4,B)),comp(D,B,F4),G1),F1),aa(fun(G2,E),fun(G2,C),aa(fun(E,C),fun(fun(G2,E),fun(G2,C)),comp(E,C,G2),G22),F22)),V) ).

% sum.map_comp
tff(fact_5751_comm__monoid__axioms_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( ! [A5: B] : aa(B,B,aa(B,fun(B,B),F,A5),Z2) = A5
     => comm_monoid_axioms(B,F,Z2) ) ).

% comm_monoid_axioms.intro
tff(fact_5752_comm__monoid__axioms__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( comm_monoid_axioms(B,F,Z2)
    <=> ! [A7: B] : aa(B,B,aa(B,fun(B,B),F,A7),Z2) = A7 ) ).

% comm_monoid_axioms_def
tff(fact_5753_case__sum__map__sum,axiom,
    ! [D: $tType,B: $tType,C: $tType,F4: $tType,E: $tType,L: fun(C,B),R: fun(D,B),F: fun(E,C),G: fun(F4,D),X2: sum_sum(E,F4)] : aa(sum_sum(C,D),B,sum_case_sum(C,B,D,L,R),aa(sum_sum(E,F4),sum_sum(C,D),sum_map_sum(E,C,F4,D,F,G),X2)) = aa(sum_sum(E,F4),B,sum_case_sum(E,B,F4,aa(fun(E,C),fun(E,B),aa(fun(C,B),fun(fun(E,C),fun(E,B)),comp(C,B,E),L),F),aa(fun(F4,D),fun(F4,B),aa(fun(D,B),fun(fun(F4,D),fun(F4,B)),comp(D,B,F4),R),G)),X2) ).

% case_sum_map_sum
tff(fact_5754_case__sum__o__map__sum,axiom,
    ! [B: $tType,E: $tType,D: $tType,F4: $tType,C: $tType,F: fun(E,D),G: fun(F4,D),H1: fun(B,E),H22: fun(C,F4)] : aa(fun(sum_sum(B,C),sum_sum(E,F4)),fun(sum_sum(B,C),D),aa(fun(sum_sum(E,F4),D),fun(fun(sum_sum(B,C),sum_sum(E,F4)),fun(sum_sum(B,C),D)),comp(sum_sum(E,F4),D,sum_sum(B,C)),sum_case_sum(E,D,F4,F,G)),sum_map_sum(B,E,C,F4,H1,H22)) = sum_case_sum(B,D,C,aa(fun(B,E),fun(B,D),aa(fun(E,D),fun(fun(B,E),fun(B,D)),comp(E,D,B),F),H1),aa(fun(C,F4),fun(C,D),aa(fun(F4,D),fun(fun(C,F4),fun(C,D)),comp(F4,D,C),G),H22)) ).

% case_sum_o_map_sum
tff(fact_5755_map__sum_Ocomp,axiom,
    ! [B: $tType,F4: $tType,D: $tType,E: $tType,G2: $tType,C: $tType,F: fun(F4,D),G: fun(G2,E),Ha: fun(B,F4),I: fun(C,G2)] : aa(fun(sum_sum(B,C),sum_sum(F4,G2)),fun(sum_sum(B,C),sum_sum(D,E)),aa(fun(sum_sum(F4,G2),sum_sum(D,E)),fun(fun(sum_sum(B,C),sum_sum(F4,G2)),fun(sum_sum(B,C),sum_sum(D,E))),comp(sum_sum(F4,G2),sum_sum(D,E),sum_sum(B,C)),sum_map_sum(F4,D,G2,E,F,G)),sum_map_sum(B,F4,C,G2,Ha,I)) = sum_map_sum(B,D,C,E,aa(fun(B,F4),fun(B,D),aa(fun(F4,D),fun(fun(B,F4),fun(B,D)),comp(F4,D,B),F),Ha),aa(fun(C,G2),fun(C,E),aa(fun(G2,E),fun(fun(C,G2),fun(C,E)),comp(G2,E,C),G),I)) ).

% map_sum.comp
tff(fact_5756_map__sum_Ocompositionality,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,G2: $tType,F4: $tType,F: fun(D,B),G: fun(E,C),Ha: fun(F4,D),I: fun(G2,E),Sum: sum_sum(F4,G2)] : aa(sum_sum(D,E),sum_sum(B,C),sum_map_sum(D,B,E,C,F,G),aa(sum_sum(F4,G2),sum_sum(D,E),sum_map_sum(F4,D,G2,E,Ha,I),Sum)) = aa(sum_sum(F4,G2),sum_sum(B,C),sum_map_sum(F4,B,G2,C,aa(fun(F4,D),fun(F4,B),aa(fun(D,B),fun(fun(F4,D),fun(F4,B)),comp(D,B,F4),F),Ha),aa(fun(G2,E),fun(G2,C),aa(fun(E,C),fun(fun(G2,E),fun(G2,C)),comp(E,C,G2),G),I)),Sum) ).

% map_sum.compositionality
tff(fact_5757_comm__monoid__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( comm_monoid(B,F,Z2)
    <=> ( abel_semigroup(B,F)
        & comm_monoid_axioms(B,F,Z2) ) ) ).

% comm_monoid_def
tff(fact_5758_mult_Oabel__semigroup__axioms,axiom,
    ! [B: $tType] :
      ( ab_semigroup_mult(B)
     => abel_semigroup(B,times_times(B)) ) ).

% mult.abel_semigroup_axioms
tff(fact_5759_comm__monoid_Oaxioms_I1_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( comm_monoid(B,F,Z2)
     => abel_semigroup(B,F) ) ).

% comm_monoid.axioms(1)
tff(fact_5760_abel__semigroup_Oleft__commute,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),B2: B,A3: B,C2: B] :
      ( abel_semigroup(B,F)
     => ( aa(B,B,aa(B,fun(B,B),F,B2),aa(B,B,aa(B,fun(B,B),F,A3),C2)) = aa(B,B,aa(B,fun(B,B),F,A3),aa(B,B,aa(B,fun(B,B),F,B2),C2)) ) ) ).

% abel_semigroup.left_commute
tff(fact_5761_abel__semigroup_Ocommute,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),A3: B,B2: B] :
      ( abel_semigroup(B,F)
     => ( aa(B,B,aa(B,fun(B,B),F,A3),B2) = aa(B,B,aa(B,fun(B,B),F,B2),A3) ) ) ).

% abel_semigroup.commute
tff(fact_5762_add_Oabel__semigroup__axioms,axiom,
    ! [B: $tType] :
      ( ab_semigroup_add(B)
     => abel_semigroup(B,plus_plus(B)) ) ).

% add.abel_semigroup_axioms
tff(fact_5763_abel__semigroup_Oaxioms_I1_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( abel_semigroup(B,F)
     => semigroup(B,F) ) ).

% abel_semigroup.axioms(1)
tff(fact_5764_comm__monoid_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B] :
      ( abel_semigroup(B,F)
     => ( comm_monoid_axioms(B,F,Z2)
       => comm_monoid(B,F,Z2) ) ) ).

% comm_monoid.intro
tff(fact_5765_abel__semigroup_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( semigroup(B,F)
     => ( abel_s757365448890700780axioms(B,F)
       => abel_semigroup(B,F) ) ) ).

% abel_semigroup.intro
tff(fact_5766_abel__semigroup__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( abel_semigroup(B,F)
    <=> ( semigroup(B,F)
        & abel_s757365448890700780axioms(B,F) ) ) ).

% abel_semigroup_def
tff(fact_5767_curr__def,axiom,
    ! [B: $tType,D: $tType,C: $tType,A4: set(B),F: fun(product_prod(B,C),D),X: B] :
      bNF_Wellorder_curr(B,C,D,A4,F,X) = $ite(member(B,X,A4),aa(B,fun(C,D),aTP_Lamp_br(fun(product_prod(B,C),D),fun(B,fun(C,D)),F),X),undefined(fun(C,D))) ).

% curr_def
tff(fact_5768_abel__semigroup__axioms_Ointro,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( ! [A5: B,B3: B] : aa(B,B,aa(B,fun(B,B),F,A5),B3) = aa(B,B,aa(B,fun(B,B),F,B3),A5)
     => abel_s757365448890700780axioms(B,F) ) ).

% abel_semigroup_axioms.intro
tff(fact_5769_abel__semigroup__axioms__def,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( abel_s757365448890700780axioms(B,F)
    <=> ! [A7: B,B7: B] : aa(B,B,aa(B,fun(B,B),F,A7),B7) = aa(B,B,aa(B,fun(B,B),F,B7),A7) ) ).

% abel_semigroup_axioms_def
tff(fact_5770_abel__semigroup_Oaxioms_I2_J,axiom,
    ! [B: $tType,F: fun(B,fun(B,B))] :
      ( abel_semigroup(B,F)
     => abel_s757365448890700780axioms(B,F) ) ).

% abel_semigroup.axioms(2)
tff(fact_5771_comm__monoid__set_Ozero__middle,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,P3: nat,K: nat,G: fun(nat,B),Ha: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( 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),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aa(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),aTP_Lamp_wh(B,fun(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B)))),Z2),K),G),Ha)),aa(nat,set(nat),set_ord_atMost(nat),P3)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_wi(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),K),G),Ha)),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),P3),aa(nat,nat,suc,zero_zero(nat))))) ) ) ) ) ).

% comm_monoid_set.zero_middle
tff(fact_5772_iterate__add__diff__add__eq2,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [I: nat,J: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M)),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),M),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),N)) ) ) ) ).

% iterate_add_diff_add_eq2
tff(fact_5773_iterate__add__add__eq1,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [J: nat,I: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
         => ( aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M)),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N)) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J),U)),M)),N) ) ) ) ).

% iterate_add_add_eq1
tff(fact_5774_iterate__add__simps_I2_J,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [N: nat,A3: B] : iterate_add(B,aa(nat,nat,suc,N),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),A3),iterate_add(B,N,A3)) ) ).

% iterate_add_simps(2)
tff(fact_5775_iterate__add__distrib,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [M: nat,N: nat,A3: B] : iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),N),A3) = aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,M,A3)),iterate_add(B,N,A3)) ) ).

% iterate_add_distrib
tff(fact_5776_iterate__add__1,axiom,
    ! [B: $tType] :
      ( ( cancel1802427076303600483id_add(B)
        & semiring_1(B) )
     => ! [N: nat] : iterate_add(B,N,one_one(B)) = aa(nat,B,semiring_1_of_nat(B),N) ) ).

% iterate_add_1
tff(fact_5777_prod_Ocomm__monoid__set__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => groups778175481326437816id_set(B,times_times(B),one_one(B)) ) ).

% prod.comm_monoid_set_axioms
tff(fact_5778_comm__monoid__set_Onat__group,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),K: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aa(fun(nat,B),fun(nat,fun(nat,B)),aa(B,fun(fun(nat,B),fun(nat,fun(nat,B))),aTP_Lamp_wj(fun(B,fun(B,B)),fun(B,fun(fun(nat,B),fun(nat,fun(nat,B)))),F),Z2),G),K)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),N),K))) ) ) ).

% comm_monoid_set.nat_group
tff(fact_5779_comm__monoid__set_Oub__add__nat,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B),P3: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),one_one(nat)))
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),P3))) = aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),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)))) ) ) ) ).

% comm_monoid_set.ub_add_nat
tff(fact_5780_comm__monoid__set_Oivl__cong,axiom,
    ! [B: $tType,C: $tType] :
      ( ord(C)
     => ! [F: fun(B,fun(B,B)),Z2: B,A3: C,C2: C,B2: C,D3: C,G: fun(C,B),Ha: fun(C,B)] :
          ( groups778175481326437816id_set(B,F,Z2)
         => ( ( A3 = C2 )
           => ( ( B2 = D3 )
             => ( ! [X3: C] :
                    ( aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),C2),X3)
                   => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),X3),D3)
                     => ( aa(C,B,G,X3) = aa(C,B,Ha,X3) ) ) )
               => ( aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups_comm_monoid_F(B,C,F,Z2),G),set_or7035219750837199246ssThan(C,A3,B2)) = aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups_comm_monoid_F(B,C,F,Z2),Ha),set_or7035219750837199246ssThan(C,C2,D3)) ) ) ) ) ) ) ).

% comm_monoid_set.ivl_cong
tff(fact_5781_comm__monoid__set_Ohead,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or3652927894154168847AtMost(nat,M,N))) ) ) ) ).

% comm_monoid_set.head
tff(fact_5782_comm__monoid__set_Olast__plus,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,N)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N))) ) ) ) ).

% comm_monoid_set.last_plus
tff(fact_5783_comm__monoid__set_OatLeast__Suc__atMost,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),N))) ) ) ) ).

% comm_monoid_set.atLeast_Suc_atMost
tff(fact_5784_comm__monoid__set_Onat__ivl__Suc_H,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),aa(nat,nat,suc,N))
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,aa(nat,nat,suc,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N))) ) ) ) ).

% comm_monoid_set.nat_ivl_Suc'
tff(fact_5785_comm__monoid__set_OatLeastLessThan__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,A3: nat,B2: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),A3),B2)
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,A3,aa(nat,nat,suc,B2))) = aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,A3,B2))),aa(nat,B,G,B2)) ) ) ) ).

% comm_monoid_set.atLeastLessThan_Suc
tff(fact_5786_comm__monoid__set_OatLeastLessThan__concat,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,P3: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),N),P3)
         => ( aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,N,P3))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,P3)) ) ) ) ) ).

% comm_monoid_set.atLeastLessThan_concat
tff(fact_5787_comm__monoid__set_OSuc__reindex__ivl,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ( aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N))),aa(nat,B,G,aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N))) ) ) ) ).

% comm_monoid_set.Suc_reindex_ivl
tff(fact_5788_comm__monoid__set_OatLeast1__atMost__eq,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,zero_zero(nat)),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ) ).

% comm_monoid_set.atLeast1_atMost_eq
tff(fact_5789_comm__monoid__set_OatLeastLessThan__rev,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat,M: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_wl(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or7035219750837199246ssThan(nat,N,M)) ) ) ).

% comm_monoid_set.atLeastLessThan_rev
tff(fact_5790_comm__monoid__set_Onested__swap,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,A3: fun(nat,fun(nat,B)),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_wm(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),F),Z2),A3)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aa(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,fun(nat,B))),aTP_Lamp_wo(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)))),F),Z2),A3),N)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N)) ) ) ).

% comm_monoid_set.nested_swap
tff(fact_5791_comm__monoid__set_Onat__diff__reindex,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aTP_Lamp_wp(fun(nat,B),fun(nat,fun(nat,B)),G),N)),aa(nat,set(nat),set_ord_lessThan(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ) ).

% comm_monoid_set.nat_diff_reindex
tff(fact_5792_comm__monoid__set_Oshift__bounds__cl__Suc__ivl,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.shift_bounds_cl_Suc_ivl
tff(fact_5793_comm__monoid__set_Oshift__bounds__Suc__ivl,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),set_or7035219750837199246ssThan(nat,M,N)) ) ) ).

% comm_monoid_set.shift_bounds_Suc_ivl
tff(fact_5794_comm__monoid__set_OlessThan__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_lessThan(nat),N))),aa(nat,B,G,N)) ) ) ).

% comm_monoid_set.lessThan_Suc
tff(fact_5795_comm__monoid__set_OatMost__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_atMost(nat),N))),aa(nat,B,G,aa(nat,nat,suc,N))) ) ) ).

% comm_monoid_set.atMost_Suc
tff(fact_5796_comm__monoid__set_Ohead__if,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N)) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),Z2,aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N))),aa(nat,B,G,N))) ) ) ).

% comm_monoid_set.head_if
tff(fact_5797_comm__monoid__set_Ocl__ivl__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,suc,N)),M),Z2,aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N))),aa(nat,B,G,aa(nat,nat,suc,N)))) ) ) ).

% comm_monoid_set.cl_ivl_Suc
tff(fact_5798_comm__monoid__set_Oop__ivl__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,aa(nat,nat,suc,N))) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),N),M),Z2,aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N))),aa(nat,B,G,N))) ) ) ).

% comm_monoid_set.op_ivl_Suc
tff(fact_5799_comm__monoid__set_OatLeast__Suc__lessThan,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),M),N)
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N)) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,M)),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),N))) ) ) ) ).

% comm_monoid_set.atLeast_Suc_lessThan
tff(fact_5800_comm__monoid__set_OatLeast0__lessThan__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))),aa(nat,B,G,N)) ) ) ).

% comm_monoid_set.atLeast0_lessThan_Suc
tff(fact_5801_comm__monoid__set_OatLeast0__atMost__Suc,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))),aa(nat,B,G,aa(nat,nat,suc,N))) ) ) ).

% comm_monoid_set.atLeast0_atMost_Suc
tff(fact_5802_comm__monoid__set_OatMost__Suc__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_atMost(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_atMost(nat),N))) ) ) ).

% comm_monoid_set.atMost_Suc_shift
tff(fact_5803_comm__monoid__set_OatLeastAtMost__rev,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat,M: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_wq(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or1337092689740270186AtMost(nat,N,M)) ) ) ).

% comm_monoid_set.atLeastAtMost_rev
tff(fact_5804_comm__monoid__set_OlessThan__Suc__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_lessThan(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ) ).

% comm_monoid_set.lessThan_Suc_shift
tff(fact_5805_comm__monoid__set_Oshift__bounds__cl__nat__ivl,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,K: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aTP_Lamp_wr(fun(nat,B),fun(nat,fun(nat,B)),G),K)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.shift_bounds_cl_nat_ivl
tff(fact_5806_comm__monoid__set_Oshift__bounds__nat__ivl,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,K: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aTP_Lamp_wr(fun(nat,B),fun(nat,fun(nat,B)),G),K)),set_or7035219750837199246ssThan(nat,M,N)) ) ) ).

% comm_monoid_set.shift_bounds_nat_ivl
tff(fact_5807_sum_Ocomm__monoid__set__axioms,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => groups778175481326437816id_set(B,plus_plus(B),zero_zero(B)) ) ).

% sum.comm_monoid_set_axioms
tff(fact_5808_comm__monoid__set_OatMost__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aTP_Lamp_wk(fun(nat,B),fun(nat,B),G)),aa(nat,set(nat),set_ord_lessThan(nat),N))) ) ) ).

% comm_monoid_set.atMost_shift
tff(fact_5809_comm__monoid__set_Onested__swap_H,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,A3: fun(nat,fun(nat,B)),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_ws(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),F),Z2),A3)),aa(nat,set(nat),set_ord_atMost(nat),N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aa(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,fun(nat,B))),aTP_Lamp_wo(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)))),F),Z2),A3),N)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ) ).

% comm_monoid_set.nested_swap'
tff(fact_5810_comm__monoid__set_Oreindex__nontrivial,axiom,
    ! [D: $tType,B: $tType,C: $tType,F: fun(B,fun(B,B)),Z2: B,A4: set(C),Ha: fun(C,D),G: fun(D,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( finite_finite2(C,A4)
       => ( ! [X3: C,Y4: C] :
              ( member(C,X3,A4)
             => ( member(C,Y4,A4)
               => ( ( X3 != Y4 )
                 => ( ( aa(C,D,Ha,X3) = aa(C,D,Ha,Y4) )
                   => ( aa(D,B,G,aa(C,D,Ha,X3)) = Z2 ) ) ) ) )
         => ( aa(set(D),B,aa(fun(D,B),fun(set(D),B),groups_comm_monoid_F(B,D,F,Z2),G),aa(set(C),set(D),image2(C,D,Ha),A4)) = aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups_comm_monoid_F(B,C,F,Z2),aa(fun(C,D),fun(C,B),aa(fun(D,B),fun(fun(C,D),fun(C,B)),comp(D,B,C),G),Ha)),A4) ) ) ) ) ).

% comm_monoid_set.reindex_nontrivial
tff(fact_5811_comm__monoid__set_Oreindex,axiom,
    ! [D: $tType,B: $tType,C: $tType,F: fun(B,fun(B,B)),Z2: B,Ha: fun(C,D),A4: set(C),G: fun(D,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( inj_on(C,D,Ha,A4)
       => ( aa(set(D),B,aa(fun(D,B),fun(set(D),B),groups_comm_monoid_F(B,D,F,Z2),G),aa(set(C),set(D),image2(C,D,Ha),A4)) = aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups_comm_monoid_F(B,C,F,Z2),aa(fun(C,D),fun(C,B),aa(fun(D,B),fun(fun(C,D),fun(C,B)),comp(D,B,C),G),Ha)),A4) ) ) ) ).

% comm_monoid_set.reindex
tff(fact_5812_comm__monoid__set_OatLeast__Suc__lessThan__Suc__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or7035219750837199246ssThan(nat,M,N)) ) ) ).

% comm_monoid_set.atLeast_Suc_lessThan_Suc_shift
tff(fact_5813_comm__monoid__set_OatLeast__Suc__atMost__Suc__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.atLeast_Suc_atMost_Suc_shift
tff(fact_5814_comm__monoid__set_OatLeastAtMost__shift__bounds,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,K: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),K))),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.atLeastAtMost_shift_bounds
tff(fact_5815_comm__monoid__set_OatLeastLessThan__shift__bounds,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,K: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),M),K),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),N),K))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),K))),set_or7035219750837199246ssThan(nat,M,N)) ) ) ).

% comm_monoid_set.atLeastLessThan_shift_bounds
tff(fact_5816_comm__monoid__set_OatLeastLessThan__reindex,axiom,
    ! [C: $tType,B: $tType] :
      ( ord(C)
     => ! [F: fun(B,fun(B,B)),Z2: B,Ha: fun(nat,C),M: nat,N: nat,G: fun(C,B)] :
          ( groups778175481326437816id_set(B,F,Z2)
         => ( bij_betw(nat,C,Ha,set_or7035219750837199246ssThan(nat,M,N),set_or7035219750837199246ssThan(C,aa(nat,C,Ha,M),aa(nat,C,Ha,N)))
           => ( aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups_comm_monoid_F(B,C,F,Z2),G),set_or7035219750837199246ssThan(C,aa(nat,C,Ha,M),aa(nat,C,Ha,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,C),fun(nat,B),aa(fun(C,B),fun(fun(nat,C),fun(nat,B)),comp(C,B,nat),G),Ha)),set_or7035219750837199246ssThan(nat,M,N)) ) ) ) ) ).

% comm_monoid_set.atLeastLessThan_reindex
tff(fact_5817_comm__monoid__set_OatLeastAtMost__reindex,axiom,
    ! [C: $tType,B: $tType] :
      ( ord(C)
     => ! [F: fun(B,fun(B,B)),Z2: B,Ha: fun(nat,C),M: nat,N: nat,G: fun(C,B)] :
          ( groups778175481326437816id_set(B,F,Z2)
         => ( bij_betw(nat,C,Ha,set_or1337092689740270186AtMost(nat,M,N),set_or1337092689740270186AtMost(C,aa(nat,C,Ha,M),aa(nat,C,Ha,N)))
           => ( aa(set(C),B,aa(fun(C,B),fun(set(C),B),groups_comm_monoid_F(B,C,F,Z2),G),set_or1337092689740270186AtMost(C,aa(nat,C,Ha,M),aa(nat,C,Ha,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,C),fun(nat,B),aa(fun(C,B),fun(fun(nat,C),fun(nat,B)),comp(C,B,nat),G),Ha)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ) ) ).

% comm_monoid_set.atLeastAtMost_reindex
tff(fact_5818_comm__monoid__set_OatLeast0__lessThan__Suc__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or7035219750837199246ssThan(nat,zero_zero(nat),N))) ) ) ).

% comm_monoid_set.atLeast0_lessThan_Suc_shift
tff(fact_5819_comm__monoid__set_OatLeast0__atMost__Suc__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,suc,N))) = aa(B,B,aa(B,fun(B,B),F,aa(nat,B,G,zero_zero(nat))),aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),suc)),set_or1337092689740270186AtMost(nat,zero_zero(nat),N))) ) ) ).

% comm_monoid_set.atLeast0_atMost_Suc_shift
tff(fact_5820_comm__monoid__set_OatLeastLessThan__shift__0,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),M))),set_or7035219750837199246ssThan(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ) ).

% comm_monoid_set.atLeastLessThan_shift_0
tff(fact_5821_comm__monoid__set_OatLeastLessThan__rev__at__least__Suc__atMost,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat,M: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,N,M)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_wq(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),G),N),M)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,N),M)) ) ) ).

% comm_monoid_set.atLeastLessThan_rev_at_least_Suc_atMost
tff(fact_5822_iterate__add__eq__add__iff1,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [I: nat,J: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
         => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),M) = aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),N) )
          <=> ( aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),M) = N ) ) ) ) ).

% iterate_add_eq_add_iff1
tff(fact_5823_iterate__add__eq__add__iff2,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [I: nat,J: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
         => ( ( aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M) = aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N) )
          <=> ( M = aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),N) ) ) ) ) ).

% iterate_add_eq_add_iff2
tff(fact_5824_iterate__add__def,axiom,
    ! [B: $tType] :
      ( cancel1802427076303600483id_add(B)
     => ! [N: nat,A3: B] : iterate_add(B,N,A3) = aa(B,B,compow(fun(B,B),N,aa(B,fun(B,B),plus_plus(B),A3)),zero_zero(B)) ) ).

% iterate_add_def
tff(fact_5825_comm__monoid__set_OatLeast__atMost__pred__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aTP_Lamp_bv(nat,nat))),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.atLeast_atMost_pred_shift
tff(fact_5826_comm__monoid__set_OatLeast__lessThan__pred__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aTP_Lamp_bv(nat,nat))),set_or7035219750837199246ssThan(nat,aa(nat,nat,suc,M),aa(nat,nat,suc,N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or7035219750837199246ssThan(nat,M,N)) ) ) ).

% comm_monoid_set.atLeast_lessThan_pred_shift
tff(fact_5827_comm__monoid__add__class_Osum__def,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(C)
     => ( groups7311177749621191930dd_sum(B,C) = groups_comm_monoid_F(C,B,plus_plus(C),zero_zero(C)) ) ) ).

% comm_monoid_add_class.sum_def
tff(fact_5828_comm__monoid__mult__class_Oprod__def,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ( groups7121269368397514597t_prod(B,C) = groups_comm_monoid_F(C,B,times_times(C),one_one(C)) ) ) ).

% comm_monoid_mult_class.prod_def
tff(fact_5829_comm__monoid__set_OatLeastAtMost__shift__0,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,M: nat,N: nat,G: fun(nat,B)] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),M),N)
       => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,M,N)) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,nat),fun(nat,B),aa(fun(nat,B),fun(fun(nat,nat),fun(nat,B)),comp(nat,B,nat),G),aa(nat,fun(nat,nat),plus_plus(nat),M))),set_or1337092689740270186AtMost(nat,zero_zero(nat),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),N),M))) ) ) ) ).

% comm_monoid_set.atLeastAtMost_shift_0
tff(fact_5830_comm__monoid__set_Oin__pairs,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),set_or1337092689740270186AtMost(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),M),aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,B),fun(nat,B),aTP_Lamp_wt(fun(B,fun(B,B)),fun(fun(nat,B),fun(nat,B)),F),G)),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.in_pairs
tff(fact_5831_comm__monoid__set_Oin__pairs__0,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,B),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),G),aa(nat,set(nat),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),aa(num,num,bit0,one2))),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,B),fun(nat,B),aTP_Lamp_wt(fun(B,fun(B,B)),fun(fun(nat,B),fun(nat,B)),F),G)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ) ).

% comm_monoid_set.in_pairs_0
tff(fact_5832_iterate__add__less__eq__iff2,axiom,
    ! [B: $tType] :
      ( ( cancel1802427076303600483id_add(B)
        & ordere2412721322843649153imp_le(B) )
     => ! [I: nat,J: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M)),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),M),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),N)) ) ) ) ).

% iterate_add_less_eq_iff2
tff(fact_5833_iterate__add__less__eq__iff1,axiom,
    ! [B: $tType] :
      ( ( cancel1802427076303600483id_add(B)
        & ordere2412721322843649153imp_le(B) )
     => ! [J: nat,I: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M)),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J),U)),M)),N) ) ) ) ).

% iterate_add_less_eq_iff1
tff(fact_5834_iterate__add__less__iff1,axiom,
    ! [B: $tType] :
      ( ( cancel1802427076303600483id_add(B)
        & ordere2412721322843649153imp_le(B) )
     => ! [J: nat,I: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),J),I)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M)),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),I),J),U)),M)),N) ) ) ) ).

% iterate_add_less_iff1
tff(fact_5835_iterate__add__less__iff2,axiom,
    ! [B: $tType] :
      ( ( cancel1802427076303600483id_add(B)
        & ordere2412721322843649153imp_le(B) )
     => ! [I: nat,J: nat,U: B,M: B,N: B] :
          ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),I),J)
         => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,I,U)),M)),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,J,U)),N))
          <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),M),aa(B,B,aa(B,fun(B,B),plus_plus(B),iterate_add(B,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),J),I),U)),N)) ) ) ) ).

% iterate_add_less_iff2
tff(fact_5836_comm__monoid__set_Otriangle__reindex,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,fun(nat,B)),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(product_prod(nat,nat)),B,aa(fun(product_prod(nat,nat),B),fun(set(product_prod(nat,nat)),B),groups_comm_monoid_F(B,product_prod(nat,nat),F,Z2),aa(fun(nat,fun(nat,B)),fun(product_prod(nat,nat),B),product_case_prod(nat,nat,B),G)),aa(fun(product_prod(nat,nat),$o),set(product_prod(nat,nat)),collect(product_prod(nat,nat)),aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aTP_Lamp_ej(nat,fun(nat,fun(nat,$o)),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_wv(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),F),Z2),G)),aa(nat,set(nat),set_ord_lessThan(nat),N)) ) ) ).

% comm_monoid_set.triangle_reindex
tff(fact_5837_comm__monoid__set_Otriangle__reindex__eq,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(nat,fun(nat,B)),N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(product_prod(nat,nat)),B,aa(fun(product_prod(nat,nat),B),fun(set(product_prod(nat,nat)),B),groups_comm_monoid_F(B,product_prod(nat,nat),F,Z2),aa(fun(nat,fun(nat,B)),fun(product_prod(nat,nat),B),product_case_prod(nat,nat,B),G)),aa(fun(product_prod(nat,nat),$o),set(product_prod(nat,nat)),collect(product_prod(nat,nat)),aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aTP_Lamp_ds(nat,fun(nat,fun(nat,$o)),N)))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_wv(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),F),Z2),G)),aa(nat,set(nat),set_ord_atMost(nat),N)) ) ) ).

% comm_monoid_set.triangle_reindex_eq
tff(fact_5838_comm__monoid__set_OatLeast__int__lessThan__int__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(int,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(int),B,aa(fun(int,B),fun(set(int),B),groups_comm_monoid_F(B,int,F,Z2),G),set_or7035219750837199246ssThan(int,aa(nat,int,semiring_1_of_nat(int),M),aa(nat,int,semiring_1_of_nat(int),N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,int),fun(nat,B),aa(fun(int,B),fun(fun(nat,int),fun(nat,B)),comp(int,B,nat),G),semiring_1_of_nat(int))),set_or7035219750837199246ssThan(nat,M,N)) ) ) ).

% comm_monoid_set.atLeast_int_lessThan_int_shift
tff(fact_5839_comm__monoid__set_OatLeast__int__atMost__int__shift,axiom,
    ! [B: $tType,F: fun(B,fun(B,B)),Z2: B,G: fun(int,B),M: nat,N: nat] :
      ( groups778175481326437816id_set(B,F,Z2)
     => ( aa(set(int),B,aa(fun(int,B),fun(set(int),B),groups_comm_monoid_F(B,int,F,Z2),G),set_or1337092689740270186AtMost(int,aa(nat,int,semiring_1_of_nat(int),M),aa(nat,int,semiring_1_of_nat(int),N))) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,F,Z2),aa(fun(nat,int),fun(nat,B),aa(fun(int,B),fun(fun(nat,int),fun(nat,B)),comp(int,B,nat),G),semiring_1_of_nat(int))),set_or1337092689740270186AtMost(nat,M,N)) ) ) ).

% comm_monoid_set.atLeast_int_atMost_int_shift
tff(fact_5840_old_Ounit_Ocase,axiom,
    ! [B: $tType,F: B] : product_case_unit(B,F,product_Unity) = F ).

% old.unit.case
tff(fact_5841_wfP__wf__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B))] :
      ( wfP(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R))
    <=> wf(B,R) ) ).

% wfP_wf_eq
tff(fact_5842_subset__mset_Omin__add__distrib__left,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B),Z2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),min(multiset(B),subseteq_mset(B),X2,Y)),Z2) = min(multiset(B),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Z2),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),Y),Z2)) ).

% subset_mset.min_add_distrib_left
tff(fact_5843_subset__mset_Omin__arg__le_I1_J,axiom,
    ! [B: $tType,N: multiset(B),M: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),N),min(multiset(B),subseteq_mset(B),M,N))
    <=> ( min(multiset(B),subseteq_mset(B),M,N) = N ) ) ).

% subset_mset.min_arg_le(1)
tff(fact_5844_subset__mset_Omin__arg__le_I2_J,axiom,
    ! [B: $tType,M: multiset(B),N: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),subseteq_mset(B),M),min(multiset(B),subseteq_mset(B),M,N))
    <=> ( min(multiset(B),subseteq_mset(B),M,N) = M ) ) ).

% subset_mset.min_arg_le(2)
tff(fact_5845_wfP__accp__iff,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o))] :
      ( wfP(B,R)
    <=> ! [X_1: B] : aa(B,$o,accp(B,R),X_1) ) ).

% wfP_accp_iff
tff(fact_5846_accp__wfPI,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o))] :
      ( ! [X_13: B] : aa(B,$o,accp(B,R),X_13)
     => wfP(B,R) ) ).

% accp_wfPI
tff(fact_5847_accp__wfPD,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),X2: B] :
      ( wfP(B,R)
     => aa(B,$o,accp(B,R),X2) ) ).

% accp_wfPD
tff(fact_5848_unit_Ocase__distrib,axiom,
    ! [C: $tType,B: $tType,Ha: fun(C,B),F: C,Unit: product_unit] : aa(C,B,Ha,product_case_unit(C,F,Unit)) = product_case_unit(B,aa(C,B,Ha,F),Unit) ).

% unit.case_distrib
tff(fact_5849_subset__mset_Omin__add__distrib__right,axiom,
    ! [B: $tType,X2: multiset(B),Y: multiset(B),Z2: multiset(B)] : aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),min(multiset(B),subseteq_mset(B),Y,Z2)) = min(multiset(B),subseteq_mset(B),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Y),aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),X2),Z2)) ).

% subset_mset.min_add_distrib_right
tff(fact_5850_accp__eq__acc,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),X: B] :
      ( aa(B,$o,accp(B,R),X)
    <=> member(B,X,acc(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% accp_eq_acc
tff(fact_5851_rtrancl__def,axiom,
    ! [B: $tType,X: set(product_prod(B,B))] : transitive_rtrancl(B,X) = aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),transitive_rtranclp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),X)))) ).

% rtrancl_def
tff(fact_5852_Enum_Ortranclp__rtrancl__eq,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),X2: B,Y: B] :
      ( aa(B,$o,aa(B,fun(B,$o),transitive_rtranclp(B,R),X2),Y)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X2),Y),transitive_rtrancl(B,aa(fun(product_prod(B,B),$o),set(product_prod(B,B)),collect(product_prod(B,B)),aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),R)))) ) ).

% Enum.rtranclp_rtrancl_eq
tff(fact_5853_acc_Ocases,axiom,
    ! [B: $tType,A3: B,R: set(product_prod(B,B))] :
      ( member(B,A3,acc(B,R))
     => ! [Y5: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),A3),R)
         => member(B,Y5,acc(B,R)) ) ) ).

% acc.cases
tff(fact_5854_acc_Osimps,axiom,
    ! [B: $tType,A3: B,R: set(product_prod(B,B))] :
      ( member(B,A3,acc(B,R))
    <=> ? [X4: B] :
          ( ( A3 = X4 )
          & ! [Xa2: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),R)
             => member(B,Xa2,acc(B,R)) ) ) ) ).

% acc.simps
tff(fact_5855_acc_Ointros,axiom,
    ! [B: $tType,X2: B,R: set(product_prod(B,B))] :
      ( ! [Y4: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y4),X2),R)
         => member(B,Y4,acc(B,R)) )
     => member(B,X2,acc(B,R)) ) ).

% acc.intros
tff(fact_5856_acc__induct,axiom,
    ! [B: $tType,A3: B,R: set(product_prod(B,B)),P: fun(B,$o)] :
      ( member(B,A3,acc(B,R))
     => ( ! [X3: B] :
            ( member(B,X3,acc(B,R))
           => ( ! [Y5: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R)
                 => aa(B,$o,P,Y5) )
             => aa(B,$o,P,X3) ) )
       => aa(B,$o,P,A3) ) ) ).

% acc_induct
tff(fact_5857_acc__downward,axiom,
    ! [B: $tType,B2: B,R: set(product_prod(B,B)),A3: B] :
      ( member(B,B2,acc(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A3),B2),R)
       => member(B,A3,acc(B,R)) ) ) ).

% acc_downward
tff(fact_5858_not__acc__down,axiom,
    ! [B: $tType,X2: B,R4: set(product_prod(B,B))] :
      ( ~ member(B,X2,acc(B,R4))
     => ~ ! [Z3: B] :
            ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z3),X2),R4)
           => member(B,Z3,acc(B,R4)) ) ) ).

% not_acc_down
tff(fact_5859_acc__induct__rule,axiom,
    ! [B: $tType,A3: B,R: set(product_prod(B,B)),P: fun(B,$o)] :
      ( member(B,A3,acc(B,R))
     => ( ! [X3: B] :
            ( member(B,X3,acc(B,R))
           => ( ! [Y5: B] :
                  ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Y5),X3),R)
                 => aa(B,$o,P,Y5) )
             => aa(B,$o,P,X3) ) )
       => aa(B,$o,P,A3) ) ) ).

% acc_induct_rule
tff(fact_5860_rtranclp__induct2,axiom,
    ! [B: $tType,C: $tType,R: fun(product_prod(B,C),fun(product_prod(B,C),$o)),Ax: B,Ay: C,Bx: B,By: C,P: fun(B,fun(C,$o))] :
      ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_rtranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By))
     => ( aa(C,$o,aa(B,fun(C,$o),P,Ax),Ay)
       => ( ! [A5: B,B3: C,Aa2: B,Ba: C] :
              ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_rtranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3))
             => ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),R,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba))
               => ( aa(C,$o,aa(B,fun(C,$o),P,A5),B3)
                 => aa(C,$o,aa(B,fun(C,$o),P,Aa2),Ba) ) ) )
         => aa(C,$o,aa(B,fun(C,$o),P,Bx),By) ) ) ) ).

% rtranclp_induct2
tff(fact_5861_converse__rtranclpE2,axiom,
    ! [B: $tType,C: $tType,R: fun(product_prod(B,C),fun(product_prod(B,C),$o)),Xa: B,Xb: C,Za2: B,Zb: C] :
      ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_rtranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa),Xb)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Za2),Zb))
     => ( ( aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa),Xb) != aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Za2),Zb) )
       => ~ ! [A5: B,B3: C] :
              ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),R,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Xa),Xb)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3))
             => ~ aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_rtranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Za2),Zb)) ) ) ) ).

% converse_rtranclpE2
tff(fact_5862_converse__rtranclp__induct2,axiom,
    ! [B: $tType,C: $tType,R: fun(product_prod(B,C),fun(product_prod(B,C),$o)),Ax: B,Ay: C,Bx: B,By: C,P: fun(B,fun(C,$o))] :
      ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_rtranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Ax),Ay)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By))
     => ( aa(C,$o,aa(B,fun(C,$o),P,Bx),By)
       => ( ! [A5: B,B3: C,Aa2: B,Ba: C] :
              ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),R,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A5),B3)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba))
             => ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),transitive_rtranclp(product_prod(B,C),R),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Aa2),Ba)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Bx),By))
               => ( aa(C,$o,aa(B,fun(C,$o),P,Aa2),Ba)
                 => aa(C,$o,aa(B,fun(C,$o),P,A5),B3) ) ) )
         => aa(C,$o,aa(B,fun(C,$o),P,Ax),Ay) ) ) ) ).

% converse_rtranclp_induct2
tff(fact_5863_accp__downwards__aux,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),B2: B,A3: B] :
      ( aa(B,$o,aa(B,fun(B,$o),transitive_rtranclp(B,R),B2),A3)
     => ( aa(B,$o,accp(B,R),A3)
       => aa(B,$o,accp(B,R),B2) ) ) ).

% accp_downwards_aux
tff(fact_5864_accp__downwards,axiom,
    ! [B: $tType,R: fun(B,fun(B,$o)),A3: B,B2: B] :
      ( aa(B,$o,accp(B,R),A3)
     => ( aa(B,$o,aa(B,fun(B,$o),transitive_rtranclp(B,R),B2),A3)
       => aa(B,$o,accp(B,R),B2) ) ) ).

% accp_downwards
tff(fact_5865_Transitive__Closure_Ortranclp__rtrancl__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X: B,Xa3: B] :
      ( aa(B,$o,aa(B,fun(B,$o),transitive_rtranclp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R)),X),Xa3)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X),Xa3),transitive_rtrancl(B,R)) ) ).

% Transitive_Closure.rtranclp_rtrancl_eq
tff(fact_5866_acc__subset__induct,axiom,
    ! [B: $tType,D4: set(B),R4: set(product_prod(B,B)),X2: B,P: fun(B,$o)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),D4),acc(B,R4))
     => ( ! [X3: B,Z3: B] :
            ( member(B,X3,D4)
           => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z3),X3),R4)
             => member(B,Z3,D4) ) )
       => ( member(B,X2,D4)
         => ( ! [X3: B] :
                ( member(B,X3,D4)
               => ( ! [Z5: B] :
                      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z5),X3),R4)
                     => aa(B,$o,P,Z5) )
                 => aa(B,$o,P,X3) ) )
           => aa(B,$o,P,X2) ) ) ) ) ).

% acc_subset_induct
tff(fact_5867_acc__downwards,axiom,
    ! [B: $tType,A3: B,R: set(product_prod(B,B)),B2: B] :
      ( member(B,A3,acc(B,R))
     => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),transitive_rtrancl(B,R))
       => member(B,B2,acc(B,R)) ) ) ).

% acc_downwards
tff(fact_5868_acc__downwards__aux,axiom,
    ! [B: $tType,B2: B,A3: B,R: set(product_prod(B,B))] :
      ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B2),A3),transitive_rtrancl(B,R))
     => ( member(B,A3,acc(B,R))
       => member(B,B2,acc(B,R)) ) ) ).

% acc_downwards_aux
tff(fact_5869_accp__acc__eq,axiom,
    ! [B: $tType,R: set(product_prod(B,B)),X: B] :
      ( aa(B,$o,accp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),R)),X)
    <=> member(B,X,acc(B,R)) ) ).

% accp_acc_eq
tff(fact_5870_acc__def,axiom,
    ! [B: $tType,X: set(product_prod(B,B))] : acc(B,X) = aa(fun(B,$o),set(B),collect(B),accp(B,aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),X))) ).

% acc_def
tff(fact_5871_scomp__fcomp,axiom,
    ! [B: $tType,E: $tType,F4: $tType,C: $tType,D: $tType,F: fun(B,product_prod(E,F4)),G: fun(E,fun(F4,D)),Ha: fun(D,C)] : fcomp(B,D,C,product_scomp(B,E,F4,D,F,G),Ha) = product_scomp(B,E,F4,C,F,aa(fun(D,C),fun(E,fun(F4,C)),aTP_Lamp_ww(fun(E,fun(F4,D)),fun(fun(D,C),fun(E,fun(F4,C))),G),Ha)) ).

% scomp_fcomp
tff(fact_5872_successively_Opelims_I2_J,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B)] :
      ( successively(B,X2,Xa)
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ( ( ( Xa = nil(B) )
           => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),nil(B))) )
         => ( ! [X3: B] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
               => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))) )
           => ~ ! [X3: B,Y4: B,Xs: list(B)] :
                  ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) )
                 => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs))))
                   => ~ ( aa(B,$o,aa(B,fun(B,$o),X2,X3),Y4)
                        & successively(B,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) ) ) ) ) ) ) ) ).

% successively.pelims(2)
tff(fact_5873_successively_Opelims_I1_J,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B),Y: $o] :
      ( ( successively(B,X2,Xa)
      <=> (Y) )
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ( ( ( Xa = nil(B) )
           => ( (Y)
             => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),nil(B))) ) )
         => ( ! [X3: B] :
                ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)) )
               => ( (Y)
                 => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),nil(B)))) ) )
           => ~ ! [X3: B,Y4: B,Xs: list(B)] :
                  ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) )
                 => ( ( (Y)
                    <=> ( aa(B,$o,aa(B,fun(B,$o),X2,X3),Y4)
                        & successively(B,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) ) )
                   => ~ aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)))) ) ) ) ) ) ) ).

% successively.pelims(1)
tff(fact_5874_fcomp__apply,axiom,
    ! [B: $tType,D: $tType,C: $tType,F: fun(C,D),G: fun(D,B),X2: C] : aa(C,B,fcomp(C,D,B,F,G),X2) = aa(D,B,G,aa(C,D,F,X2)) ).

% fcomp_apply
tff(fact_5875_id__fcomp,axiom,
    ! [C: $tType,B: $tType,G: fun(B,C)] : fcomp(B,B,C,id(B),G) = G ).

% id_fcomp
tff(fact_5876_fcomp__id,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C)] : fcomp(B,C,C,F,id(C)) = F ).

% fcomp_id
tff(fact_5877_fcomp__scomp,axiom,
    ! [B: $tType,F4: $tType,C: $tType,E: $tType,D: $tType,F: fun(B,F4),G: fun(F4,product_prod(D,E)),Ha: fun(D,fun(E,C))] : product_scomp(B,D,E,C,fcomp(B,F4,product_prod(D,E),F,G),Ha) = fcomp(B,F4,C,F,product_scomp(F4,D,E,C,G,Ha)) ).

% fcomp_scomp
tff(fact_5878_fcomp__assoc,axiom,
    ! [B: $tType,E: $tType,C: $tType,D: $tType,F: fun(B,E),G: fun(E,D),Ha: fun(D,C)] : fcomp(B,D,C,fcomp(B,E,D,F,G),Ha) = fcomp(B,E,C,F,fcomp(E,D,C,G,Ha)) ).

% fcomp_assoc
tff(fact_5879_fcomp__def,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,D),G: fun(D,C),X: B] : aa(B,C,fcomp(B,D,C,F,G),X) = aa(D,C,G,aa(B,D,F,X)) ).

% fcomp_def
tff(fact_5880_fcomp__comp,axiom,
    ! [C: $tType,D: $tType,B: $tType,F: fun(B,D),G: fun(D,C)] : fcomp(B,D,C,F,G) = aa(fun(B,D),fun(B,C),aa(fun(D,C),fun(fun(B,D),fun(B,C)),comp(D,C,B),G),F) ).

% fcomp_comp
tff(fact_5881_successively_Opelims_I3_J,axiom,
    ! [B: $tType,X2: fun(B,fun(B,$o)),Xa: list(B)] :
      ( ~ successively(B,X2,Xa)
     => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),Xa))
       => ~ ! [X3: B,Y4: B,Xs: list(B)] :
              ( ( Xa = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) )
             => ( aa(product_prod(fun(B,fun(B,$o)),list(B)),$o,accp(product_prod(fun(B,fun(B,$o)),list(B)),successively_rel(B)),aa(list(B),product_prod(fun(B,fun(B,$o)),list(B)),aa(fun(B,fun(B,$o)),fun(list(B),product_prod(fun(B,fun(B,$o)),list(B))),product_Pair(fun(B,fun(B,$o)),list(B)),X2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs))))
               => ( aa(B,$o,aa(B,fun(B,$o),X2,X3),Y4)
                  & successively(B,X2,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y4),Xs)) ) ) ) ) ) ).

% successively.pelims(3)
tff(fact_5882_folding__idem__axioms_Ointro,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( ! [X3: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,X3)) = aa(B,fun(C,C),F,X3)
     => finite7837460588564673216axioms(B,C,F) ) ).

% folding_idem_axioms.intro
tff(fact_5883_comp__fun__idem__axioms_Ointro,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( ! [X3: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,X3)) = aa(B,fun(C,C),F,X3)
     => finite1981172056906289455axioms(B,C,F) ) ).

% comp_fun_idem_axioms.intro
tff(fact_5884_folding__idem__on__axioms_Ointro,axiom,
    ! [C: $tType,B: $tType,S2: set(B),F: fun(B,fun(C,C))] :
      ( ! [X3: B,Y4: B] :
          ( member(B,X3,S2)
         => ( member(B,Y4,S2)
           => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,X3)) = aa(B,fun(C,C),F,X3) ) ) )
     => finite6916993218817215295axioms(B,C,S2,F) ) ).

% folding_idem_on_axioms.intro
tff(fact_5885_folding__idem__on__axioms__def,axiom,
    ! [C: $tType,B: $tType,S2: set(B),F: fun(B,fun(C,C))] :
      ( finite6916993218817215295axioms(B,C,S2,F)
    <=> ! [X4: B,Y3: B] :
          ( member(B,X4,S2)
         => ( member(B,Y3,S2)
           => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X4)),aa(B,fun(C,C),F,X4)) = aa(B,fun(C,C),F,X4) ) ) ) ) ).

% folding_idem_on_axioms_def
tff(fact_5886_comp__fun__idem__axioms__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( finite1981172056906289455axioms(B,C,F)
    <=> ! [X4: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X4)),aa(B,fun(C,C),F,X4)) = aa(B,fun(C,C),F,X4) ) ).

% comp_fun_idem_axioms_def
tff(fact_5887_folding__idem__axioms__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( finite7837460588564673216axioms(B,C,F)
    <=> ! [X4: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X4)),aa(B,fun(C,C),F,X4)) = aa(B,fun(C,C),F,X4) ) ).

% folding_idem_axioms_def
tff(fact_5888_comp__fun__idem__on__axioms__def,axiom,
    ! [C: $tType,B: $tType,S2: set(B),F: fun(B,fun(C,C))] :
      ( finite4980608107308702382axioms(B,C,S2,F)
    <=> ! [X4: B] :
          ( member(B,X4,S2)
         => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X4)),aa(B,fun(C,C),F,X4)) = aa(B,fun(C,C),F,X4) ) ) ) ).

% comp_fun_idem_on_axioms_def
tff(fact_5889_comp__fun__idem__on__axioms_Ointro,axiom,
    ! [C: $tType,B: $tType,S2: set(B),F: fun(B,fun(C,C))] :
      ( ! [X3: B] :
          ( member(B,X3,S2)
         => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,X3)) = aa(B,fun(C,C),F,X3) ) )
     => finite4980608107308702382axioms(B,C,S2,F) ) ).

% comp_fun_idem_on_axioms.intro
tff(fact_5890_image__mset__If,axiom,
    ! [B: $tType,C: $tType,P: fun(C,$o),F: fun(C,B),G: fun(C,B),A4: multiset(C)] : aa(multiset(C),multiset(B),image_mset(C,B,aa(fun(C,B),fun(C,B),aa(fun(C,B),fun(fun(C,B),fun(C,B)),aTP_Lamp_wx(fun(C,$o),fun(fun(C,B),fun(fun(C,B),fun(C,B))),P),F),G)),A4) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),aa(multiset(C),multiset(B),image_mset(C,B,F),filter_mset(C,P,A4))),aa(multiset(C),multiset(B),image_mset(C,B,G),filter_mset(C,aTP_Lamp_wy(fun(C,$o),fun(C,$o),P),A4))) ).

% image_mset_If
tff(fact_5891_union__filter__mset__complement,axiom,
    ! [B: $tType,P: fun(B,$o),Q: fun(B,$o),M2: multiset(B)] :
      ( ! [X3: B] :
          ( aa(B,$o,P,X3)
        <=> ~ aa(B,$o,Q,X3) )
     => ( aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),filter_mset(B,P,M2)),filter_mset(B,Q,M2)) = M2 ) ) ).

% union_filter_mset_complement
tff(fact_5892_filter__union__mset,axiom,
    ! [B: $tType,P: fun(B,$o),M2: multiset(B),N5: multiset(B)] : filter_mset(B,P,aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M2),N5)) = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),filter_mset(B,P,M2)),filter_mset(B,P,N5)) ).

% filter_union_mset
tff(fact_5893_multiset__partition,axiom,
    ! [B: $tType,M2: multiset(B),P: fun(B,$o)] : M2 = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),filter_mset(B,P,M2)),filter_mset(B,aTP_Lamp_ol(fun(B,$o),fun(B,$o),P),M2)) ).

% multiset_partition
tff(fact_5894_heap_Olub__upper,axiom,
    ! [B: $tType,A4: set(heap_Time_Heap(B)),X2: heap_Time_Heap(B)] :
      ( comple1602240252501008431_chain(heap_Time_Heap(B),heap_Time_Heap_ord(B),A4)
     => ( member(heap_Time_Heap(B),X2,A4)
       => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X2),aa(set(heap_Time_Heap(B)),heap_Time_Heap(B),heap_Time_Heap_lub(B),A4)) ) ) ).

% heap.lub_upper
tff(fact_5895_heap_Olub__least,axiom,
    ! [B: $tType,A4: set(heap_Time_Heap(B)),Z2: heap_Time_Heap(B)] :
      ( comple1602240252501008431_chain(heap_Time_Heap(B),heap_Time_Heap_ord(B),A4)
     => ( ! [X3: heap_Time_Heap(B)] :
            ( member(heap_Time_Heap(B),X3,A4)
           => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),X3),Z2) )
       => aa(heap_Time_Heap(B),$o,aa(heap_Time_Heap(B),fun(heap_Time_Heap(B),$o),heap_Time_Heap_ord(B),aa(set(heap_Time_Heap(B)),heap_Time_Heap(B),heap_Time_Heap_lub(B),A4)),Z2) ) ) ).

% heap.lub_least
tff(fact_5896_plus__int__code_I6_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),plus_plus(int),neg(M)),neg(N)) = neg(aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% plus_int_code(6)
tff(fact_5897_ccpo__Sup__mono,axiom,
    ! [B: $tType] :
      ( comple9053668089753744459l_ccpo(B)
     => ! [A4: set(B),B5: set(B)] :
          ( comple1602240252501008431_chain(B,ord_less_eq(B),A4)
         => ( comple1602240252501008431_chain(B,ord_less_eq(B),B5)
           => ( ! [X3: B] :
                  ( member(B,X3,A4)
                 => ? [Xa3: B] :
                      ( member(B,Xa3,B5)
                      & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X3),Xa3) ) )
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(set(B),B,complete_Sup_Sup(B),A4)),aa(set(B),B,complete_Sup_Sup(B),B5)) ) ) ) ) ).

% ccpo_Sup_mono
tff(fact_5898_plus__int__code_I5_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),plus_plus(int),neg(M)),pos(N)) = sub(N,M) ).

% plus_int_code(5)
tff(fact_5899_plus__int__code_I4_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),plus_plus(int),pos(M)),neg(N)) = sub(M,N) ).

% plus_int_code(4)
tff(fact_5900_minus__int__code_I4_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),minus_minus(int),pos(M)),neg(N)) = pos(aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% minus_int_code(4)
tff(fact_5901_plus__int__code_I3_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),plus_plus(int),pos(M)),pos(N)) = pos(aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% plus_int_code(3)
tff(fact_5902_minus__int__code_I5_J,axiom,
    ! [M: num,N: num] : aa(int,int,aa(int,fun(int,int),minus_minus(int),neg(M)),pos(N)) = neg(aa(num,num,aa(num,fun(num,num),plus_plus(num),M),N)) ).

% minus_int_code(5)
tff(fact_5903_Unity__def,axiom,
    product_Unity = aa($o,product_unit,product_Abs_unit,$true) ).

% Unity_def
tff(fact_5904_Domainp__Domain__eq,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(B,C)),X: B] :
      ( aa(B,$o,domainp(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),R)),X)
    <=> member(B,X,domain(B,C,R)) ) ).

% Domainp_Domain_eq
tff(fact_5905_Domain__def,axiom,
    ! [C: $tType,B: $tType,X: set(product_prod(B,C))] : domain(B,C,X) = aa(fun(B,$o),set(B),collect(B),domainp(B,C,aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),X))) ).

% Domain_def
tff(fact_5906_Abs__unit__inject,axiom,
    ! [X2: $o,Y: $o] :
      ( member($o,(X2),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o))))
     => ( member($o,(Y),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o))))
       => ( ( aa($o,product_unit,product_Abs_unit,(X2)) = aa($o,product_unit,product_Abs_unit,(Y)) )
        <=> ( (X2)
          <=> (Y) ) ) ) ) ).

% Abs_unit_inject
tff(fact_5907_Abs__unit__induct,axiom,
    ! [P: fun(product_unit,$o),X2: product_unit] :
      ( ! [Y4: $o] :
          ( member($o,(Y4),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o))))
         => aa(product_unit,$o,P,aa($o,product_unit,product_Abs_unit,(Y4))) )
     => aa(product_unit,$o,P,X2) ) ).

% Abs_unit_induct
tff(fact_5908_Abs__unit__cases,axiom,
    ! [X2: product_unit] :
      ~ ! [Y4: $o] :
          ( ( X2 = aa($o,product_unit,product_Abs_unit,(Y4)) )
         => ~ member($o,(Y4),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o)))) ) ).

% Abs_unit_cases
tff(fact_5909_Heap_ODomainp__rel,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(C,$o))] : domainp(heap_Time_Heap(B),heap_Time_Heap(C),aa(fun(B,fun(C,$o)),fun(heap_Time_Heap(B),fun(heap_Time_Heap(C),$o)),heap_Time_rel_Heap(B,C),R4)) = aa(fun(B,$o),fun(heap_Time_Heap(B),$o),heap_Time_pred_Heap(B),domainp(B,C,R4)) ).

% Heap.Domainp_rel
tff(fact_5910_integer_Odomain,axiom,
    ! [P: fun(int,$o)] :
      ( ( domainp(int,int,fequal(int)) = P )
     => ( domainp(int,code_integer,code_pcr_integer) = P ) ) ).

% integer.domain
tff(fact_5911_natural_Odomain,axiom,
    ! [P: fun(nat,$o)] :
      ( ( domainp(nat,nat,fequal(nat)) = P )
     => ( domainp(nat,code_natural,code_pcr_natural) = P ) ) ).

% natural.domain
tff(fact_5912_option_ODomainp__rel,axiom,
    ! [C: $tType,B: $tType,R4: fun(B,fun(C,$o))] : domainp(option(B),option(C),aa(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),rel_option(B,C),R4)) = aa(fun(B,$o),fun(option(B),$o),pred_option(B),domainp(B,C,R4)) ).

% option.Domainp_rel
tff(fact_5913_Abs__unit__inverse,axiom,
    ! [Y: $o] :
      ( member($o,(Y),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o))))
     => ( aa(product_unit,$o,product_Rep_unit,aa($o,product_unit,product_Abs_unit,(Y)))
      <=> (Y) ) ) ).

% Abs_unit_inverse
tff(fact_5914_type__definition__unit,axiom,
    type_definition(product_unit,$o,product_Rep_unit,product_Abs_unit,aa(set($o),set($o),insert2($o,$true),bot_bot(set($o)))) ).

% type_definition_unit
tff(fact_5915_Rep__unit__inverse,axiom,
    ! [X2: product_unit] : aa($o,product_unit,product_Abs_unit,aa(product_unit,$o,product_Rep_unit,X2)) = X2 ).

% Rep_unit_inverse
tff(fact_5916_Rep__unit__inject,axiom,
    ! [X2: product_unit,Y: product_unit] :
      ( ( aa(product_unit,$o,product_Rep_unit,X2)
      <=> aa(product_unit,$o,product_Rep_unit,Y) )
    <=> ( X2 = Y ) ) ).

% Rep_unit_inject
tff(fact_5917_Rep__unit,axiom,
    ! [X2: product_unit] : member($o,aa(product_unit,$o,product_Rep_unit,X2),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o)))) ).

% Rep_unit
tff(fact_5918_Rep__unit__cases,axiom,
    ! [Y: $o] :
      ( member($o,(Y),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o))))
     => ~ ! [X3: product_unit] :
            ( (Y)
          <=> ~ aa(product_unit,$o,product_Rep_unit,X3) ) ) ).

% Rep_unit_cases
tff(fact_5919_Rep__unit__induct,axiom,
    ! [Y: $o,P: fun($o,$o)] :
      ( member($o,(Y),aa(set($o),set($o),insert2($o,$true),bot_bot(set($o))))
     => ( ! [X3: product_unit] : aa($o,$o,P,aa(product_unit,$o,product_Rep_unit,X3))
       => aa($o,$o,P,(Y)) ) ) ).

% Rep_unit_induct
tff(fact_5920_adm__wf__def,axiom,
    ! [C: $tType,B: $tType,R4: set(product_prod(B,B)),F5: fun(fun(B,C),fun(B,C))] :
      ( adm_wf(B,C,R4,F5)
    <=> ! [F6: fun(B,C),G5: fun(B,C),X4: B] :
          ( ! [Z4: B] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z4),X4),R4)
             => ( aa(B,C,F6,Z4) = aa(B,C,G5,Z4) ) )
         => ( aa(B,C,aa(fun(B,C),fun(B,C),F5,F6),X4) = aa(B,C,aa(fun(B,C),fun(B,C),F5,G5),X4) ) ) ) ).

% adm_wf_def
tff(fact_5921_folding__idem_Ocomp__fun__idem,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C)),X2: B] :
      ( finite_folding_idem(B,C,F)
     => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X2)),aa(B,fun(C,C),F,X2)) = aa(B,fun(C,C),F,X2) ) ) ).

% folding_idem.comp_fun_idem
tff(fact_5922_compat__def,axiom,
    ! [B: $tType,C: $tType,R: set(product_prod(B,B)),R3: set(product_prod(C,C)),F: fun(B,C)] :
      ( bNF_Wellorder_compat(B,C,R,R3,F)
    <=> ! [A7: B,B7: B] :
          ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),B7),R)
         => member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,F,A7)),aa(B,C,F,B7)),R3) ) ) ).

% compat_def
tff(fact_5923_positive__add,axiom,
    ! [X2: rat,Y: rat] :
      ( positive(X2)
     => ( positive(Y)
       => positive(aa(rat,rat,aa(rat,fun(rat,rat),plus_plus(rat),X2),Y)) ) ) ).

% positive_add
tff(fact_5924_inj__on__iff__Uniq,axiom,
    ! [C: $tType,B: $tType,F: fun(B,C),A4: set(B)] :
      ( inj_on(B,C,F,A4)
    <=> ! [X4: B] :
          ( member(B,X4,A4)
         => uniq(B,aa(B,fun(B,$o),aa(set(B),fun(B,fun(B,$o)),aTP_Lamp_wz(fun(B,C),fun(set(B),fun(B,fun(B,$o))),F),A4),X4)) ) ) ).

% inj_on_iff_Uniq
tff(fact_5925_mono__imp__mono__on,axiom,
    ! [C: $tType,B: $tType] :
      ( ( order(B)
        & order(C) )
     => ! [F: fun(B,C),A4: set(B)] :
          ( order_mono(B,C,F)
         => mono_on(B,C,F,A4) ) ) ).

% mono_imp_mono_on
tff(fact_5926_mono__on__subset,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [F: fun(B,C),A4: set(B),B5: set(B)] :
          ( mono_on(B,C,F,A4)
         => ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),B5),A4)
           => mono_on(B,C,F,B5) ) ) ) ).

% mono_on_subset
tff(fact_5927_mono__on__greaterD,axiom,
    ! [C: $tType,B: $tType] :
      ( ( linorder(B)
        & linorder(C) )
     => ! [G: fun(B,C),A4: set(B),X2: B,Y: B] :
          ( mono_on(B,C,G,A4)
         => ( member(B,X2,A4)
           => ( member(B,Y,A4)
             => ( aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(B,C,G,Y)),aa(B,C,G,X2))
               => aa(B,$o,aa(B,fun(B,$o),ord_less(B),Y),X2) ) ) ) ) ) ).

% mono_on_greaterD
tff(fact_5928_mono__onD,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [F: fun(B,C),A4: set(B),R: B,S: B] :
          ( mono_on(B,C,F,A4)
         => ( member(B,R,A4)
           => ( member(B,S,A4)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),R),S)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,F,R)),aa(B,C,F,S)) ) ) ) ) ) ).

% mono_onD
tff(fact_5929_mono__onI,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [A4: set(B),F: fun(B,C)] :
          ( ! [R2: B,S4: B] :
              ( member(B,R2,A4)
             => ( member(B,S4,A4)
               => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),R2),S4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,F,R2)),aa(B,C,F,S4)) ) ) )
         => mono_on(B,C,F,A4) ) ) ).

% mono_onI
tff(fact_5930_mono__on__def,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [F: fun(B,C),A4: set(B)] :
          ( mono_on(B,C,F,A4)
        <=> ! [R5: B,S6: B] :
              ( ( member(B,R5,A4)
                & member(B,S6,A4)
                & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),R5),S6) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,F,R5)),aa(B,C,F,S6)) ) ) ) ).

% mono_on_def
tff(fact_5931_strict__mono__on__imp__mono__on,axiom,
    ! [C: $tType,B: $tType] :
      ( ( linorder(B)
        & preorder(C) )
     => ! [F: fun(B,C),A4: set(B)] :
          ( strict_mono_on(B,C,F,A4)
         => mono_on(B,C,F,A4) ) ) ).

% strict_mono_on_imp_mono_on
tff(fact_5932_folding_Ointro,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( ! [Y4: B,X3: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y4)),aa(B,fun(C,C),F,X3)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X3)),aa(B,fun(C,C),F,Y4))
     => finite_folding(B,C,F) ) ).

% folding.intro
tff(fact_5933_folding_Ocomp__fun__commute,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C)),Y: B,X2: B] :
      ( finite_folding(B,C,F)
     => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y)),aa(B,fun(C,C),F,X2)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X2)),aa(B,fun(C,C),F,Y)) ) ) ).

% folding.comp_fun_commute
tff(fact_5934_strict__mono__on__eqD,axiom,
    ! [C: $tType,B: $tType] :
      ( ( linorder(B)
        & preorder(C) )
     => ! [F: fun(B,C),A4: set(B),X2: B,Y: B] :
          ( strict_mono_on(B,C,F,A4)
         => ( ( aa(B,C,F,X2) = aa(B,C,F,Y) )
           => ( member(B,X2,A4)
             => ( member(B,Y,A4)
               => ( Y = X2 ) ) ) ) ) ) ).

% strict_mono_on_eqD
tff(fact_5935_strict__mono__on__leD,axiom,
    ! [C: $tType,B: $tType] :
      ( ( linorder(B)
        & preorder(C) )
     => ! [F: fun(B,C),A4: set(B),X2: B,Y: B] :
          ( strict_mono_on(B,C,F,A4)
         => ( member(B,X2,A4)
           => ( member(B,Y,A4)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),X2),Y)
               => aa(C,$o,aa(C,fun(C,$o),ord_less_eq(C),aa(B,C,F,X2)),aa(B,C,F,Y)) ) ) ) ) ) ).

% strict_mono_on_leD
tff(fact_5936_strict__mono__on__def,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [F: fun(B,C),A4: set(B)] :
          ( strict_mono_on(B,C,F,A4)
        <=> ! [R5: B,S6: B] :
              ( ( member(B,R5,A4)
                & member(B,S6,A4)
                & aa(B,$o,aa(B,fun(B,$o),ord_less(B),R5),S6) )
             => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(B,C,F,R5)),aa(B,C,F,S6)) ) ) ) ).

% strict_mono_on_def
tff(fact_5937_strict__mono__onI,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [A4: set(B),F: fun(B,C)] :
          ( ! [R2: B,S4: B] :
              ( member(B,R2,A4)
             => ( member(B,S4,A4)
               => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),R2),S4)
                 => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(B,C,F,R2)),aa(B,C,F,S4)) ) ) )
         => strict_mono_on(B,C,F,A4) ) ) ).

% strict_mono_onI
tff(fact_5938_strict__mono__onD,axiom,
    ! [C: $tType,B: $tType] :
      ( ( ord(B)
        & ord(C) )
     => ! [F: fun(B,C),A4: set(B),R: B,S: B] :
          ( strict_mono_on(B,C,F,A4)
         => ( member(B,R,A4)
           => ( member(B,S,A4)
             => ( aa(B,$o,aa(B,fun(B,$o),ord_less(B),R),S)
               => aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(B,C,F,R)),aa(B,C,F,S)) ) ) ) ) ) ).

% strict_mono_onD
tff(fact_5939_strict__mono__on__imp__inj__on,axiom,
    ! [C: $tType,B: $tType] :
      ( ( linorder(B)
        & preorder(C) )
     => ! [F: fun(B,C),A4: set(B)] :
          ( strict_mono_on(B,C,F,A4)
         => inj_on(B,C,F,A4) ) ) ).

% strict_mono_on_imp_inj_on
tff(fact_5940_folding__def,axiom,
    ! [C: $tType,B: $tType,F: fun(B,fun(C,C))] :
      ( finite_folding(B,C,F)
    <=> ! [Y3: B,X4: B] : aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,Y3)),aa(B,fun(C,C),F,X4)) = aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X4)),aa(B,fun(C,C),F,Y3)) ) ).

% folding_def
tff(fact_5941_folding__idem__on_Ocomp__fun__idem__on,axiom,
    ! [C: $tType,B: $tType,S2: set(B),F: fun(B,fun(C,C)),X2: B,Y: B] :
      ( finite1890593828518410140dem_on(B,C,S2,F)
     => ( member(B,X2,S2)
       => ( member(B,Y,S2)
         => ( aa(fun(C,C),fun(C,C),aa(fun(C,C),fun(fun(C,C),fun(C,C)),comp(C,C,C),aa(B,fun(C,C),F,X2)),aa(B,fun(C,C),F,X2)) = aa(B,fun(C,C),F,X2) ) ) ) ) ).

% folding_idem_on.comp_fun_idem_on
tff(fact_5942_sum_OPlus,axiom,
    ! [B: $tType,D: $tType,C: $tType] :
      ( comm_monoid_add(D)
     => ! [A4: set(B),B5: set(C),G: fun(sum_sum(B,C),D)] :
          ( finite_finite2(B,A4)
         => ( finite_finite2(C,B5)
           => ( aa(set(sum_sum(B,C)),D,aa(fun(sum_sum(B,C),D),fun(set(sum_sum(B,C)),D),groups7311177749621191930dd_sum(sum_sum(B,C),D),G),sum_Plus(B,C,A4,B5)) = aa(D,D,aa(D,fun(D,D),plus_plus(D),aa(set(B),D,aa(fun(B,D),fun(set(B),D),groups7311177749621191930dd_sum(B,D),aa(fun(B,sum_sum(B,C)),fun(B,D),aa(fun(sum_sum(B,C),D),fun(fun(B,sum_sum(B,C)),fun(B,D)),comp(sum_sum(B,C),D,B),G),sum_Inl(B,C))),A4)),aa(set(C),D,aa(fun(C,D),fun(set(C),D),groups7311177749621191930dd_sum(C,D),aa(fun(C,sum_sum(B,C)),fun(C,D),aa(fun(sum_sum(B,C),D),fun(fun(C,sum_sum(B,C)),fun(C,D)),comp(sum_sum(B,C),D,C),G),sum_Inr(C,B))),B5)) ) ) ) ) ).

% sum.Plus
tff(fact_5943_map__sum__Inl__conv,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,Fl: fun(D,B),Fr: fun(E,C),S: sum_sum(D,E),Y: B] :
      ( ( aa(sum_sum(D,E),sum_sum(B,C),sum_map_sum(D,B,E,C,Fl,Fr),S) = aa(B,sum_sum(B,C),sum_Inl(B,C),Y) )
    <=> ? [X4: D] :
          ( ( S = aa(D,sum_sum(D,E),sum_Inl(D,E),X4) )
          & ( Y = aa(D,B,Fl,X4) ) ) ) ).

% map_sum_Inl_conv
tff(fact_5944_map__sum__Inr__conv,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,Fl: fun(D,B),Fr: fun(E,C),S: sum_sum(D,E),Y: C] :
      ( ( aa(sum_sum(D,E),sum_sum(B,C),sum_map_sum(D,B,E,C,Fl,Fr),S) = aa(C,sum_sum(B,C),sum_Inr(C,B),Y) )
    <=> ? [X4: E] :
          ( ( S = aa(E,sum_sum(D,E),sum_Inr(E,D),X4) )
          & ( Y = aa(E,C,Fr,X4) ) ) ) ).

% map_sum_Inr_conv
tff(fact_5945_Union__plus,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(sum_sum(C,D),set(B)),A4: set(C),B5: set(D)] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(sum_sum(C,D)),set(set(B)),image2(sum_sum(C,D),set(B),F),sum_Plus(C,D,A4,B5))) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(C),set(set(B)),image2(C,set(B),aTP_Lamp_xa(fun(sum_sum(C,D),set(B)),fun(C,set(B)),F)),A4))),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(D),set(set(B)),image2(D,set(B),aTP_Lamp_xb(fun(sum_sum(C,D),set(B)),fun(D,set(B)),F)),B5))) ).

% Union_plus
tff(fact_5946_Union__sum,axiom,
    ! [C: $tType,B: $tType,D: $tType,F: fun(sum_sum(C,D),set(B))] : aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(sum_sum(C,D)),set(set(B)),image2(sum_sum(C,D),set(B),F),top_top(set(sum_sum(C,D))))) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),sup_sup(set(B)),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(C),set(set(B)),image2(C,set(B),aTP_Lamp_xa(fun(sum_sum(C,D),set(B)),fun(C,set(B)),F)),top_top(set(C))))),aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(D),set(set(B)),image2(D,set(B),aTP_Lamp_xb(fun(sum_sum(C,D),set(B)),fun(D,set(B)),F)),top_top(set(D))))) ).

% Union_sum
tff(fact_5947_sum_Osize__gen_I1_J,axiom,
    ! [C: $tType,B: $tType,Xa: fun(B,nat),X2: fun(C,nat),X1: B] : basic_BNF_size_sum(B,C,Xa,X2,aa(B,sum_sum(B,C),sum_Inl(B,C),X1)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,Xa,X1)),aa(nat,nat,suc,zero_zero(nat))) ).

% sum.size_gen(1)
tff(fact_5948_sum_Osize__gen_I2_J,axiom,
    ! [B: $tType,C: $tType,Xa: fun(B,nat),X2: fun(C,nat),X22: C] : basic_BNF_size_sum(B,C,Xa,X2,aa(C,sum_sum(B,C),sum_Inr(C,B),X22)) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(C,nat,X2,X22)),aa(nat,nat,suc,zero_zero(nat))) ).

% sum.size_gen(2)
tff(fact_5949_Node__def,axiom,
    ! [C: $tType,B: $tType] : old_Node(B,C) = aa(fun(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),$o),set(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat))),collect(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat))),aTP_Lamp_xc(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),$o)) ).

% Node_def
tff(fact_5950_Node__K0__I,axiom,
    ! [C: $tType,B: $tType,A3: sum_sum(C,nat)] : member(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),aa(sum_sum(C,nat),product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),aa(fun(nat,sum_sum(B,nat)),fun(sum_sum(C,nat),product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat))),product_Pair(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),aTP_Lamp_xd(nat,sum_sum(B,nat))),A3),old_Node(B,C)) ).

% Node_K0_I
tff(fact_5951_nth__item_Opinduct,axiom,
    ! [A0: nat,P: fun(nat,$o)] :
      ( aa(nat,$o,accp(nat,nth_item_rel),A0)
     => ( ( aa(nat,$o,accp(nat,nth_item_rel),zero_zero(nat))
         => aa(nat,$o,P,zero_zero(nat)) )
       => ( ! [N3: nat] :
              ( aa(nat,$o,accp(nat,nth_item_rel),aa(nat,nat,suc,N3))
             => ( ! [A14: nat,Aa3: nat] :
                    ( ( nat_sum_decode(N3) = aa(nat,sum_sum(nat,nat),sum_Inl(nat,nat),A14) )
                   => ( ( nat_sum_decode(A14) = aa(nat,sum_sum(nat,nat),sum_Inl(nat,nat),Aa3) )
                     => aa(nat,$o,P,Aa3) ) )
               => ( ! [A14: nat,B6: nat] :
                      ( ( nat_sum_decode(N3) = aa(nat,sum_sum(nat,nat),sum_Inl(nat,nat),A14) )
                     => ( ( nat_sum_decode(A14) = aa(nat,sum_sum(nat,nat),sum_Inr(nat,nat),B6) )
                       => aa(nat,$o,P,B6) ) )
                 => ( ! [B6: nat,Ba2: nat,X: nat,Y5: nat] :
                        ( ( nat_sum_decode(N3) = aa(nat,sum_sum(nat,nat),sum_Inr(nat,nat),B6) )
                       => ( ( nat_sum_decode(B6) = aa(nat,sum_sum(nat,nat),sum_Inr(nat,nat),Ba2) )
                         => ( ( aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X),Y5) = nat_prod_decode(Ba2) )
                           => aa(nat,$o,P,X) ) ) )
                   => ( ! [B6: nat,Ba2: nat,X: nat,Y5: nat] :
                          ( ( nat_sum_decode(N3) = aa(nat,sum_sum(nat,nat),sum_Inr(nat,nat),B6) )
                         => ( ( nat_sum_decode(B6) = aa(nat,sum_sum(nat,nat),sum_Inr(nat,nat),Ba2) )
                           => ( ( aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),X),Y5) = nat_prod_decode(Ba2) )
                             => aa(nat,$o,P,Y5) ) ) )
                     => aa(nat,$o,P,aa(nat,nat,suc,N3)) ) ) ) ) )
         => aa(nat,$o,P,A0) ) ) ) ).

% nth_item.pinduct
tff(fact_5952_ndepth__K0,axiom,
    ! [B: $tType,C: $tType,X2: sum_sum(B,nat)] : old_ndepth(B,C,old_Abs_Node(C,B,aa(sum_sum(B,nat),product_prod(fun(nat,sum_sum(C,nat)),sum_sum(B,nat)),aa(fun(nat,sum_sum(C,nat)),fun(sum_sum(B,nat),product_prod(fun(nat,sum_sum(C,nat)),sum_sum(B,nat))),product_Pair(fun(nat,sum_sum(C,nat)),sum_sum(B,nat)),aTP_Lamp_xe(nat,sum_sum(C,nat))),X2))) = zero_zero(nat) ).

% ndepth_K0
tff(fact_5953_Atom__def,axiom,
    ! [C: $tType,B: $tType,X: sum_sum(B,nat)] : old_Atom(B,C,X) = aa(set(old_node(B,C)),set(old_node(B,C)),insert2(old_node(B,C),old_Abs_Node(C,B,aa(sum_sum(B,nat),product_prod(fun(nat,sum_sum(C,nat)),sum_sum(B,nat)),aa(fun(nat,sum_sum(C,nat)),fun(sum_sum(B,nat),product_prod(fun(nat,sum_sum(C,nat)),sum_sum(B,nat))),product_Pair(fun(nat,sum_sum(C,nat)),sum_sum(B,nat)),aTP_Lamp_xe(nat,sum_sum(C,nat))),X))),bot_bot(set(old_node(B,C)))) ).

% Atom_def
tff(fact_5954_nth__item_Opsimps_I1_J,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ( aa(nat,$o,accp(nat,nth_item_rel),zero_zero(nat))
       => ( nth_item(B,zero_zero(nat)) = undefined(set(old_node(B,product_unit))) ) ) ) ).

% nth_item.psimps(1)
tff(fact_5955_nth__item_Opelims,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [X2: nat,Y: set(old_node(B,product_unit))] :
          ( ( nth_item(B,X2) = Y )
         => ( aa(nat,$o,accp(nat,nth_item_rel),X2)
           => ( ( ( X2 = zero_zero(nat) )
               => ( ( Y = undefined(set(old_node(B,product_unit))) )
                 => ~ aa(nat,$o,accp(nat,nth_item_rel),zero_zero(nat)) ) )
             => ~ ! [N3: nat] :
                    ( ( X2 = aa(nat,nat,suc,N3) )
                   => ( ( Y = aa(sum_sum(nat,nat),set(old_node(B,product_unit)),sum_case_sum(nat,set(old_node(B,product_unit)),nat,aTP_Lamp_xh(nat,set(old_node(B,product_unit))),aTP_Lamp_xl(nat,set(old_node(B,product_unit)))),nat_sum_decode(N3)) )
                     => ~ aa(nat,$o,accp(nat,nth_item_rel),aa(nat,nat,suc,N3)) ) ) ) ) ) ) ).

% nth_item.pelims
tff(fact_5956_nth__item_Opsimps_I2_J,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [N: nat] :
          ( aa(nat,$o,accp(nat,nth_item_rel),aa(nat,nat,suc,N))
         => ( nth_item(B,aa(nat,nat,suc,N)) = aa(sum_sum(nat,nat),set(old_node(B,product_unit)),sum_case_sum(nat,set(old_node(B,product_unit)),nat,aTP_Lamp_xh(nat,set(old_node(B,product_unit))),aTP_Lamp_xl(nat,set(old_node(B,product_unit)))),nat_sum_decode(N)) ) ) ) ).

% nth_item.psimps(2)
tff(fact_5957_Scons__def,axiom,
    ! [C: $tType,B: $tType,M2: set(old_node(B,C)),N5: set(old_node(B,C))] : old_Scons(B,C,M2,N5) = aa(set(old_node(B,C)),set(old_node(B,C)),aa(set(old_node(B,C)),fun(set(old_node(B,C)),set(old_node(B,C))),sup_sup(set(old_node(B,C))),aa(set(old_node(B,C)),set(old_node(B,C)),image2(old_node(B,C),old_node(B,C),old_Push_Node(C,B,aa(nat,sum_sum(C,nat),sum_Inr(nat,C),one_one(nat)))),M2)),aa(set(old_node(B,C)),set(old_node(B,C)),image2(old_node(B,C),old_node(B,C),old_Push_Node(C,B,aa(nat,sum_sum(C,nat),sum_Inr(nat,C),aa(nat,nat,suc,one_one(nat))))),N5)) ).

% Scons_def
tff(fact_5958_In1__def,axiom,
    ! [C: $tType,B: $tType,M2: set(old_node(B,C))] : old_In1(B,C,M2) = old_Scons(B,C,old_Numb(B,C,one_one(nat)),M2) ).

% In1_def
tff(fact_5959_dsum__def,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] : old_dsum(B,C,R,S) = aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),fun(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),sup_sup(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),complete_Sup_Sup(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),image2(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),fun(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),product_case_prod(set(old_node(B,C)),set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aTP_Lamp_xm(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))))),R))),aa(set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),complete_Sup_Sup(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),image2(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),fun(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),product_case_prod(set(old_node(B,C)),set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aTP_Lamp_xn(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))))),S))) ).

% dsum_def
tff(fact_5960_dsumE,axiom,
    ! [C: $tType,B: $tType,W: product_prod(set(old_node(B,C)),set(old_node(B,C))),R: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] :
      ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),W,old_dsum(B,C,R,S))
     => ( ! [X3: set(old_node(B,C)),X5: set(old_node(B,C))] :
            ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),X3),X5),R)
           => ( W != aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_In0(B,C,X3)),old_In0(B,C,X5)) ) )
       => ~ ! [Y4: set(old_node(B,C)),Y11: set(old_node(B,C))] :
              ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),Y4),Y11),S)
             => ( W != aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_In1(B,C,Y4)),old_In1(B,C,Y11)) ) ) ) ) ).

% dsumE
tff(fact_5961_dsum__In0I,axiom,
    ! [C: $tType,B: $tType,M2: set(old_node(B,C)),M9: set(old_node(B,C)),R: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] :
      ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),M2),M9),R)
     => member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_In0(B,C,M2)),old_In0(B,C,M9)),old_dsum(B,C,R,S)) ) ).

% dsum_In0I
tff(fact_5962_dsum__In1I,axiom,
    ! [C: $tType,B: $tType,N5: set(old_node(B,C)),N10: set(old_node(B,C)),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),R: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] :
      ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),N5),N10),S)
     => member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_In1(B,C,N5)),old_In1(B,C,N10)),old_dsum(B,C,R,S)) ) ).

% dsum_In1I
tff(fact_5963_dprod__def,axiom,
    ! [C: $tType,B: $tType,R: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] : old_dprod(B,C,R,S) = aa(set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),complete_Sup_Sup(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),image2(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),fun(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),product_case_prod(set(old_node(B,C)),set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aTP_Lamp_xp(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),S))),R)) ).

% dprod_def
tff(fact_5964_dprodI,axiom,
    ! [C: $tType,B: $tType,M2: set(old_node(B,C)),M9: set(old_node(B,C)),R: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),N5: set(old_node(B,C)),N10: set(old_node(B,C)),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] :
      ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),M2),M9),R)
     => ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),N5),N10),S)
       => member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_Scons(B,C,M2,N5)),old_Scons(B,C,M9,N10)),old_dprod(B,C,R,S)) ) ) ).

% dprodI
tff(fact_5965_dprodE,axiom,
    ! [C: $tType,B: $tType,C2: product_prod(set(old_node(B,C)),set(old_node(B,C))),R: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),S: set(product_prod(set(old_node(B,C)),set(old_node(B,C))))] :
      ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),C2,old_dprod(B,C,R,S))
     => ~ ! [X3: set(old_node(B,C)),Y4: set(old_node(B,C)),X5: set(old_node(B,C))] :
            ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),X3),X5),R)
           => ! [Y11: set(old_node(B,C))] :
                ( member(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),Y4),Y11),S)
               => ( C2 != aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_Scons(B,C,X3,Y4)),old_Scons(B,C,X5,Y11)) ) ) ) ) ).

% dprodE
tff(fact_5966_prop__matchD,axiom,
    ! [B: $tType,Al: list(B),E2: B,Bl: list(B),Al2: list(B),E5: B,Bl2: list(B),P: fun(B,$o)] :
      ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),Bl)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E5),Bl2)) )
     => ( list_all(B,P,Al)
       => ( ~ aa(B,$o,P,E2)
         => ( ~ aa(B,$o,P,E5)
           => ( list_all(B,P,Bl)
             => ( ( Al = Al2 )
                & ( E2 = E5 )
                & ( Bl = Bl2 ) ) ) ) ) ) ) ).

% prop_matchD
tff(fact_5967_prop__match,axiom,
    ! [B: $tType,P: fun(B,$o),Al: list(B),E2: B,E5: B,Bl: list(B),Al2: list(B),Bl2: list(B)] :
      ( list_all(B,P,Al)
     => ( ~ aa(B,$o,P,E2)
       => ( ~ aa(B,$o,P,E5)
         => ( list_all(B,P,Bl)
           => ( ( aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E2),Bl)) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Al2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),E5),Bl2)) )
            <=> ( ( Al = Al2 )
                & ( E2 = E5 )
                & ( Bl = Bl2 ) ) ) ) ) ) ) ).

% prop_match
tff(fact_5968_Heap__lub__def,axiom,
    ! [B: $tType] : heap_Time_Heap_lub(B) = partial_img_lub(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(B),heap_Time_execute(B),heap_Time_Heap2(B),partial_fun_lub(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit),partial_flat_lub(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),none(product_prod(B,product_prod(heap_ext(product_unit),nat)))))) ).

% Heap_lub_def
tff(fact_5969_heap__step__admissible,axiom,
    ! [B: $tType,D: $tType,C: $tType,E: $tType,F4: $tType,P: fun(F4,fun(B,fun(D,fun(C,fun(E,$o))))),X2: F4] : comple1908693960933563346ssible(fun(B,option(product_prod(C,product_prod(D,E)))),partial_fun_lub(option(product_prod(C,product_prod(D,E))),option(product_prod(C,product_prod(D,E))),B,partial_flat_lub(option(product_prod(C,product_prod(D,E))),none(product_prod(C,product_prod(D,E))))),partial_fun_ord(option(product_prod(C,product_prod(D,E))),option(product_prod(C,product_prod(D,E))),B,partial_flat_ord(option(product_prod(C,product_prod(D,E))),none(product_prod(C,product_prod(D,E))))),aa(F4,fun(fun(B,option(product_prod(C,product_prod(D,E)))),$o),aTP_Lamp_xq(fun(F4,fun(B,fun(D,fun(C,fun(E,$o))))),fun(F4,fun(fun(B,option(product_prod(C,product_prod(D,E)))),$o)),P),X2)) ).

% heap_step_admissible
tff(fact_5970_option__admissible,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(C,$o))] : comple1908693960933563346ssible(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),aTP_Lamp_xr(fun(B,fun(C,$o)),fun(fun(B,option(C)),$o),P)) ).

% option_admissible
tff(fact_5971_option_Olub__upper,axiom,
    ! [B: $tType,A4: set(option(B)),X2: option(B)] :
      ( comple1602240252501008431_chain(option(B),partial_flat_ord(option(B),none(B)),A4)
     => ( member(option(B),X2,A4)
       => aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),X2),aa(set(option(B)),option(B),partial_flat_lub(option(B),none(B)),A4)) ) ) ).

% option.lub_upper
tff(fact_5972_option_Oleq__antisym,axiom,
    ! [B: $tType,X2: option(B),Y: option(B)] :
      ( aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),X2),Y)
     => ( aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),Y),X2)
       => ( X2 = Y ) ) ) ).

% option.leq_antisym
tff(fact_5973_option_Oleq__trans,axiom,
    ! [B: $tType,X2: option(B),Y: option(B),Z2: option(B)] :
      ( aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),X2),Y)
     => ( aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),Y),Z2)
       => aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),X2),Z2) ) ) ).

% option.leq_trans
tff(fact_5974_option_Oleq__refl,axiom,
    ! [B: $tType,X2: option(B)] : aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),X2),X2) ).

% option.leq_refl
tff(fact_5975_option_Olub__least,axiom,
    ! [B: $tType,A4: set(option(B)),Z2: option(B)] :
      ( comple1602240252501008431_chain(option(B),partial_flat_ord(option(B),none(B)),A4)
     => ( ! [X3: option(B)] :
            ( member(option(B),X3,A4)
           => aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),X3),Z2) )
       => aa(option(B),$o,aa(option(B),fun(option(B),$o),partial_flat_ord(option(B),none(B)),aa(set(option(B)),option(B),partial_flat_lub(option(B),none(B)),A4)),Z2) ) ) ).

% option.lub_least
tff(fact_5976_Heap__ord__def,axiom,
    ! [B: $tType] : heap_Time_Heap_ord(B) = partial_img_ord(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),$o,heap_Time_execute(B),partial_fun_ord(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit),partial_flat_ord(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),none(product_prod(B,product_prod(heap_ext(product_unit),nat)))))) ).

% Heap_ord_def
tff(fact_5977_Partial__Function_Obind__mono,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,B5: fun(fun(B,option(C)),option(D)),C5: fun(D,fun(fun(B,option(C)),option(E)))] :
      ( comple7038119648293358887notone(fun(B,option(C)),option(D),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(D),none(D)),B5)
     => ( ! [Y4: D] : comple7038119648293358887notone(fun(B,option(C)),option(E),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(E),none(E)),aa(D,fun(fun(B,option(C)),option(E)),C5,Y4))
       => comple7038119648293358887notone(fun(B,option(C)),option(E),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(E),none(E)),aa(fun(D,fun(fun(B,option(C)),option(E))),fun(fun(B,option(C)),option(E)),aTP_Lamp_xt(fun(fun(B,option(C)),option(D)),fun(fun(D,fun(fun(B,option(C)),option(E))),fun(fun(B,option(C)),option(E))),B5),C5)) ) ) ).

% Partial_Function.bind_mono
tff(fact_5978_option_Oconst__mono,axiom,
    ! [B: $tType,C: $tType,Ord: fun(B,fun(B,$o)),C2: option(C)] : comple7038119648293358887notone(B,option(C),Ord,partial_flat_ord(option(C),none(C)),aTP_Lamp_xu(option(C),fun(B,option(C)),C2)) ).

% option.const_mono
tff(fact_5979_option_Ofixp__induct__uc,axiom,
    ! [B: $tType,C: $tType,D: $tType,U3: fun(D,fun(B,option(C))),F5: fun(D,D),C5: fun(fun(B,option(C)),D),F: D,P: fun(fun(B,option(C)),$o)] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,option(C)),option(C),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(C),none(C)),aa(B,fun(fun(B,option(C)),option(C)),aa(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C)))),aTP_Lamp_xv(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))))),U3),F5),C5),X3))
     => ( ( F = aa(fun(B,option(C)),D,C5,comple187402453842119260l_fixp(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),aa(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C)))),aTP_Lamp_xw(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))))),U3),F5),C5))) )
       => ( ! [F3: fun(B,option(C))] : aa(D,fun(B,option(C)),U3,aa(fun(B,option(C)),D,C5,F3)) = F3
         => ( comple1908693960933563346ssible(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),P)
           => ( aa(fun(B,option(C)),$o,P,aTP_Lamp_hj(B,option(C)))
             => ( ! [F3: D] :
                    ( aa(fun(B,option(C)),$o,P,aa(D,fun(B,option(C)),U3,F3))
                   => aa(fun(B,option(C)),$o,P,aa(D,fun(B,option(C)),U3,aa(D,D,F5,F3))) )
               => aa(fun(B,option(C)),$o,P,aa(D,fun(B,option(C)),U3,F)) ) ) ) ) ) ) ).

% option.fixp_induct_uc
tff(fact_5980_fixp__induct__option,axiom,
    ! [D: $tType,B: $tType,C: $tType,U3: fun(D,fun(B,option(C))),F5: fun(D,D),C5: fun(fun(B,option(C)),D),F: D,P: fun(B,fun(C,$o)),X2: B,Y: C] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,option(C)),option(C),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(C),none(C)),aa(B,fun(fun(B,option(C)),option(C)),aa(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C)))),aTP_Lamp_xv(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))))),U3),F5),C5),X3))
     => ( ( F = aa(fun(B,option(C)),D,C5,comple187402453842119260l_fixp(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),aa(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C)))),aTP_Lamp_xw(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))))),U3),F5),C5))) )
       => ( ! [F3: fun(B,option(C))] : aa(D,fun(B,option(C)),U3,aa(fun(B,option(C)),D,C5,F3)) = F3
         => ( ! [F3: D,X3: B,Y4: C] :
                ( ! [Xa3: B,Ya3: C] :
                    ( ( aa(B,option(C),aa(D,fun(B,option(C)),U3,F3),Xa3) = aa(C,option(C),some(C),Ya3) )
                   => aa(C,$o,aa(B,fun(C,$o),P,Xa3),Ya3) )
               => ( ( aa(B,option(C),aa(D,fun(B,option(C)),U3,aa(D,D,F5,F3)),X3) = aa(C,option(C),some(C),Y4) )
                 => aa(C,$o,aa(B,fun(C,$o),P,X3),Y4) ) )
           => ( ( aa(B,option(C),aa(D,fun(B,option(C)),U3,F),X2) = aa(C,option(C),some(C),Y) )
             => aa(C,$o,aa(B,fun(C,$o),P,X2),Y) ) ) ) ) ) ).

% fixp_induct_option
tff(fact_5981_option_Ofixp__rule__uc,axiom,
    ! [B: $tType,C: $tType,D: $tType,U3: fun(D,fun(B,option(C))),F5: fun(D,D),C5: fun(fun(B,option(C)),D),F: D] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,option(C)),option(C),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(C),none(C)),aa(B,fun(fun(B,option(C)),option(C)),aa(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C)))),aTP_Lamp_xv(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))))),U3),F5),C5),X3))
     => ( ( F = aa(fun(B,option(C)),D,C5,comple187402453842119260l_fixp(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),aa(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C)))),aTP_Lamp_xw(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))))),U3),F5),C5))) )
       => ( ! [F3: D] : aa(fun(B,option(C)),D,C5,aa(D,fun(B,option(C)),U3,F3)) = F3
         => ( F = aa(D,D,F5,F) ) ) ) ) ).

% option.fixp_rule_uc
tff(fact_5982_option_Omono__body__fixp,axiom,
    ! [C: $tType,B: $tType,F5: fun(fun(B,option(C)),fun(B,option(C)))] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,option(C)),option(C),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),partial_flat_ord(option(C),none(C)),aa(B,fun(fun(B,option(C)),option(C)),aTP_Lamp_xx(fun(fun(B,option(C)),fun(B,option(C))),fun(B,fun(fun(B,option(C)),option(C))),F5),X3))
     => ( comple187402453842119260l_fixp(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),F5) = aa(fun(B,option(C)),fun(B,option(C)),F5,comple187402453842119260l_fixp(fun(B,option(C)),partial_fun_lub(option(C),option(C),B,partial_flat_lub(option(C),none(C))),partial_fun_ord(option(C),option(C),B,partial_flat_ord(option(C),none(C))),F5)) ) ) ).

% option.mono_body_fixp
tff(fact_5983_option_Opartial__function__definitions__axioms,axiom,
    ! [B: $tType] : partia7178651479351089652itions(option(B),partial_flat_ord(option(B),none(B)),partial_flat_lub(option(B),none(B))) ).

% option.partial_function_definitions_axioms
tff(fact_5984_fixp__mono,axiom,
    ! [B: $tType] :
      ( comple9053668089753744459l_ccpo(B)
     => ! [F: fun(B,B),G: fun(B,B)] :
          ( comple7038119648293358887notone(B,B,ord_less_eq(B),ord_less_eq(B),F)
         => ( comple7038119648293358887notone(B,B,ord_less_eq(B),ord_less_eq(B),G)
           => ( ! [Z9: B] : aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(B,B,F,Z9)),aa(B,B,G,Z9))
             => aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),comple115746919287870866o_fixp(B,F)),comple115746919287870866o_fixp(B,G)) ) ) ) ) ).

% fixp_mono
tff(fact_5985_heap_Oconst__mono,axiom,
    ! [B: $tType,C: $tType,Ord: fun(B,fun(B,$o)),C2: heap_Time_Heap(C)] : comple7038119648293358887notone(B,heap_Time_Heap(C),Ord,heap_Time_Heap_ord(C),aTP_Lamp_xy(heap_Time_Heap(C),fun(B,heap_Time_Heap(C)),C2)) ).

% heap.const_mono
tff(fact_5986_Heap__Time__Monad_Obind__mono,axiom,
    ! [E: $tType,C: $tType,B: $tType,D: $tType,B5: fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(D)),C5: fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E)))] :
      ( comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(D),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(D),B5)
     => ( ! [Y4: D] : comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(E),aa(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E)),C5,Y4))
       => comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(E),aa(fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E)),aTP_Lamp_ya(fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(D)),fun(fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),B5),C5)) ) ) ).

% Heap_Time_Monad.bind_mono
tff(fact_5987_fixp__induct__heap,axiom,
    ! [D: $tType,C: $tType,B: $tType,U3: fun(D,fun(B,heap_Time_Heap(C))),F5: fun(D,D),C5: fun(fun(B,heap_Time_Heap(C)),D),F: D,P: fun(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))))),X2: B,Ha: heap_ext(product_unit),H2: heap_ext(product_unit),R: C,N: nat] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(C),aa(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)))),aTP_Lamp_yb(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))))),U3),F5),C5),X3))
     => ( ( F = aa(fun(B,heap_Time_Heap(C)),D,C5,comple187402453842119260l_fixp(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)))),aTP_Lamp_yc(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))))),U3),F5),C5))) )
       => ( ! [F3: fun(B,heap_Time_Heap(C))] : aa(D,fun(B,heap_Time_Heap(C)),U3,aa(fun(B,heap_Time_Heap(C)),D,C5,F3)) = F3
         => ( ! [F3: D,X3: B,H: heap_ext(product_unit),H4: heap_ext(product_unit),R2: C,N3: nat] :
                ( ! [Xa3: B,Ha2: heap_ext(product_unit),H_a: heap_ext(product_unit),Ra3: C,Na: nat] :
                    ( heap_Time_effect(C,aa(B,heap_Time_Heap(C),aa(D,fun(B,heap_Time_Heap(C)),U3,F3),Xa3),Ha2,H_a,Ra3,Na)
                   => aa(nat,$o,aa(C,fun(nat,$o),aa(heap_ext(product_unit),fun(C,fun(nat,$o)),aa(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))),aa(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o)))),P,Xa3),Ha2),H_a),Ra3),Na) )
               => ( heap_Time_effect(C,aa(B,heap_Time_Heap(C),aa(D,fun(B,heap_Time_Heap(C)),U3,aa(D,D,F5,F3)),X3),H,H4,R2,N3)
                 => aa(nat,$o,aa(C,fun(nat,$o),aa(heap_ext(product_unit),fun(C,fun(nat,$o)),aa(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))),aa(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o)))),P,X3),H),H4),R2),N3) ) )
           => ( heap_Time_effect(C,aa(B,heap_Time_Heap(C),aa(D,fun(B,heap_Time_Heap(C)),U3,F),X2),Ha,H2,R,N)
             => aa(nat,$o,aa(C,fun(nat,$o),aa(heap_ext(product_unit),fun(C,fun(nat,$o)),aa(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))),aa(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o)))),P,X2),Ha),H2),R),N) ) ) ) ) ) ).

% fixp_induct_heap
tff(fact_5988_refines__adm,axiom,
    ! [C: $tType,B: $tType,T2: fun(B,heap_Time_Heap(C))] : comple1908693960933563346ssible(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),aTP_Lamp_yd(fun(B,heap_Time_Heap(C)),fun(fun(B,heap_Time_Heap(C)),$o),T2)) ).

% refines_adm
tff(fact_5989_heap_Ofixp__induct__uc,axiom,
    ! [B: $tType,C: $tType,D: $tType,U3: fun(D,fun(B,heap_Time_Heap(C))),F5: fun(D,D),C5: fun(fun(B,heap_Time_Heap(C)),D),F: D,P: fun(fun(B,heap_Time_Heap(C)),$o)] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(C),aa(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)))),aTP_Lamp_yb(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))))),U3),F5),C5),X3))
     => ( ( F = aa(fun(B,heap_Time_Heap(C)),D,C5,comple187402453842119260l_fixp(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)))),aTP_Lamp_yc(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))))),U3),F5),C5))) )
       => ( ! [F3: fun(B,heap_Time_Heap(C))] : aa(D,fun(B,heap_Time_Heap(C)),U3,aa(fun(B,heap_Time_Heap(C)),D,C5,F3)) = F3
         => ( comple1908693960933563346ssible(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),P)
           => ( aa(fun(B,heap_Time_Heap(C)),$o,P,aTP_Lamp_yf(B,heap_Time_Heap(C)))
             => ( ! [F3: D] :
                    ( aa(fun(B,heap_Time_Heap(C)),$o,P,aa(D,fun(B,heap_Time_Heap(C)),U3,F3))
                   => aa(fun(B,heap_Time_Heap(C)),$o,P,aa(D,fun(B,heap_Time_Heap(C)),U3,aa(D,D,F5,F3))) )
               => aa(fun(B,heap_Time_Heap(C)),$o,P,aa(D,fun(B,heap_Time_Heap(C)),U3,F)) ) ) ) ) ) ) ).

% heap.fixp_induct_uc
tff(fact_5990_heap_Omono__body__fixp,axiom,
    ! [C: $tType,B: $tType,F5: fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)))] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(C),aa(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)),aTP_Lamp_yg(fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))),F5),X3))
     => ( comple187402453842119260l_fixp(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),F5) = aa(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)),F5,comple187402453842119260l_fixp(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),F5)) ) ) ).

% heap.mono_body_fixp
tff(fact_5991_heap_Ofixp__rule__uc,axiom,
    ! [B: $tType,C: $tType,D: $tType,U3: fun(D,fun(B,heap_Time_Heap(C))),F5: fun(D,D),C5: fun(fun(B,heap_Time_Heap(C)),D),F: D] :
      ( ! [X3: B] : comple7038119648293358887notone(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),heap_Time_Heap_ord(C),aa(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)))),aTP_Lamp_yb(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))))),U3),F5),C5),X3))
     => ( ( F = aa(fun(B,heap_Time_Heap(C)),D,C5,comple187402453842119260l_fixp(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)))),aTP_Lamp_yc(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))))),U3),F5),C5))) )
       => ( ! [F3: D] : aa(fun(B,heap_Time_Heap(C)),D,C5,aa(D,fun(B,heap_Time_Heap(C)),U3,F3)) = F3
         => ( F = aa(D,D,F5,F) ) ) ) ) ).

% heap.fixp_rule_uc
tff(fact_5992_admissible__heap,axiom,
    ! [C: $tType,B: $tType,P: fun(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o)))))] : comple1908693960933563346ssible(fun(B,heap_Time_Heap(C)),partial_fun_lub(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_lub(C)),partial_fun_ord(heap_Time_Heap(C),heap_Time_Heap(C),B,heap_Time_Heap_ord(C)),aTP_Lamp_yh(fun(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))))),fun(fun(B,heap_Time_Heap(C)),$o),P)) ).

% admissible_heap
tff(fact_5993_ATP_Olambda__1,axiom,
    ! [Uu: product_prod(int,int)] :
      aa(product_prod(int,int),product_prod(int,int),aTP_Lamp_kk(product_prod(int,int),product_prod(int,int)),Uu) = $ite(aa(product_prod(int,int),int,product_fst(int,int),Uu) = zero_zero(int),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(product_prod(int,int),int,product_snd(int,int),Uu)),aa(product_prod(int,int),int,product_fst(int,int),Uu))) ).

% ATP.lambda_1
tff(fact_5994_ATP_Olambda__2,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat] : aa(nat,set(old_node(B,product_unit)),aTP_Lamp_xl(nat,set(old_node(B,product_unit))),Uu) = aa(sum_sum(nat,nat),set(old_node(B,product_unit)),sum_case_sum(nat,set(old_node(B,product_unit)),nat,aTP_Lamp_xi(nat,set(old_node(B,product_unit))),aTP_Lamp_xk(nat,set(old_node(B,product_unit)))),nat_sum_decode(Uu)) ) ).

% ATP.lambda_2
tff(fact_5995_ATP_Olambda__3,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat] : aa(nat,set(old_node(B,product_unit)),aTP_Lamp_xh(nat,set(old_node(B,product_unit))),Uu) = aa(sum_sum(nat,nat),set(old_node(B,product_unit)),sum_case_sum(nat,set(old_node(B,product_unit)),nat,aTP_Lamp_xf(nat,set(old_node(B,product_unit))),aTP_Lamp_xg(nat,set(old_node(B,product_unit)))),nat_sum_decode(Uu)) ) ).

% ATP.lambda_3
tff(fact_5996_ATP_Olambda__4,axiom,
    ! [B: $tType,Uu: set(set(B))] : aa(set(set(B)),int,aTP_Lamp_io(set(set(B)),int),Uu) = aa(int,int,aa(int,fun(int,int),times_times(int),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(int,int,uminus_uminus(int),one_one(int))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),finite_card(set(B),Uu)),one_one(nat)))),aa(nat,int,semiring_1_of_nat(int),finite_card(B,complete_Inf_Inf(set(B),Uu)))) ).

% ATP.lambda_4
tff(fact_5997_ATP_Olambda__5,axiom,
    ! [B: $tType,Uu: B] : aa(B,set(product_prod(B,B)),aTP_Lamp_kl(B,set(product_prod(B,B))),Uu) = aa(set(product_prod(B,B)),set(product_prod(B,B)),insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uu),Uu)),bot_bot(set(product_prod(B,B)))) ).

% ATP.lambda_5
tff(fact_5998_ATP_Olambda__6,axiom,
    ! [Uu: product_prod(int,int)] : aa(product_prod(int,int),product_prod(int,int),aTP_Lamp_kn(product_prod(int,int),product_prod(int,int)),Uu) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),aa(product_prod(int,int),int,product_fst(int,int),Uu))),aa(product_prod(int,int),int,product_snd(int,int),Uu)) ).

% ATP.lambda_6
tff(fact_5999_ATP_Olambda__7,axiom,
    ! [B: $tType,Uu: list(B)] : aa(list(B),product_prod(nat,list(B)),aTP_Lamp_pr(list(B),product_prod(nat,list(B))),Uu) = aa(list(B),product_prod(nat,list(B)),aa(nat,fun(list(B),product_prod(nat,list(B))),product_Pair(nat,list(B)),aa(list(B),nat,size_size(list(B)),Uu)),Uu) ).

% ATP.lambda_7
tff(fact_6000_ATP_Olambda__8,axiom,
    ! [Uu: nat] : aa(nat,nat,aTP_Lamp_bv(nat,nat),Uu) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uu),aa(nat,nat,suc,zero_zero(nat))) ).

% ATP.lambda_8
tff(fact_6001_ATP_Olambda__9,axiom,
    ! [Uu: int] : aa(int,int,aTP_Lamp_hf(int,int),Uu) = aa(int,int,aa(int,fun(int,int),plus_plus(int),Uu),Uu) ).

% ATP.lambda_9
tff(fact_6002_ATP_Olambda__10,axiom,
    ! [C: $tType,Uu: C] : aa(C,product_prod(C,C),aTP_Lamp_jf(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_10
tff(fact_6003_ATP_Olambda__11,axiom,
    ! [B: $tType,Uu: B] : aa(B,product_prod(B,B),aTP_Lamp_je(B,product_prod(B,B)),Uu) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uu),Uu) ).

% ATP.lambda_11
tff(fact_6004_ATP_Olambda__12,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [Uu: B] : aa(B,B,aTP_Lamp_di(B,B),Uu) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),one_one(B)) ) ).

% ATP.lambda_12
tff(fact_6005_ATP_Olambda__13,axiom,
    ! [B: $tType] :
      ( semiring_Gcd(B)
     => ! [Uu: B] :
          ( aa(B,$o,aTP_Lamp_ut(B,$o),Uu)
        <=> dvd_dvd(B,Uu,one_one(B)) ) ) ).

% ATP.lambda_13
tff(fact_6006_ATP_Olambda__14,axiom,
    ! [Uu: nat] : aa(nat,product_prod(nat,nat),aTP_Lamp_ki(nat,product_prod(nat,nat)),Uu) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),Uu),zero_zero(nat)) ).

% ATP.lambda_14
tff(fact_6007_ATP_Olambda__15,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: B] : aa(B,list(B),aTP_Lamp_pw(B,list(B)),Uu) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uu),nil(B)) ) ).

% ATP.lambda_15
tff(fact_6008_ATP_Olambda__16,axiom,
    ! [B: $tType,Uu: B] : aa(B,set(B),aTP_Lamp_nj(B,set(B)),Uu) = aa(set(B),set(B),insert2(B,Uu),bot_bot(set(B))) ).

% ATP.lambda_16
tff(fact_6009_ATP_Olambda__17,axiom,
    ! [C: $tType,Uu: option(C)] :
      ( aa(option(C),$o,aTP_Lamp_ue(option(C),$o),Uu)
    <=> ( Uu = none(C) ) ) ).

% ATP.lambda_17
tff(fact_6010_ATP_Olambda__18,axiom,
    ! [B: $tType,Uu: option(B)] :
      ( aa(option(B),$o,aTP_Lamp_ud(option(B),$o),Uu)
    <=> ( Uu = none(B) ) ) ).

% ATP.lambda_18
tff(fact_6011_ATP_Olambda__19,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat] : aa(nat,set(old_node(B,product_unit)),aTP_Lamp_xk(nat,set(old_node(B,product_unit))),Uu) = aa(product_prod(nat,nat),set(old_node(B,product_unit)),aa(fun(nat,fun(nat,set(old_node(B,product_unit)))),fun(product_prod(nat,nat),set(old_node(B,product_unit))),product_case_prod(nat,nat,set(old_node(B,product_unit))),aTP_Lamp_xj(nat,fun(nat,set(old_node(B,product_unit))))),nat_prod_decode(Uu)) ) ).

% ATP.lambda_19
tff(fact_6012_ATP_Olambda__20,axiom,
    ! [Uu: code_natural] : aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),aTP_Lamp_sf(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)))),Uu) = product_scomp(product_prod(code_natural,code_natural),code_natural,product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),next,aTP_Lamp_se(code_natural,fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)))),Uu)) ).

% ATP.lambda_20
tff(fact_6013_ATP_Olambda__21,axiom,
    ! [B: $tType,Uu: B] : aa(B,fun(set(product_prod(B,B)),set(product_prod(B,B))),aTP_Lamp_la(B,fun(set(product_prod(B,B)),set(product_prod(B,B)))),Uu) = insert2(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uu),Uu)) ).

% ATP.lambda_21
tff(fact_6014_ATP_Olambda__22,axiom,
    ! [C: $tType,Uu: option(C)] :
      ( aa(option(C),$o,aTP_Lamp_uc(option(C),$o),Uu)
    <=> ( Uu != none(C) ) ) ).

% ATP.lambda_22
tff(fact_6015_ATP_Olambda__23,axiom,
    ! [B: $tType,Uu: option(B)] :
      ( aa(option(B),$o,aTP_Lamp_ub(option(B),$o),Uu)
    <=> ( Uu != none(B) ) ) ).

% ATP.lambda_23
tff(fact_6016_ATP_Olambda__24,axiom,
    ! [B: $tType,Uu: list(B)] :
      ( aa(list(B),$o,aTP_Lamp_pn(list(B),$o),Uu)
    <=> ( Uu != nil(B) ) ) ).

% ATP.lambda_24
tff(fact_6017_ATP_Olambda__25,axiom,
    ! [B: $tType,Uu: option(product_prod(B,product_prod(heap_ext(product_unit),nat)))] : aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(B),aTP_Lamp_vj(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(B)),Uu) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(set(B)),image2(product_prod(B,product_prod(heap_ext(product_unit),nat)),set(B),basic_fsts(B,product_prod(heap_ext(product_unit),nat))),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),set(product_prod(B,product_prod(heap_ext(product_unit),nat))),set_option(product_prod(B,product_prod(heap_ext(product_unit),nat))),Uu))) ).

% ATP.lambda_25
tff(fact_6018_ATP_Olambda__26,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,option(C))] : aa(fun(B,option(C)),fun(product_prod(B,C),fun(B,option(C))),aTP_Lamp_qp(fun(B,option(C)),fun(product_prod(B,C),fun(B,option(C)))),Uu) = aa(fun(B,fun(C,fun(B,option(C)))),fun(product_prod(B,C),fun(B,option(C))),product_case_prod(B,C,fun(B,option(C))),aTP_Lamp_qo(fun(B,option(C)),fun(B,fun(C,fun(B,option(C)))),Uu)) ).

% ATP.lambda_26
tff(fact_6019_ATP_Olambda__27,axiom,
    ! [B: $tType,D: $tType,C: $tType,Uu: C] : aa(C,fun(product_prod(B,D),product_prod(B,product_prod(C,D))),aTP_Lamp_qm(C,fun(product_prod(B,D),product_prod(B,product_prod(C,D)))),Uu) = aa(fun(B,fun(D,product_prod(B,product_prod(C,D)))),fun(product_prod(B,D),product_prod(B,product_prod(C,D))),product_case_prod(B,D,product_prod(B,product_prod(C,D))),aTP_Lamp_ql(C,fun(B,fun(D,product_prod(B,product_prod(C,D)))),Uu)) ).

% ATP.lambda_27
tff(fact_6020_ATP_Olambda__28,axiom,
    ! [B: $tType,Uu: B] : aa(B,fun(product_prod(heap_ext(product_unit),nat),B),aTP_Lamp_dm(B,fun(product_prod(heap_ext(product_unit),nat),B)),Uu) = aa(fun(heap_ext(product_unit),fun(nat,B)),fun(product_prod(heap_ext(product_unit),nat),B),product_case_prod(heap_ext(product_unit),nat,B),aTP_Lamp_dl(B,fun(heap_ext(product_unit),fun(nat,B)),Uu)) ).

% ATP.lambda_28
tff(fact_6021_ATP_Olambda__29,axiom,
    ! [B: $tType,Uu: fun(B,nat)] :
      ( aa(fun(B,nat),$o,aTP_Lamp_ts(fun(B,nat),$o),Uu)
    <=> finite_finite2(B,aa(fun(B,$o),set(B),collect(B),aTP_Lamp_tr(fun(B,nat),fun(B,$o),Uu))) ) ).

% ATP.lambda_29
tff(fact_6022_ATP_Olambda__30,axiom,
    ! [B: $tType] :
      ( semiring_1(B)
     => ! [Uu: nat] : aa(nat,heap_Time_Heap(B),aTP_Lamp_ry(nat,heap_Time_Heap(B)),Uu) = aa(B,heap_Time_Heap(B),heap_Time_ureturn(B),aa(nat,B,semiring_1_of_nat(B),Uu)) ) ).

% ATP.lambda_30
tff(fact_6023_ATP_Olambda__31,axiom,
    ! [Uu: num] : aa(num,option(num),aTP_Lamp_dy(num,option(num)),Uu) = aa(num,option(num),some(num),aa(num,num,bit1,Uu)) ).

% ATP.lambda_31
tff(fact_6024_ATP_Olambda__32,axiom,
    ! [Uu: num] : aa(num,option(num),aTP_Lamp_dk(num,option(num)),Uu) = aa(num,option(num),some(num),aa(num,num,bit0,Uu)) ).

% ATP.lambda_32
tff(fact_6025_ATP_Olambda__33,axiom,
    ! [Uu: int] : aa(int,fun(int,product_prod(int,int)),aTP_Lamp_gv(int,fun(int,product_prod(int,int))),Uu) = aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,uminus_uminus(int),Uu)) ).

% ATP.lambda_33
tff(fact_6026_ATP_Olambda__34,axiom,
    ! [Uu: int] : aa(int,fun(int,product_prod(int,int)),aTP_Lamp_gw(int,fun(int,product_prod(int,int))),Uu) = aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,abs_abs(int),Uu)) ).

% ATP.lambda_34
tff(fact_6027_ATP_Olambda__35,axiom,
    ! [Uu: nat] : aa(nat,fun(nat,product_prod(nat,nat)),aTP_Lamp_bk(nat,fun(nat,product_prod(nat,nat))),Uu) = aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,suc,Uu)) ).

% ATP.lambda_35
tff(fact_6028_ATP_Olambda__36,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat] : aa(nat,set(old_node(B,product_unit)),aTP_Lamp_xi(nat,set(old_node(B,product_unit))),Uu) = old_Leaf(B,product_unit,aa(nat,B,from_nat(B),Uu)) ) ).

% ATP.lambda_36
tff(fact_6029_ATP_Olambda__37,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat] : aa(nat,set(old_node(B,product_unit)),aTP_Lamp_xg(nat,set(old_node(B,product_unit))),Uu) = old_In1(B,product_unit,nth_item(B,Uu)) ) ).

% ATP.lambda_37
tff(fact_6030_ATP_Olambda__38,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat] : aa(nat,set(old_node(B,product_unit)),aTP_Lamp_xf(nat,set(old_node(B,product_unit))),Uu) = old_In0(B,product_unit,nth_item(B,Uu)) ) ).

% ATP.lambda_38
tff(fact_6031_ATP_Olambda__39,axiom,
    ! [B: $tType,Uu: product_prod(B,B)] :
      ( aa(product_prod(B,B),$o,aTP_Lamp_mg(product_prod(B,B),$o),Uu)
    <=> ? [X4: B] : Uu = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),X4) ) ).

% ATP.lambda_39
tff(fact_6032_ATP_Olambda__40,axiom,
    ! [B: $tType,C: $tType,Uu: product_prod(product_prod($o,B),product_prod($o,C))] :
      ( aa(product_prod(product_prod($o,B),product_prod($o,C)),$o,aTP_Lamp_ly(product_prod(product_prod($o,B),product_prod($o,C)),$o),Uu)
    <=> ? [X4: B,Y3: C] : Uu = aa(product_prod($o,C),product_prod(product_prod($o,B),product_prod($o,C)),aa(product_prod($o,B),fun(product_prod($o,C),product_prod(product_prod($o,B),product_prod($o,C))),product_Pair(product_prod($o,B),product_prod($o,C)),aa(B,product_prod($o,B),aa($o,fun(B,product_prod($o,B)),product_Pair($o,B),$true),X4)),aa(C,product_prod($o,C),aa($o,fun(C,product_prod($o,C)),product_Pair($o,C),$false),Y3)) ) ).

% ATP.lambda_40
tff(fact_6033_ATP_Olambda__41,axiom,
    ! [C: $tType,B: $tType,Uu: product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat))] :
      ( aa(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),$o,aTP_Lamp_xc(product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),$o),Uu)
    <=> ? [F6: fun(nat,sum_sum(B,nat)),X4: sum_sum(C,nat),K4: nat] :
          ( ( Uu = aa(sum_sum(C,nat),product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),aa(fun(nat,sum_sum(B,nat)),fun(sum_sum(C,nat),product_prod(fun(nat,sum_sum(B,nat)),sum_sum(C,nat))),product_Pair(fun(nat,sum_sum(B,nat)),sum_sum(C,nat)),F6),X4) )
          & ( aa(nat,sum_sum(B,nat),F6,K4) = aa(nat,sum_sum(B,nat),sum_Inr(nat,B),zero_zero(nat)) ) ) ) ).

% ATP.lambda_41
tff(fact_6034_ATP_Olambda__42,axiom,
    ! [B: $tType,Uu: B] : aa(B,fun(product_prod(heap_ext(product_unit),nat),nat),aTP_Lamp_fk(B,fun(product_prod(heap_ext(product_unit),nat),nat)),Uu) = aa(fun(heap_ext(product_unit),fun(nat,nat)),fun(product_prod(heap_ext(product_unit),nat),nat),product_case_prod(heap_ext(product_unit),nat,nat),aTP_Lamp_fj(heap_ext(product_unit),fun(nat,nat))) ).

% ATP.lambda_42
tff(fact_6035_ATP_Olambda__43,axiom,
    ! [B: $tType,Uu: B] : aa(B,fun(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit)),aTP_Lamp_dq(B,fun(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit))),Uu) = aa(fun(heap_ext(product_unit),fun(nat,heap_ext(product_unit))),fun(product_prod(heap_ext(product_unit),nat),heap_ext(product_unit)),product_case_prod(heap_ext(product_unit),nat,heap_ext(product_unit)),aTP_Lamp_dp(heap_ext(product_unit),fun(nat,heap_ext(product_unit)))) ).

% ATP.lambda_43
tff(fact_6036_ATP_Olambda__44,axiom,
    ! [B: $tType,C: $tType,Uu: B] : aa(B,heap_Time_Heap(C),aTP_Lamp_yf(B,heap_Time_Heap(C)),Uu) = aa(fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_Heap(C),heap_Time_Heap2(C),aTP_Lamp_ye(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))))) ).

% ATP.lambda_44
tff(fact_6037_ATP_Olambda__45,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B)] : aa(array(B),heap_Time_Heap(product_unit),aTP_Lamp_rw(array(B),heap_Time_Heap(product_unit)),Uu) = aa(product_unit,heap_Time_Heap(product_unit),heap_Time_ureturn(product_unit),product_Unity) ) ).

% ATP.lambda_45
tff(fact_6038_ATP_Olambda__46,axiom,
    ! [C: $tType,Uu: nat] : aa(nat,sum_sum(C,nat),aTP_Lamp_xe(nat,sum_sum(C,nat)),Uu) = aa(nat,sum_sum(C,nat),sum_Inr(nat,C),zero_zero(nat)) ).

% ATP.lambda_46
tff(fact_6039_ATP_Olambda__47,axiom,
    ! [B: $tType,Uu: nat] : aa(nat,sum_sum(B,nat),aTP_Lamp_xd(nat,sum_sum(B,nat)),Uu) = aa(nat,sum_sum(B,nat),sum_Inr(nat,B),zero_zero(nat)) ).

% ATP.lambda_47
tff(fact_6040_ATP_Olambda__48,axiom,
    ! [Uu: num,Uua: nat] : aa(nat,option(num),aTP_Lamp_gh(num,fun(nat,option(num)),Uu),Uua) = case_num(option(num),aa(num,option(num),some(num),one2),aTP_Lamp_gf(nat,fun(num,option(num)),Uua),aTP_Lamp_gg(nat,fun(num,option(num)),Uua),Uu) ).

% ATP.lambda_48
tff(fact_6041_ATP_Olambda__49,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: product_prod(B,D),Uua: product_prod(D,C)] :
      aa(product_prod(D,C),list(product_prod(B,C)),aTP_Lamp_pl(product_prod(B,D),fun(product_prod(D,C),list(product_prod(B,C))),Uu),Uua) = $ite(aa(product_prod(B,D),D,product_snd(B,D),Uu) = aa(product_prod(D,C),D,product_fst(D,C),Uua),aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(product_prod(B,D),B,product_fst(B,D),Uu)),aa(product_prod(D,C),C,product_snd(D,C),Uua))),nil(product_prod(B,C))),nil(product_prod(B,C))) ).

% ATP.lambda_49
tff(fact_6042_ATP_Olambda__50,axiom,
    ! [B: $tType,Uu: list(B),Uua: nat] :
      aa(nat,option(B),aTP_Lamp_oz(list(B),fun(nat,option(B)),Uu),Uua) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uua),aa(list(B),nat,size_size(list(B)),Uu)),aa(B,option(B),some(B),aa(nat,B,nth(B,Uu),Uua)),none(B)) ).

% ATP.lambda_50
tff(fact_6043_ATP_Olambda__51,axiom,
    ! [Uu: int,Uua: int] :
      aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_he(int,fun(int,product_prod(int,int))),Uu),Uua) = $ite(Uu = zero_zero(int),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(int,int,sgn_sgn(int),Uu)),Uua)),aa(int,int,abs_abs(int),Uu))) ).

% ATP.lambda_51
tff(fact_6044_ATP_Olambda__52,axiom,
    ! [Uu: int,Uua: int] :
      aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_kx(int,fun(int,product_prod(int,int))),Uu),Uua) = $ite(Uua = zero_zero(int),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),zero_zero(int)),one_one(int)),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),Uu),Uua)) ).

% ATP.lambda_52
tff(fact_6045_ATP_Olambda__53,axiom,
    ! [B: $tType] :
      ( inf(B)
     => ! [Uu: option(B),Uua: B] : aa(B,option(B),aTP_Lamp_ms(option(B),fun(B,option(B)),Uu),Uua) = aa(option(B),option(B),aa(fun(B,option(B)),fun(option(B),option(B)),aa(option(B),fun(fun(B,option(B)),fun(option(B),option(B))),case_option(option(B),B),none(B)),aTP_Lamp_mr(B,fun(B,option(B)),Uua)),Uu) ) ).

% ATP.lambda_53
tff(fact_6046_ATP_Olambda__54,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [Uu: option(B),Uua: B] :
          ( aa(B,$o,aTP_Lamp_al(option(B),fun(B,$o),Uu),Uua)
        <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),$true),aTP_Lamp_ak(B,fun(B,$o),Uua)),Uu) ) ) ).

% ATP.lambda_54
tff(fact_6047_ATP_Olambda__55,axiom,
    ! [Uu: nat,Uua: num] : aa(num,option(num),aa(nat,fun(num,option(num)),aTP_Lamp_gi(nat,fun(num,option(num))),Uu),Uua) = case_nat(option(num),none(num),aTP_Lamp_gh(num,fun(nat,option(num)),Uua),Uu) ).

% ATP.lambda_55
tff(fact_6048_ATP_Olambda__56,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [Uu: option(B),Uua: B] :
          ( aa(B,$o,aTP_Lamp_bh(option(B),fun(B,$o),Uu),Uua)
        <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),$false),aa(B,fun(B,$o),ord_less_eq(B),Uua)),Uu) ) ) ).

% ATP.lambda_56
tff(fact_6049_ATP_Olambda__57,axiom,
    ! [Uu: nat,Uua: num] : aa(num,option(num),aTP_Lamp_gf(nat,fun(num,option(num)),Uu),Uua) = aa(option(num),option(num),aa(fun(num,option(num)),fun(option(num),option(num)),aa(option(num),fun(fun(num,option(num)),fun(option(num),option(num))),case_option(option(num),num),none(num)),aTP_Lamp_dk(num,option(num))),bit_take_bit_num(Uu,Uua)) ).

% ATP.lambda_57
tff(fact_6050_ATP_Olambda__58,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,fun(C,$o)),Uua: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aTP_Lamp_nm(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),Uu),Uua)
    <=> aa(C,$o,aa(B,fun(C,$o),Uu,aa(product_prod(B,C),B,product_fst(B,C),Uua)),aa(product_prod(B,C),C,product_snd(B,C),Uua)) ) ).

% ATP.lambda_58
tff(fact_6051_ATP_Olambda__59,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat] : aa(nat,B,aTP_Lamp_gk(fun(nat,fun(nat,B)),fun(nat,B),Uu),Uua) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_gj(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua)),aa(nat,set(nat),set_ord_atMost(nat),Uua)) ) ).

% ATP.lambda_59
tff(fact_6052_ATP_Olambda__60,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat] : aa(nat,B,aTP_Lamp_du(fun(nat,fun(nat,B)),fun(nat,B),Uu),Uua) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_dt(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua)),aa(nat,set(nat),set_ord_atMost(nat),Uua)) ) ).

% ATP.lambda_60
tff(fact_6053_ATP_Olambda__61,axiom,
    ! [Uu: product_prod(int,int),Uua: product_prod(int,int)] : aa(product_prod(int,int),product_prod(int,int),aa(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)),aTP_Lamp_kj(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),Uu),Uua) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),Uu)),aa(product_prod(int,int),int,product_snd(int,int),Uua))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),Uua)),aa(product_prod(int,int),int,product_snd(int,int),Uu)))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),Uu)),aa(product_prod(int,int),int,product_snd(int,int),Uua))) ).

% ATP.lambda_61
tff(fact_6054_ATP_Olambda__62,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [Uu: nat,Uua: nat] : aa(nat,B,aTP_Lamp_ey(nat,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),Uua)),aa(nat,B,semiring_1_of_nat(B),Uua))),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,binomial(Uu),Uua))) ) ).

% ATP.lambda_62
tff(fact_6055_ATP_Olambda__63,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: nat,Uua: nat] : aa(nat,B,aTP_Lamp_ef(nat,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(nat,B,gbinomial(B,aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uua))),Uua)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Uua)) ) ).

% ATP.lambda_63
tff(fact_6056_ATP_Olambda__64,axiom,
    ! [Uu: code_integer,Uua: code_integer] :
      aa(code_integer,int,aa(code_integer,fun(code_integer,int),aTP_Lamp_fh(code_integer,fun(code_integer,int)),Uu),Uua) = $let(
        l2: int,
        l2:= aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(code_integer,int,code_int_of_integer,Uu)),
        $ite(Uua = zero_zero(code_integer),l2,aa(int,int,aa(int,fun(int,int),plus_plus(int),l2),one_one(int))) ) ).

% ATP.lambda_64
tff(fact_6057_ATP_Olambda__65,axiom,
    ! [Uu: product_prod(int,int),Uua: product_prod(int,int)] : aa(product_prod(int,int),product_prod(int,int),aa(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int)),aTP_Lamp_km(product_prod(int,int),fun(product_prod(int,int),product_prod(int,int))),Uu),Uua) = aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_fst(int,int),Uu)),aa(product_prod(int,int),int,product_fst(int,int),Uua))),aa(int,int,aa(int,fun(int,int),times_times(int),aa(product_prod(int,int),int,product_snd(int,int),Uu)),aa(product_prod(int,int),int,product_snd(int,int),Uua))) ).

% ATP.lambda_65
tff(fact_6058_ATP_Olambda__66,axiom,
    ! [C: $tType,B: $tType,Uu: set(old_node(B,C)),Uua: set(old_node(B,C))] : aa(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aTP_Lamp_xn(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),Uu),Uua) = aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),insert2(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_In1(B,C,Uu)),old_In1(B,C,Uua))),bot_bot(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))) ).

% ATP.lambda_66
tff(fact_6059_ATP_Olambda__67,axiom,
    ! [C: $tType,B: $tType,Uu: set(old_node(B,C)),Uua: set(old_node(B,C))] : aa(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aTP_Lamp_xm(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),Uu),Uua) = aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),insert2(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_In0(B,C,Uu)),old_In0(B,C,Uua))),bot_bot(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))) ).

% ATP.lambda_67
tff(fact_6060_ATP_Olambda__68,axiom,
    ! [Uu: rat,Uua: int] :
      ( aa(int,$o,aTP_Lamp_nb(rat,fun(int,$o),Uu),Uua)
    <=> ( aa(rat,$o,aa(rat,fun(rat,$o),ord_less_eq(rat),aa(int,rat,ring_1_of_int(rat),Uua)),Uu)
        & aa(rat,$o,aa(rat,fun(rat,$o),ord_less(rat),Uu),aa(int,rat,ring_1_of_int(rat),aa(int,int,aa(int,fun(int,int),plus_plus(int),Uua),one_one(int)))) ) ) ).

% ATP.lambda_68
tff(fact_6061_ATP_Olambda__69,axiom,
    ! [B: $tType,Uu: set(B),Uua: list(B)] :
      ( aa(list(B),$o,aTP_Lamp_of(set(B),fun(list(B),$o),Uu),Uua)
    <=> ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),Uua)),Uu)
        & distinct(B,Uua) ) ) ).

% ATP.lambda_69
tff(fact_6062_ATP_Olambda__70,axiom,
    ! [B: $tType,Uu: set(B),Uua: list(B)] :
      ( aa(list(B),$o,aTP_Lamp_oe(set(B),fun(list(B),$o),Uu),Uua)
    <=> ( ( aa(list(B),set(B),set2(B),Uua) = Uu )
        & distinct(B,Uua) ) ) ).

% ATP.lambda_70
tff(fact_6063_ATP_Olambda__71,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [Uu: nat,Uua: nat] : aa(nat,B,aTP_Lamp_eh(nat,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),Uua)),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,binomial(Uu),Uua))) ) ).

% ATP.lambda_71
tff(fact_6064_ATP_Olambda__72,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: B,Uua: nat] : aa(nat,B,aTP_Lamp_dz(B,fun(nat,B),Uu),Uua) = aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(nat,B,semiring_1_of_nat(B),Uua))),Uua) ) ).

% ATP.lambda_72
tff(fact_6065_ATP_Olambda__73,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: B,Uua: nat] : aa(nat,B,aTP_Lamp_dx(B,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,Uu),Uua)),aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),Uu),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))),aa(nat,B,semiring_1_of_nat(B),Uua))) ) ).

% ATP.lambda_73
tff(fact_6066_ATP_Olambda__74,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: B,Uua: nat] : aa(nat,B,aTP_Lamp_ea(B,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,Uu),Uua)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),one_one(B))),Uua)) ) ).

% ATP.lambda_74
tff(fact_6067_ATP_Olambda__75,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B),Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(list(B),product_prod(heap_ext(product_unit),nat)),aTP_Lamp_rq(array(B),fun(heap_ext(product_unit),product_prod(list(B),product_prod(heap_ext(product_unit),nat))),Uu),Uua) = aa(product_prod(heap_ext(product_unit),nat),product_prod(list(B),product_prod(heap_ext(product_unit),nat)),aa(list(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(list(B),product_prod(heap_ext(product_unit),nat))),product_Pair(list(B),product_prod(heap_ext(product_unit),nat)),array_get(B,Uua,Uu)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uua),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),aa(array(B),nat,array_length(B,Uua),Uu)))) ) ).

% ATP.lambda_75
tff(fact_6068_ATP_Olambda__76,axiom,
    ! [B: $tType,Uu: set(set(B)),Uua: set(set(B))] :
      ( aa(set(set(B)),$o,aTP_Lamp_ip(set(set(B)),fun(set(set(B)),$o),Uu),Uua)
    <=> ( aa(set(set(B)),$o,aa(set(set(B)),fun(set(set(B)),$o),ord_less_eq(set(set(B))),Uua),Uu)
        & ( Uua != bot_bot(set(set(B))) ) ) ) ).

% ATP.lambda_76
tff(fact_6069_ATP_Olambda__77,axiom,
    ! [B: $tType,Uu: set(option(B)),Uua: option(B)] :
      ( aa(option(B),$o,aTP_Lamp_hp(set(option(B)),fun(option(B),$o),Uu),Uua)
    <=> ( member(option(B),Uua,Uu)
        & ( Uua != none(B) ) ) ) ).

% ATP.lambda_77
tff(fact_6070_ATP_Olambda__78,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(product_prod(B,B))] :
      ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),aTP_Lamp_sn(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o)),Uu),Uua)
    <=> ( aa(set(product_prod(B,B)),$o,aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),$o),ord_less_eq(set(product_prod(B,B))),Uu),Uua)
        & ! [A7: B,B7: B,C4: B] :
            ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),B7),Uua)
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B7),C4),Uu) )
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A7),B7),Uu) ) ) ) ).

% ATP.lambda_78
tff(fact_6071_ATP_Olambda__79,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_er(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uua)),Uu) ).

% ATP.lambda_79
tff(fact_6072_ATP_Olambda__80,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_eq(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,binomial(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uua)),Uua) ).

% ATP.lambda_80
tff(fact_6073_ATP_Olambda__81,axiom,
    ! [B: $tType,C: $tType,Uu: C,Uua: B] : aa(B,set(product_prod(C,B)),aTP_Lamp_ku(C,fun(B,set(product_prod(C,B))),Uu),Uua) = aa(set(product_prod(C,B)),set(product_prod(C,B)),insert2(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Uu),Uua)),bot_bot(set(product_prod(C,B)))) ).

% ATP.lambda_81
tff(fact_6074_ATP_Olambda__82,axiom,
    ! [C: $tType,B: $tType,Uu: B,Uua: C] : aa(C,set(product_prod(B,C)),aTP_Lamp_kf(B,fun(C,set(product_prod(B,C))),Uu),Uua) = aa(set(product_prod(B,C)),set(product_prod(B,C)),insert2(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uu),Uua)),bot_bot(set(product_prod(B,C)))) ).

% ATP.lambda_82
tff(fact_6075_ATP_Olambda__83,axiom,
    ! [B: $tType,D: $tType,C: $tType,Uu: fun(C,fun(D,$o)),Uua: fun(B,product_prod(C,D))] :
      ( aa(fun(B,product_prod(C,D)),$o,aTP_Lamp_ji(fun(C,fun(D,$o)),fun(fun(B,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(set(B),set(product_prod(C,D)),image2(B,product_prod(C,D),Uua),top_top(set(B)))),aa(fun(product_prod(C,D),$o),set(product_prod(C,D)),collect(product_prod(C,D)),aa(fun(C,fun(D,$o)),fun(product_prod(C,D),$o),product_case_prod(C,D,$o),Uu))) ) ).

% ATP.lambda_83
tff(fact_6076_ATP_Olambda__84,axiom,
    ! [B: $tType,C: $tType,Uu: set(C),Uua: fun(B,C)] :
      ( aa(fun(B,C),$o,aTP_Lamp_uq(set(C),fun(fun(B,C),$o),Uu),Uua)
    <=> aa(set(C),$o,aa(set(C),fun(set(C),$o),ord_less_eq(set(C)),aa(set(B),set(C),image2(B,C,Uua),top_top(set(B)))),Uu) ) ).

% ATP.lambda_84
tff(fact_6077_ATP_Olambda__85,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(D,product_prod(B,C)),Uua: B] : aa(B,set(C),aTP_Lamp_jh(fun(D,product_prod(B,C)),fun(B,set(C)),Uu),Uua) = aa(set(D),set(C),image2(D,C,aa(fun(D,product_prod(B,C)),fun(D,C),aa(fun(product_prod(B,C),C),fun(fun(D,product_prod(B,C)),fun(D,C)),comp(product_prod(B,C),C,D),product_snd(B,C)),Uu)),top_top(set(D))) ).

% ATP.lambda_85
tff(fact_6078_ATP_Olambda__86,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_fz(fun(nat,B),fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uua))),aa(nat,B,Uu,aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uua)))) ) ).

% ATP.lambda_86
tff(fact_6079_ATP_Olambda__87,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_cx(fun(nat,B),fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uua))),aa(nat,B,Uu,aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uua)))) ) ).

% ATP.lambda_87
tff(fact_6080_ATP_Olambda__88,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_bt(fun(nat,B),fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,Uu,aa(nat,nat,suc,Uua))),aa(nat,B,Uu,Uua)) ) ).

% ATP.lambda_88
tff(fact_6081_ATP_Olambda__89,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat] : aa(nat,B,aTP_Lamp_fr(fun(nat,fun(nat,B)),fun(nat,B),Uu),Uua) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),Uu,Uua)),set_or7035219750837199246ssThan(nat,zero_zero(nat),Uua)) ) ).

% ATP.lambda_89
tff(fact_6082_ATP_Olambda__90,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat] : aa(nat,B,aTP_Lamp_fc(fun(nat,fun(nat,B)),fun(nat,B),Uu),Uua) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),Uu,Uua)),set_or7035219750837199246ssThan(nat,zero_zero(nat),Uua)) ) ).

% ATP.lambda_90
tff(fact_6083_ATP_Olambda__91,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_bl(fun(nat,B),fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,Uu,Uua)),aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),one_one(nat)))) ) ).

% ATP.lambda_91
tff(fact_6084_ATP_Olambda__92,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_bx(fun(nat,B),fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,Uu,Uua)),aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),one_one(nat)))) ) ).

% ATP.lambda_92
tff(fact_6085_ATP_Olambda__93,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_do(fun(nat,B),fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(nat,B,Uu,Uua)),aa(nat,B,Uu,aa(nat,nat,suc,Uua))) ) ).

% ATP.lambda_93
tff(fact_6086_ATP_Olambda__94,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat] : aa(nat,B,aTP_Lamp_fv(fun(nat,fun(nat,B)),fun(nat,B),Uu),Uua) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),Uu,Uua)),aa(nat,set(nat),set_ord_lessThan(nat),Uua)) ) ).

% ATP.lambda_94
tff(fact_6087_ATP_Olambda__95,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat] : aa(nat,B,aTP_Lamp_en(fun(nat,fun(nat,B)),fun(nat,B),Uu),Uua) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),Uu,Uua)),aa(nat,set(nat),set_ord_lessThan(nat),Uua)) ) ).

% ATP.lambda_95
tff(fact_6088_ATP_Olambda__96,axiom,
    ! [B: $tType,Uu: fun(B,nat),Uua: B] : aa(B,product_prod(nat,B),aTP_Lamp_gp(fun(B,nat),fun(B,product_prod(nat,B)),Uu),Uua) = aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),aa(B,nat,Uu,Uua)),Uua) ).

% ATP.lambda_96
tff(fact_6089_ATP_Olambda__97,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,C),Uua: B] : aa(B,product_prod(C,B),aTP_Lamp_nh(fun(B,C),fun(B,product_prod(C,B)),Uu),Uua) = aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),aa(B,C,Uu,Uua)),Uua) ).

% ATP.lambda_97
tff(fact_6090_ATP_Olambda__98,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(B,C),Uua: B] :
          ( aa(B,$o,aTP_Lamp_ie(fun(B,C),fun(B,$o),Uu),Uua)
        <=> ( aa(B,C,Uu,Uua) = one_one(C) ) ) ) ).

% ATP.lambda_98
tff(fact_6091_ATP_Olambda__99,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: list(B),Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aTP_Lamp_os(list(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),Uu),Uua) = aa(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(array(B),heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_or(list(B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu)),array_alloc(B,Uu,Uua)) ) ).

% ATP.lambda_99
tff(fact_6092_ATP_Olambda__100,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aa(nat,fun(nat,nat),aTP_Lamp_im(nat,fun(nat,nat)),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),nat_triangle(aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uua))),Uu) ).

% ATP.lambda_100
tff(fact_6093_ATP_Olambda__101,axiom,
    ! [Uu: num,Uua: num] : aa(num,int,aTP_Lamp_dj(num,fun(num,int),Uu),Uua) = aa(int,int,aa(nat,fun(int,int),bit_se2584673776208193580ke_bit(int),aa(num,nat,numeral_numeral(nat),Uu)),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(nat,int,aa(int,fun(nat,int),power_power(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),aa(num,nat,numeral_numeral(nat),Uu))),aa(num,int,numeral_numeral(int),Uua))) ).

% ATP.lambda_101
tff(fact_6094_ATP_Olambda__102,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,fun(C,$o)),Uua: heap_Time_Heap(product_prod(B,C))] :
      ( aa(heap_Time_Heap(product_prod(B,C)),$o,aTP_Lamp_vl(fun(B,fun(C,$o)),fun(heap_Time_Heap(product_prod(B,C)),$o),Uu),Uua)
    <=> aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),heap_Time_set_Heap(product_prod(B,C),Uua)),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),Uu))) ) ).

% ATP.lambda_102
tff(fact_6095_ATP_Olambda__103,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,fun(C,$o)),Uua: option(product_prod(B,C))] :
      ( aa(option(product_prod(B,C)),$o,aTP_Lamp_tv(fun(B,fun(C,$o)),fun(option(product_prod(B,C)),$o),Uu),Uua)
    <=> aa(set(product_prod(B,C)),$o,aa(set(product_prod(B,C)),fun(set(product_prod(B,C)),$o),ord_less_eq(set(product_prod(B,C))),aa(option(product_prod(B,C)),set(product_prod(B,C)),set_option(product_prod(B,C)),Uua)),aa(fun(product_prod(B,C),$o),set(product_prod(B,C)),collect(product_prod(B,C)),aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),Uu))) ) ).

% ATP.lambda_103
tff(fact_6096_ATP_Olambda__104,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [Uu: product_prod(B,C),Uua: product_prod(B,C)] :
          ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),aTP_Lamp_pc(product_prod(B,C),fun(product_prod(B,C),$o)),Uu),Uua)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(product_prod(B,C),B,product_fst(B,C),Uu)),aa(product_prod(B,C),B,product_fst(B,C),Uua)) ) ) ).

% ATP.lambda_104
tff(fact_6097_ATP_Olambda__105,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [Uu: product_prod(B,C),Uua: product_prod(B,C)] :
          ( aa(product_prod(B,C),$o,aa(product_prod(B,C),fun(product_prod(B,C),$o),aTP_Lamp_qh(product_prod(B,C),fun(product_prod(B,C),$o)),Uu),Uua)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(product_prod(B,C),B,product_fst(B,C),Uua)),aa(product_prod(B,C),B,product_fst(B,C),Uu)) ) ) ).

% ATP.lambda_105
tff(fact_6098_ATP_Olambda__106,axiom,
    ! [B: $tType,Uu: list(option(B)),Uua: B] : aa(B,option(list(B)),aTP_Lamp_vm(list(option(B)),fun(B,option(list(B))),Uu),Uua) = aa(option(list(B)),option(list(B)),aa(fun(list(B),list(B)),fun(option(list(B)),option(list(B))),map_option(list(B),list(B)),aa(B,fun(list(B),list(B)),cons(B),Uua)),those(B,Uu)) ).

% ATP.lambda_106
tff(fact_6099_ATP_Olambda__107,axiom,
    ! [Uu: num,Uua: num] : aa(num,int,aa(num,fun(num,int),aTP_Lamp_hm(num,fun(num,int)),Uu),Uua) = aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(num,int,numeral_numeral(int),Uu)),aa(num,int,numeral_numeral(int),Uua)) ).

% ATP.lambda_107
tff(fact_6100_ATP_Olambda__108,axiom,
    ! [B: $tType] :
      ( countable(B)
     => ! [Uu: nat,Uua: nat] : aa(nat,set(old_node(B,product_unit)),aa(nat,fun(nat,set(old_node(B,product_unit))),aTP_Lamp_xj(nat,fun(nat,set(old_node(B,product_unit)))),Uu),Uua) = old_Scons(B,product_unit,nth_item(B,Uu),nth_item(B,Uua)) ) ).

% ATP.lambda_108
tff(fact_6101_ATP_Olambda__109,axiom,
    ! [Uu: code_integer,Uua: code_integer] :
      aa(code_integer,num,aa(code_integer,fun(code_integer,num),aTP_Lamp_fa(code_integer,fun(code_integer,num)),Uu),Uua) = $let(
        l2: num,
        l2:= aa(code_integer,num,code_num_of_integer,Uu),
        $let(
          l3: num,
          l3:= aa(num,num,aa(num,fun(num,num),plus_plus(num),l2),l2),
          $ite(Uua = zero_zero(code_integer),l3,aa(num,num,aa(num,fun(num,num),plus_plus(num),l3),one2)) ) ) ).

% ATP.lambda_109
tff(fact_6102_ATP_Olambda__110,axiom,
    ! [Uu: code_integer,Uua: code_integer] :
      aa(code_integer,nat,aa(code_integer,fun(code_integer,nat),aTP_Lamp_ff(code_integer,fun(code_integer,nat)),Uu),Uua) = $let(
        l2: nat,
        l2:= aa(code_integer,nat,code_nat_of_integer,Uu),
        $let(
          l3: nat,
          l3:= aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),l2),l2),
          $ite(Uua = zero_zero(code_integer),l3,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),l3),one_one(nat))) ) ) ).

% ATP.lambda_110
tff(fact_6103_ATP_Olambda__111,axiom,
    ! [B: $tType,Uu: set(B),Uua: heap_Time_Heap(B)] :
      ( aa(heap_Time_Heap(B),$o,aTP_Lamp_vk(set(B),fun(heap_Time_Heap(B),$o),Uu),Uua)
    <=> aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),heap_Time_set_Heap(B,Uua)),Uu) ) ).

% ATP.lambda_111
tff(fact_6104_ATP_Olambda__112,axiom,
    ! [B: $tType,Uu: set(B),Uua: option(B)] :
      ( aa(option(B),$o,aTP_Lamp_up(set(B),fun(option(B),$o),Uu),Uua)
    <=> aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(option(B),set(B),set_option(B),Uua)),Uu) ) ).

% ATP.lambda_112
tff(fact_6105_ATP_Olambda__113,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: nat,Uua: nat] : aa(nat,B,aTP_Lamp_eb(nat,fun(nat,B),Uu),Uua) = aa(nat,B,gbinomial(B,aa(nat,B,semiring_1_of_nat(B),Uua)),Uu) ) ).

% ATP.lambda_113
tff(fact_6106_ATP_Olambda__114,axiom,
    ! [B: $tType,C: $tType,Uu: list(C),Uua: B] : aa(B,list(product_prod(B,C)),aTP_Lamp_po(list(C),fun(B,list(product_prod(B,C))),Uu),Uua) = aa(list(C),list(product_prod(B,C)),map(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua)),Uu) ).

% ATP.lambda_114
tff(fact_6107_ATP_Olambda__115,axiom,
    ! [B: $tType,Uu: set(nat),Uua: product_prod(B,nat)] :
      ( aa(product_prod(B,nat),$o,aTP_Lamp_qw(set(nat),fun(product_prod(B,nat),$o),Uu),Uua)
    <=> member(nat,aa(product_prod(B,nat),nat,product_snd(B,nat),Uua),Uu) ) ).

% ATP.lambda_115
tff(fact_6108_ATP_Olambda__116,axiom,
    ! [B: $tType,Uu: nat,Uua: list(B)] :
      ( aa(list(B),$o,aTP_Lamp_ug(nat,fun(list(B),$o),Uu),Uua)
    <=> ( aa(list(B),nat,size_size(list(B)),Uua) = Uu ) ) ).

% ATP.lambda_116
tff(fact_6109_ATP_Olambda__117,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [Uu: B,Uua: B] : aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),aTP_Lamp_dh(B,fun(B,product_prod(B,B))),Uu),Uua) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uu),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Uua)),one_one(B))) ) ).

% ATP.lambda_117
tff(fact_6110_ATP_Olambda__118,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [Uu: B,Uua: B] : aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),aTP_Lamp_dg(B,fun(B,product_prod(B,B))),Uu),Uua) = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uu),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Uua)) ) ).

% ATP.lambda_118
tff(fact_6111_ATP_Olambda__119,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: B,Uua: nat] : aa(nat,B,aTP_Lamp_fg(B,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(B,B,aa(B,fun(B,B),divide_divide(B),aa(nat,B,semiring_1_of_nat(B),Uua)),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2)))) ) ).

% ATP.lambda_119
tff(fact_6112_ATP_Olambda__120,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_ei(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uua),aa(nat,nat,binomial(Uu),Uua)) ).

% ATP.lambda_120
tff(fact_6113_ATP_Olambda__121,axiom,
    ! [B: $tType,Uu: B,Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),aTP_Lamp_an(B,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Uu),Uua) = aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),Uu),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uua),zero_zero(nat))) ).

% ATP.lambda_121
tff(fact_6114_ATP_Olambda__122,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: ref(B),Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)),aa(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_we(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)))),Uu),Uua) = aa(product_prod(heap_ext(product_unit),nat),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)),aa(ref(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),product_Pair(ref(B),product_prod(heap_ext(product_unit),nat)),Uu),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uua),one_one(nat))) ) ).

% ATP.lambda_122
tff(fact_6115_ATP_Olambda__123,axiom,
    ! [B: $tType,Uu: B,Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),aTP_Lamp_aa(B,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Uu),Uua) = aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),Uu),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uua),one_one(nat))) ).

% ATP.lambda_123
tff(fact_6116_ATP_Olambda__124,axiom,
    ! [B: $tType,Uu: fun(nat,B),Uua: nat] : aa(nat,product_prod(nat,B),aTP_Lamp_pa(fun(nat,B),fun(nat,product_prod(nat,B)),Uu),Uua) = aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),Uua),aa(nat,B,Uu,Uua)) ).

% ATP.lambda_124
tff(fact_6117_ATP_Olambda__125,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,C),Uua: B] : aa(B,product_prod(B,C),aTP_Lamp_ng(fun(B,C),fun(B,product_prod(B,C)),Uu),Uua) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),aa(B,C,Uu,Uua)) ).

% ATP.lambda_125
tff(fact_6118_ATP_Olambda__126,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,option(C)),Uua: B] : aa(B,product_prod(B,C),aTP_Lamp_ny(fun(B,option(C)),fun(B,product_prod(B,C)),Uu),Uua) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),aa(option(C),C,the2(C),aa(B,option(C),Uu,Uua))) ).

% ATP.lambda_126
tff(fact_6119_ATP_Olambda__127,axiom,
    ! [Uu: int,Uua: int] : aa(int,int,aa(int,fun(int,int),aTP_Lamp_dr(int,fun(int,int)),Uu),Uua) = aa(int,int,aa(int,fun(int,int),plus_plus(int),Uu),aa($o,int,zero_neq_one_of_bool(int),Uua != zero_zero(int))) ).

% ATP.lambda_127
tff(fact_6120_ATP_Olambda__128,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Uu: B,Uua: nat] : aa(nat,B,aTP_Lamp_fx(B,fun(nat,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(nat,B,semiring_1_of_nat(B),Uua)) ) ).

% ATP.lambda_128
tff(fact_6121_ATP_Olambda__129,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,list(nat),aa(nat,fun(nat,list(nat)),aTP_Lamp_pg(nat,fun(nat,list(nat))),Uu),Uua) = aa(list(nat),list(nat),aa(nat,fun(list(nat),list(nat)),cons(nat),Uu),nat_list_decode(Uua)) ).

% ATP.lambda_129
tff(fact_6122_ATP_Olambda__130,axiom,
    ! [C: $tType,B: $tType,Uu: list(product_prod(B,C)),Uua: fun(B,option(C))] : aa(fun(B,option(C)),fun(B,option(C)),aa(list(product_prod(B,C)),fun(fun(B,option(C)),fun(B,option(C))),aTP_Lamp_pp(list(product_prod(B,C)),fun(fun(B,option(C)),fun(B,option(C)))),Uu),Uua) = map_add(B,C,Uua,map_of(B,C,Uu)) ).

% ATP.lambda_130
tff(fact_6123_ATP_Olambda__131,axiom,
    ! [B: $tType,Uu: list(set(B)),Uua: set(B)] :
      ( aa(set(B),$o,aTP_Lamp_oo(list(set(B)),fun(set(B),$o),Uu),Uua)
    <=> member(set(B),Uua,aa(list(set(B)),set(set(B)),set2(set(B)),Uu)) ) ).

% ATP.lambda_131
tff(fact_6124_ATP_Olambda__132,axiom,
    ! [B: $tType,Uu: nat,Uua: list(B)] :
      ( aa(list(B),$o,aTP_Lamp_uh(nat,fun(list(B),$o),Uu),Uua)
    <=> ( Uu = aa(list(B),nat,size_size(list(B)),Uua) ) ) ).

% ATP.lambda_132
tff(fact_6125_ATP_Olambda__133,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: B,Uua: B] :
          ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_qj(B,fun(B,$o)),Uu),Uua)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Uua),Uu) ) ) ).

% ATP.lambda_133
tff(fact_6126_ATP_Olambda__134,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [Uu: B,Uua: B] :
          ( aa(B,$o,aTP_Lamp_dn(B,fun(B,$o),Uu),Uua)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Uua),Uu) ) ) ).

% ATP.lambda_134
tff(fact_6127_ATP_Olambda__135,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_ho(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),modulo_modulo(nat),Uua),Uu) ).

% ATP.lambda_135
tff(fact_6128_ATP_Olambda__136,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [Uu: B,Uua: B] : aa(B,B,aTP_Lamp_gn(B,fun(B,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),divide_divide(B),Uua),Uu) ) ).

% ATP.lambda_136
tff(fact_6129_ATP_Olambda__137,axiom,
    ! [Uu: nat,Uua: nat] :
      ( aa(nat,$o,aTP_Lamp_cw(nat,fun(nat,$o),Uu),Uua)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uua),Uu) ) ).

% ATP.lambda_137
tff(fact_6130_ATP_Olambda__138,axiom,
    ! [B: $tType] :
      ( preorder(B)
     => ! [Uu: B,Uua: B] :
          ( aa(B,$o,aTP_Lamp_ak(B,fun(B,$o),Uu),Uua)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),Uua),Uu) ) ) ).

% ATP.lambda_138
tff(fact_6131_ATP_Olambda__139,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [Uu: B,Uua: B] :
          ( aa(B,$o,aTP_Lamp_ek(B,fun(B,$o),Uu),Uua)
        <=> aa(B,$o,aa(B,fun(B,$o),ord_less(B),Uua),Uu) ) ) ).

% ATP.lambda_139
tff(fact_6132_ATP_Olambda__140,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [Uu: B,Uua: B] : aa(B,B,aTP_Lamp_hk(B,fun(B,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),times_times(B),Uua),Uu) ) ).

% ATP.lambda_140
tff(fact_6133_ATP_Olambda__141,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_hn(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),Uu) ).

% ATP.lambda_141
tff(fact_6134_ATP_Olambda__142,axiom,
    ! [B: $tType] :
      ( linordered_idom(B)
     => ! [Uu: B,Uua: B] : aa(B,B,aTP_Lamp_gm(B,fun(B,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),minus_minus(B),Uua),Uu) ) ).

% ATP.lambda_142
tff(fact_6135_ATP_Olambda__143,axiom,
    ! [B: $tType] :
      ( ab_group_add(B)
     => ! [Uu: B,Uua: B] : aa(B,B,aTP_Lamp_go(B,fun(B,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),minus_minus(B),Uua),Uu) ) ).

% ATP.lambda_143
tff(fact_6136_ATP_Olambda__144,axiom,
    ! [Uu: code_integer,Uua: code_integer] : aa(code_integer,code_integer,aTP_Lamp_gy(code_integer,fun(code_integer,code_integer),Uu),Uua) = aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),Uua),Uu) ).

% ATP.lambda_144
tff(fact_6137_ATP_Olambda__145,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_ox(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uu) ).

% ATP.lambda_145
tff(fact_6138_ATP_Olambda__146,axiom,
    ! [Uu: int,Uua: int] : aa(int,int,aTP_Lamp_gx(int,fun(int,int),Uu),Uua) = aa(int,int,aa(int,fun(int,int),plus_plus(int),Uua),Uu) ).

% ATP.lambda_146
tff(fact_6139_ATP_Olambda__147,axiom,
    ! [B: $tType] :
      ( cancel_semigroup_add(B)
     => ! [Uu: B,Uua: B] : aa(B,B,aTP_Lamp_ni(B,fun(B,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uua),Uu) ) ).

% ATP.lambda_147
tff(fact_6140_ATP_Olambda__148,axiom,
    ! [B: $tType] :
      ( linordered_semidom(B)
     => ! [Uu: B,Uua: B] : aa(B,B,aTP_Lamp_gl(B,fun(B,B),Uu),Uua) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uua),Uu) ) ).

% ATP.lambda_148
tff(fact_6141_ATP_Olambda__149,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: list(B),Uua: array(B)] : aa(array(B),assn,aTP_Lamp_wa(list(B),fun(array(B),assn),Uu),Uua) = snga_assn(B,Uua,Uu) ) ).

% ATP.lambda_149
tff(fact_6142_ATP_Olambda__150,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(C)),Uua: set(B)] : aa(set(B),set(product_prod(B,C)),aTP_Lamp_jv(fun(B,set(C)),fun(set(B),set(product_prod(B,C))),Uu),Uua) = product_Sigma(B,C,Uua,Uu) ).

% ATP.lambda_150
tff(fact_6143_ATP_Olambda__151,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),aTP_Lamp_bo(nat,fun(nat,product_prod(nat,nat))),Uu),Uua) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),Uua),Uu) ).

% ATP.lambda_151
tff(fact_6144_ATP_Olambda__152,axiom,
    ! [B: $tType,C: $tType,Uu: C,Uua: B] : aa(B,product_prod(B,C),aa(C,fun(B,product_prod(B,C)),aTP_Lamp_is(C,fun(B,product_prod(B,C))),Uu),Uua) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),Uu) ).

% ATP.lambda_152
tff(fact_6145_ATP_Olambda__153,axiom,
    ! [B: $tType,Uu: B,Uua: nat] : aa(nat,product_prod(nat,B),aTP_Lamp_oy(B,fun(nat,product_prod(nat,B)),Uu),Uua) = aa(B,product_prod(nat,B),aa(nat,fun(B,product_prod(nat,B)),product_Pair(nat,B),Uua),Uu) ).

% ATP.lambda_153
tff(fact_6146_ATP_Olambda__154,axiom,
    ! [C: $tType,B: $tType,Uu: B,Uua: C] : aa(C,product_prod(C,B),aa(B,fun(C,product_prod(C,B)),aTP_Lamp_it(B,fun(C,product_prod(C,B))),Uu),Uua) = aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Uua),Uu) ).

% ATP.lambda_154
tff(fact_6147_ATP_Olambda__155,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B),Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),nat,aTP_Lamp_rx(array(B),fun(heap_ext(product_unit),nat),Uu),Uua) = aa(array(B),nat,array_length(B,Uua),Uu) ) ).

% ATP.lambda_155
tff(fact_6148_ATP_Olambda__156,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: ref(B),Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),B,aTP_Lamp_bd(ref(B),fun(heap_ext(product_unit),B),Uu),Uua) = ref_get(B,Uua,Uu) ) ).

% ATP.lambda_156
tff(fact_6149_ATP_Olambda__157,axiom,
    ! [B: $tType,Uu: set(B),Uua: B] :
      ( aa(B,$o,aTP_Lamp_a(set(B),fun(B,$o),Uu),Uua)
    <=> member(B,Uua,Uu) ) ).

% ATP.lambda_157
tff(fact_6150_ATP_Olambda__158,axiom,
    ! [B: $tType,Uu: B,Uua: B] :
      ( aa(B,$o,aTP_Lamp_ac(B,fun(B,$o),Uu),Uua)
    <=> ( Uua = Uu ) ) ).

% ATP.lambda_158
tff(fact_6151_ATP_Olambda__159,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,nat,aTP_Lamp_wd(nat,fun(nat,nat),Uu),Uua) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),one_one(nat)) ).

% ATP.lambda_159
tff(fact_6152_ATP_Olambda__160,axiom,
    ! [B: $tType,Uu: B,Uua: list(B)] : aa(list(B),list(B),aa(B,fun(list(B),list(B)),aTP_Lamp_rg(B,fun(list(B),list(B))),Uu),Uua) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uu),nil(B)) ).

% ATP.lambda_160
tff(fact_6153_ATP_Olambda__161,axiom,
    ! [B: $tType,Uu: B,Uua: list(B)] : aa(list(B),list(list(B)),aa(B,fun(list(B),list(list(B))),aTP_Lamp_rd(B,fun(list(B),list(list(B)))),Uu),Uua) = aa(list(list(B)),list(list(B)),aa(list(B),fun(list(list(B)),list(list(B))),cons(list(B)),Uua),nil(list(B))) ).

% ATP.lambda_161
tff(fact_6154_ATP_Olambda__162,axiom,
    ! [B: $tType,Uu: B,Uua: B] : aa(B,set(B),aTP_Lamp_ns(B,fun(B,set(B)),Uu),Uua) = aa(set(B),set(B),insert2(B,Uu),bot_bot(set(B))) ).

% ATP.lambda_162
tff(fact_6155_ATP_Olambda__163,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: B,Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)),aTP_Lamp_wf(B,fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),Uu),Uua) = aa(product_prod(ref(B),heap_ext(product_unit)),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)),aa(fun(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(ref(B),heap_ext(product_unit)),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(ref(B),heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_we(ref(B),fun(heap_ext(product_unit),product_prod(ref(B),product_prod(heap_ext(product_unit),nat))))),ref_alloc(B,Uu,Uua)) ) ).

% ATP.lambda_163
tff(fact_6156_ATP_Olambda__164,axiom,
    ! [B: $tType,Uu: fun(B,nat),Uua: B] :
      ( aa(B,$o,aTP_Lamp_tr(fun(B,nat),fun(B,$o),Uu),Uua)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),zero_zero(nat)),aa(B,nat,Uu,Uua)) ) ).

% ATP.lambda_164
tff(fact_6157_ATP_Olambda__165,axiom,
    ! [C: $tType,B: $tType,Uu: set(product_prod(B,C)),Uua: B] : aa(B,set(C),aTP_Lamp_kh(set(product_prod(B,C)),fun(B,set(C)),Uu),Uua) = aa(set(product_prod(B,C)),set(C),image2(product_prod(B,C),C,product_snd(B,C)),Uu) ).

% ATP.lambda_165
tff(fact_6158_ATP_Olambda__166,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: fun(C,D),Uua: product_prod(B,C)] : aa(product_prod(B,C),D,aTP_Lamp_iu(fun(C,D),fun(product_prod(B,C),D),Uu),Uua) = aa(C,D,Uu,aa(product_prod(B,C),C,product_snd(B,C),Uua)) ).

% ATP.lambda_166
tff(fact_6159_ATP_Olambda__167,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: fun(B,D),Uua: product_prod(B,C)] : aa(product_prod(B,C),D,aTP_Lamp_ix(fun(B,D),fun(product_prod(B,C),D),Uu),Uua) = aa(B,D,Uu,aa(product_prod(B,C),B,product_fst(B,C),Uua)) ).

% ATP.lambda_167
tff(fact_6160_ATP_Olambda__168,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(sum_sum(C,D),set(B)),Uua: D] : aa(D,set(B),aTP_Lamp_xb(fun(sum_sum(C,D),set(B)),fun(D,set(B)),Uu),Uua) = aa(sum_sum(C,D),set(B),Uu,aa(D,sum_sum(C,D),sum_Inr(D,C),Uua)) ).

% ATP.lambda_168
tff(fact_6161_ATP_Olambda__169,axiom,
    ! [B: $tType,D: $tType,C: $tType,Uu: fun(sum_sum(C,D),set(B)),Uua: C] : aa(C,set(B),aTP_Lamp_xa(fun(sum_sum(C,D),set(B)),fun(C,set(B)),Uu),Uua) = aa(sum_sum(C,D),set(B),Uu,aa(C,sum_sum(C,D),sum_Inl(C,D),Uua)) ).

% ATP.lambda_169
tff(fact_6162_ATP_Olambda__170,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_fm(fun(nat,B),fun(nat,B),Uu),Uua) = aa(nat,B,Uu,aa(nat,nat,suc,Uua)) ) ).

% ATP.lambda_170
tff(fact_6163_ATP_Olambda__171,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_bp(fun(nat,B),fun(nat,B),Uu),Uua) = aa(nat,B,Uu,aa(nat,nat,suc,Uua)) ) ).

% ATP.lambda_171
tff(fact_6164_ATP_Olambda__172,axiom,
    ! [B: $tType,Uu: fun(nat,B),Uua: nat] : aa(nat,B,aTP_Lamp_wk(fun(nat,B),fun(nat,B),Uu),Uua) = aa(nat,B,Uu,aa(nat,nat,suc,Uua)) ).

% ATP.lambda_172
tff(fact_6165_ATP_Olambda__173,axiom,
    ! [B: $tType,D: $tType,Uu: D,Uua: fun(D,set(set(B)))] : aa(fun(D,set(set(B))),set(set(B)),aTP_Lamp_va(D,fun(fun(D,set(set(B))),set(set(B))),Uu),Uua) = aa(D,set(set(B)),Uua,Uu) ).

% ATP.lambda_173
tff(fact_6166_ATP_Olambda__174,axiom,
    ! [B: $tType,Uu: fun(product_unit,B),Uua: product_unit] : aa(product_unit,B,aTP_Lamp_mo(fun(product_unit,B),fun(product_unit,B),Uu),Uua) = aa(product_unit,B,Uu,product_Unity) ).

% ATP.lambda_174
tff(fact_6167_ATP_Olambda__175,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: B,Uua: option(B)] : aa(option(B),option(B),aa(B,fun(option(B),option(B)),aTP_Lamp_lk(B,fun(option(B),option(B))),Uu),Uua) = aa(B,option(B),some(B),aa(option(B),B,aa(fun(B,B),fun(option(B),B),aa(B,fun(fun(B,B),fun(option(B),B)),case_option(B,B),Uu),ord_min(B,Uu)),Uua)) ) ).

% ATP.lambda_175
tff(fact_6168_ATP_Olambda__176,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: B,Uua: option(B)] : aa(option(B),option(B),aa(B,fun(option(B),option(B)),aTP_Lamp_lj(B,fun(option(B),option(B))),Uu),Uua) = aa(B,option(B),some(B),aa(option(B),B,aa(fun(B,B),fun(option(B),B),aa(B,fun(fun(B,B),fun(option(B),B)),case_option(B,B),Uu),ord_max(B,Uu)),Uua)) ) ).

% ATP.lambda_176
tff(fact_6169_ATP_Olambda__177,axiom,
    ! [B: $tType] :
      ( semilattice_sup(B)
     => ! [Uu: B,Uua: option(B)] : aa(option(B),option(B),aa(B,fun(option(B),option(B)),aTP_Lamp_li(B,fun(option(B),option(B))),Uu),Uua) = aa(B,option(B),some(B),aa(option(B),B,aa(fun(B,B),fun(option(B),B),aa(B,fun(fun(B,B),fun(option(B),B)),case_option(B,B),Uu),aa(B,fun(B,B),sup_sup(B),Uu)),Uua)) ) ).

% ATP.lambda_177
tff(fact_6170_ATP_Olambda__178,axiom,
    ! [B: $tType] :
      ( semilattice_inf(B)
     => ! [Uu: B,Uua: option(B)] : aa(option(B),option(B),aa(B,fun(option(B),option(B)),aTP_Lamp_mw(B,fun(option(B),option(B))),Uu),Uua) = aa(B,option(B),some(B),aa(option(B),B,aa(fun(B,B),fun(option(B),B),aa(B,fun(fun(B,B),fun(option(B),B)),case_option(B,B),Uu),inf_inf(B,Uu)),Uua)) ) ).

% ATP.lambda_178
tff(fact_6171_ATP_Olambda__179,axiom,
    ! [Uu: nat,Uua: num] : aa(num,option(num),aTP_Lamp_gg(nat,fun(num,option(num)),Uu),Uua) = aa(num,option(num),some(num),aa(option(num),num,aa(fun(num,num),fun(option(num),num),aa(num,fun(fun(num,num),fun(option(num),num)),case_option(num,num),one2),bit1),bit_take_bit_num(Uu,Uua))) ).

% ATP.lambda_179
tff(fact_6172_ATP_Olambda__180,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(D,fun(B,D)),Uua: D] : aa(D,fun(product_prod(C,B),D),aTP_Lamp_qt(fun(D,fun(B,D)),fun(D,fun(product_prod(C,B),D)),Uu),Uua) = aa(fun(C,fun(B,D)),fun(product_prod(C,B),D),product_case_prod(C,B,D),aa(D,fun(C,fun(B,D)),aTP_Lamp_qs(fun(D,fun(B,D)),fun(D,fun(C,fun(B,D))),Uu),Uua)) ).

% ATP.lambda_180
tff(fact_6173_ATP_Olambda__181,axiom,
    ! [B: $tType,Uu: list(B),Uua: list(B)] : aa(list(B),fun(product_prod(B,list(B)),option($o)),aTP_Lamp_qc(list(B),fun(list(B),fun(product_prod(B,list(B)),option($o))),Uu),Uua) = aa(fun(B,fun(list(B),option($o))),fun(product_prod(B,list(B)),option($o)),product_case_prod(B,list(B),option($o)),aa(list(B),fun(B,fun(list(B),option($o))),aTP_Lamp_qb(list(B),fun(list(B),fun(B,fun(list(B),option($o)))),Uu),Uua)) ).

% ATP.lambda_181
tff(fact_6174_ATP_Olambda__182,axiom,
    ! [B: $tType,Uu: B,Uua: list(B)] : aa(list(B),fun(product_prod(B,list(B)),option(product_prod(list(B),product_prod(B,list(B))))),aTP_Lamp_qa(B,fun(list(B),fun(product_prod(B,list(B)),option(product_prod(list(B),product_prod(B,list(B)))))),Uu),Uua) = aa(fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B)))))),fun(product_prod(B,list(B)),option(product_prod(list(B),product_prod(B,list(B))))),product_case_prod(B,list(B),option(product_prod(list(B),product_prod(B,list(B))))),aa(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B)))))),aTP_Lamp_pz(B,fun(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B))))))),Uu),Uua)) ).

% ATP.lambda_182
tff(fact_6175_ATP_Olambda__183,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,fun(product_prod(nat,nat),$o),aa(nat,fun(nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_kt(nat,fun(nat,fun(product_prod(nat,nat),$o))),Uu),Uua) = aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aa(nat,fun(nat,fun(nat,$o)),aTP_Lamp_ks(nat,fun(nat,fun(nat,fun(nat,$o))),Uu),Uua)) ).

% ATP.lambda_183
tff(fact_6176_ATP_Olambda__184,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,fun(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cv(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),Uu),Uua) = aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aa(nat,fun(nat,fun(nat,product_prod(nat,nat))),aTP_Lamp_cu(nat,fun(nat,fun(nat,fun(nat,product_prod(nat,nat)))),Uu),Uua)) ).

% ATP.lambda_184
tff(fact_6177_ATP_Olambda__185,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,fun(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_ct(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),Uu),Uua) = aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aa(nat,fun(nat,fun(nat,product_prod(nat,nat))),aTP_Lamp_cs(nat,fun(nat,fun(nat,fun(nat,product_prod(nat,nat)))),Uu),Uua)) ).

% ATP.lambda_185
tff(fact_6178_ATP_Olambda__186,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,fun(product_prod(nat,nat),product_prod(nat,nat)),aa(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat))),aTP_Lamp_cr(nat,fun(nat,fun(product_prod(nat,nat),product_prod(nat,nat)))),Uu),Uua) = aa(fun(nat,fun(nat,product_prod(nat,nat))),fun(product_prod(nat,nat),product_prod(nat,nat)),product_case_prod(nat,nat,product_prod(nat,nat)),aa(nat,fun(nat,fun(nat,product_prod(nat,nat))),aTP_Lamp_cq(nat,fun(nat,fun(nat,fun(nat,product_prod(nat,nat)))),Uu),Uua)) ).

% ATP.lambda_186
tff(fact_6179_ATP_Olambda__187,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,heap_Time_Heap(B)),Uua: C] : aa(C,fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_cl(fun(C,heap_Time_Heap(B)),fun(C,fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),Uu),Uua) = aa(fun(heap_ext(product_unit),fun(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),product_case_prod(heap_ext(product_unit),nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(C,fun(heap_ext(product_unit),fun(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),aTP_Lamp_ck(fun(C,heap_Time_Heap(B)),fun(C,fun(heap_ext(product_unit),fun(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))))),Uu),Uua)) ).

% ATP.lambda_187
tff(fact_6180_ATP_Olambda__188,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,fun(product_prod(nat,nat),$o),aa(nat,fun(nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_cj(nat,fun(nat,fun(product_prod(nat,nat),$o))),Uu),Uua) = aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aa(nat,fun(nat,fun(nat,$o)),aTP_Lamp_ci(nat,fun(nat,fun(nat,fun(nat,$o))),Uu),Uua)) ).

% ATP.lambda_188
tff(fact_6181_ATP_Olambda__189,axiom,
    ! [Uu: nat,Uua: nat] : aa(nat,fun(product_prod(nat,nat),$o),aa(nat,fun(nat,fun(product_prod(nat,nat),$o)),aTP_Lamp_ch(nat,fun(nat,fun(product_prod(nat,nat),$o))),Uu),Uua) = aa(fun(nat,fun(nat,$o)),fun(product_prod(nat,nat),$o),product_case_prod(nat,nat,$o),aa(nat,fun(nat,fun(nat,$o)),aTP_Lamp_cg(nat,fun(nat,fun(nat,fun(nat,$o))),Uu),Uua)) ).

% ATP.lambda_189
tff(fact_6182_ATP_Olambda__190,axiom,
    ! [B: $tType,Uu: fun(heap_ext(product_unit),B),Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ar(fun(heap_ext(product_unit),B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),Uu),Uua) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(heap_ext(product_unit),B,Uu,Uua)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uua),one_one(nat)))) ).

% ATP.lambda_190
tff(fact_6183_ATP_Olambda__191,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,option(B)),Uua: C] :
      ( aa(C,$o,aTP_Lamp_oq(fun(C,option(B)),fun(C,$o),Uu),Uua)
    <=> ( aa(C,option(B),Uu,Uua) != none(B) ) ) ).

% ATP.lambda_191
tff(fact_6184_ATP_Olambda__192,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,option(C)),Uua: B] :
      ( aa(B,$o,aTP_Lamp_nw(fun(B,option(C)),fun(B,$o),Uu),Uua)
    <=> ( aa(B,option(C),Uu,Uua) != none(C) ) ) ).

% ATP.lambda_192
tff(fact_6185_ATP_Olambda__193,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(C)),Uua: B] : aa(B,set(product_prod(B,C)),aTP_Lamp_kg(fun(B,set(C)),fun(B,set(product_prod(B,C))),Uu),Uua) = aa(set(set(product_prod(B,C))),set(product_prod(B,C)),complete_Sup_Sup(set(product_prod(B,C))),aa(set(C),set(set(product_prod(B,C))),image2(C,set(product_prod(B,C)),aTP_Lamp_kf(B,fun(C,set(product_prod(B,C))),Uua)),aa(B,set(C),Uu,Uua))) ).

% ATP.lambda_193
tff(fact_6186_ATP_Olambda__194,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: list(product_prod(D,C)),Uua: product_prod(B,D)] : aa(product_prod(B,D),list(product_prod(B,C)),aTP_Lamp_pm(list(product_prod(D,C)),fun(product_prod(B,D),list(product_prod(B,C))),Uu),Uua) = concat(product_prod(B,C),aa(list(product_prod(D,C)),list(list(product_prod(B,C))),map(product_prod(D,C),list(product_prod(B,C)),aTP_Lamp_pl(product_prod(B,D),fun(product_prod(D,C),list(product_prod(B,C))),Uua)),Uu)) ).

% ATP.lambda_194
tff(fact_6187_ATP_Olambda__195,axiom,
    ! [Uu: code_natural,Uua: code_natural] : aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),aTP_Lamp_se(code_natural,fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)))),Uu),Uua) = aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),product_Pair(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),Uua),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),times_times(code_natural),Uu),aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2)))))))))))))))))))))))))))))))))) ).

% ATP.lambda_195
tff(fact_6188_ATP_Olambda__196,axiom,
    ! [B: $tType,Uu: fun(nat,set(B)),Uua: nat] : aa(nat,set(B),aTP_Lamp_jc(fun(nat,set(B)),fun(nat,set(B)),Uu),Uua) = aa(set(set(B)),set(B),complete_Sup_Sup(set(B)),aa(set(nat),set(set(B)),image2(nat,set(B),Uu),set_or7035219750837199246ssThan(nat,zero_zero(nat),Uua))) ).

% ATP.lambda_196
tff(fact_6189_ATP_Olambda__197,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: B,Uua: nat] : aa(nat,fun(B,B),aTP_Lamp_eg(B,fun(nat,fun(B,B)),Uu),Uua) = aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),minus_minus(B),Uu),aa(nat,B,semiring_1_of_nat(B),Uua))) ) ).

% ATP.lambda_197
tff(fact_6190_ATP_Olambda__198,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Uu: B,Uua: nat] : aa(nat,fun(B,B),aTP_Lamp_ez(B,fun(nat,fun(B,B)),Uu),Uua) = aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(nat,B,semiring_1_of_nat(B),Uua))) ) ).

% ATP.lambda_198
tff(fact_6191_ATP_Olambda__199,axiom,
    ! [B: $tType,Uu: list(B),Uua: code_natural] : aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural))),aTP_Lamp_ta(list(B),fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural)))),Uu),Uua) = aa(B,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural))),product_Pair(B,product_prod(code_natural,code_natural)),aa(nat,B,nth(B,Uu),aa(code_natural,nat,code_nat_of_natural,Uua))) ).

% ATP.lambda_199
tff(fact_6192_ATP_Olambda__200,axiom,
    ! [B: $tType] :
      ( sup(B)
     => ! [Uu: B,Uua: B] : aa(B,option(B),aTP_Lamp_kq(B,fun(B,option(B)),Uu),Uua) = aa(B,option(B),some(B),aa(B,B,aa(B,fun(B,B),sup_sup(B),Uu),Uua)) ) ).

% ATP.lambda_200
tff(fact_6193_ATP_Olambda__201,axiom,
    ! [B: $tType] :
      ( inf(B)
     => ! [Uu: B,Uua: B] : aa(B,option(B),aTP_Lamp_mr(B,fun(B,option(B)),Uu),Uua) = aa(B,option(B),some(B),aa(B,B,inf_inf(B,Uu),Uua)) ) ).

% ATP.lambda_201
tff(fact_6194_ATP_Olambda__202,axiom,
    ! [Uu: code_natural,Uua: code_natural] : aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),aTP_Lamp_sg(code_natural,fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)))),Uu),Uua) = aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural))),product_Pair(code_natural,product_prod(code_natural,code_natural)),aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),modulo_modulo(code_natural),Uua),Uu)) ).

% ATP.lambda_202
tff(fact_6195_ATP_Olambda__203,axiom,
    ! [B: $tType,Uu: pred(B),Uua: pred(B)] : aa(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aTP_Lamp_ui(pred(B),fun(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uu),Uua) = aa(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),product_Pair(pred(B),product_prod(code_natural,code_natural)),aa(pred(B),pred(B),aa(pred(B),fun(pred(B),pred(B)),sup_sup(pred(B)),Uu),Uua)) ).

% ATP.lambda_203
tff(fact_6196_ATP_Olambda__204,axiom,
    ! [B: $tType,Uu: list(product_prod(code_natural,B)),Uua: code_natural] : aa(code_natural,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural))),aTP_Lamp_sz(list(product_prod(code_natural,B)),fun(code_natural,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural)))),Uu),Uua) = aa(B,fun(product_prod(code_natural,code_natural),product_prod(B,product_prod(code_natural,code_natural))),product_Pair(B,product_prod(code_natural,code_natural)),pick(B,Uu,Uua)) ).

% ATP.lambda_204
tff(fact_6197_ATP_Olambda__205,axiom,
    ! [C: $tType,B: $tType,Uu: list(product_prod(B,C)),Uua: B] : aa(B,C,aTP_Lamp_rz(list(product_prod(B,C)),fun(B,C),Uu),Uua) = aa(option(C),C,the2(C),aa(B,option(C),map_of(B,C,Uu),Uua)) ).

% ATP.lambda_205
tff(fact_6198_ATP_Olambda__206,axiom,
    ! [C: $tType,B: $tType,Uu: C,Uua: B] : aa(B,fun(set(product_prod(C,B)),set(product_prod(C,B))),aTP_Lamp_kv(C,fun(B,fun(set(product_prod(C,B)),set(product_prod(C,B)))),Uu),Uua) = insert2(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Uu),Uua)) ).

% ATP.lambda_206
tff(fact_6199_ATP_Olambda__207,axiom,
    ! [B: $tType,C: $tType,Uu: B,Uua: C] : aa(C,fun(set(product_prod(B,C)),set(product_prod(B,C))),aTP_Lamp_ky(B,fun(C,fun(set(product_prod(B,C)),set(product_prod(B,C)))),Uu),Uua) = insert2(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uu),Uua)) ).

% ATP.lambda_207
tff(fact_6200_ATP_Olambda__208,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: B,Uua: B] :
          ( aa(B,$o,aTP_Lamp_te(B,fun(B,$o),Uu),Uua)
        <=> ~ aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Uu),Uua) ) ) ).

% ATP.lambda_208
tff(fact_6201_ATP_Olambda__209,axiom,
    ! [B: $tType,Uu: B,Uua: B] :
      ( aa(B,$o,aTP_Lamp_qy(B,fun(B,$o),Uu),Uua)
    <=> ( Uua != Uu ) ) ).

% ATP.lambda_209
tff(fact_6202_ATP_Olambda__210,axiom,
    ! [B: $tType,Uu: B,Uua: B] : aa(B,set(B),aTP_Lamp_na(B,fun(B,set(B)),Uu),Uua) = aa(set(B),set(B),uminus_uminus(set(B)),aa(set(B),set(B),insert2(B,Uu),bot_bot(set(B)))) ).

% ATP.lambda_210
tff(fact_6203_ATP_Olambda__211,axiom,
    ! [Uu: nat,Uua: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_mt(nat,fun(heap_ext(product_unit),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),Uu),Uua) = aa(product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),option(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),some(product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),aa(product_unit,fun(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),product_Pair(product_unit,product_prod(heap_ext(product_unit),nat)),product_Unity),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uua),Uu))) ).

% ATP.lambda_211
tff(fact_6204_ATP_Olambda__212,axiom,
    ! [D: $tType,C: $tType,Uu: fun(C,set(D)),Uua: C] : aa(C,set(product_prod(D,D)),aTP_Lamp_vd(fun(C,set(D)),fun(C,set(product_prod(D,D))),Uu),Uua) = bNF_Ca6860139660246222851ard_of(D,aa(C,set(D),Uu,Uua)) ).

% ATP.lambda_212
tff(fact_6205_ATP_Olambda__213,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(C)),Uua: B] : aa(B,set(product_prod(C,C)),aTP_Lamp_ve(fun(B,set(C)),fun(B,set(product_prod(C,C))),Uu),Uua) = bNF_Ca6860139660246222851ard_of(C,aa(B,set(C),Uu,Uua)) ).

% ATP.lambda_213
tff(fact_6206_ATP_Olambda__214,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(product_prod(C,C))),Uua: B] : aa(B,set(product_prod(C,C)),aTP_Lamp_nt(fun(B,set(product_prod(C,C))),fun(B,set(product_prod(C,C))),Uu),Uua) = transitive_trancl(C,aa(B,set(product_prod(C,C)),Uu,Uua)) ).

% ATP.lambda_214
tff(fact_6207_ATP_Olambda__215,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,fun(B,B),aTP_Lamp_fw(fun(nat,B),fun(nat,fun(B,B)),Uu),Uua) = aa(B,fun(B,B),times_times(B),aa(nat,B,Uu,Uua)) ) ).

% ATP.lambda_215
tff(fact_6208_ATP_Olambda__216,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,B),Uua: C] : aa(C,heap_Time_Heap(B),aTP_Lamp_ap(fun(C,B),fun(C,heap_Time_Heap(B)),Uu),Uua) = aa(B,heap_Time_Heap(B),heap_Time_return(B),aa(C,B,Uu,Uua)) ).

% ATP.lambda_216
tff(fact_6209_ATP_Olambda__217,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat] : aa(nat,fun(B,B),aTP_Lamp_bw(fun(nat,B),fun(nat,fun(B,B)),Uu),Uua) = aa(B,fun(B,B),plus_plus(B),aa(nat,B,Uu,Uua)) ) ).

% ATP.lambda_217
tff(fact_6210_ATP_Olambda__218,axiom,
    ! [B: $tType,C: $tType] :
      ( comple6319245703460814977attice(B)
     => ! [Uu: fun(C,B),Uua: C] : aa(C,option(B),aTP_Lamp_ja(fun(C,B),fun(C,option(B)),Uu),Uua) = aa(B,option(B),some(B),aa(C,B,Uu,Uua)) ) ).

% ATP.lambda_218
tff(fact_6211_ATP_Olambda__219,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,B),Uua: C] : aa(C,option(B),aTP_Lamp_ax(fun(C,B),fun(C,option(B)),Uu),Uua) = aa(B,option(B),some(B),aa(C,B,Uu,Uua)) ).

% ATP.lambda_219
tff(fact_6212_ATP_Olambda__220,axiom,
    ! [C: $tType,B: $tType] :
      ( comple6319245703460814977attice(C)
     => ! [Uu: fun(B,C),Uua: B] : aa(B,option(C),aTP_Lamp_jb(fun(B,C),fun(B,option(C)),Uu),Uua) = aa(C,option(C),some(C),aa(B,C,Uu,Uua)) ) ).

% ATP.lambda_220
tff(fact_6213_ATP_Olambda__221,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,C),Uua: B] : aa(B,option(C),aTP_Lamp_nv(fun(B,C),fun(B,option(C)),Uu),Uua) = aa(C,option(C),some(C),aa(B,C,Uu,Uua)) ).

% ATP.lambda_221
tff(fact_6214_ATP_Olambda__222,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(D,B),Uua: D] : aa(D,fun(C,product_prod(B,C)),aTP_Lamp_qu(fun(D,B),fun(D,fun(C,product_prod(B,C))),Uu),Uua) = aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,Uu,Uua)) ).

% ATP.lambda_222
tff(fact_6215_ATP_Olambda__223,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: fun(B,C),Uua: B] : aa(B,fun(D,product_prod(C,D)),aTP_Lamp_oc(fun(B,C),fun(B,fun(D,product_prod(C,D))),Uu),Uua) = aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(B,C,Uu,Uua)) ).

% ATP.lambda_223
tff(fact_6216_ATP_Olambda__224,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,fun(C,$o)),Uua: B] : aa(B,set(C),aTP_Lamp_jx(fun(B,fun(C,$o)),fun(B,set(C)),Uu),Uua) = aa(fun(C,$o),set(C),collect(C),aa(B,fun(C,$o),Uu,Uua)) ).

% ATP.lambda_224
tff(fact_6217_ATP_Olambda__225,axiom,
    ! [B: $tType,Uu: fun(B,nat),Uua: B] : aa(B,nat,aTP_Lamp_id(fun(B,nat),fun(B,nat),Uu),Uua) = aa(nat,nat,suc,aa(B,nat,Uu,Uua)) ).

% ATP.lambda_225
tff(fact_6218_ATP_Olambda__226,axiom,
    ! [C: $tType,Uu: fun(C,$o),Uua: C] :
      ( aa(C,$o,aTP_Lamp_wy(fun(C,$o),fun(C,$o),Uu),Uua)
    <=> ~ aa(C,$o,Uu,Uua) ) ).

% ATP.lambda_226
tff(fact_6219_ATP_Olambda__227,axiom,
    ! [B: $tType,Uu: fun(B,$o),Uua: B] :
      ( aa(B,$o,aTP_Lamp_ol(fun(B,$o),fun(B,$o),Uu),Uua)
    <=> ~ aa(B,$o,Uu,Uua) ) ).

% ATP.lambda_227
tff(fact_6220_ATP_Olambda__228,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,fun(C,$o)),Uua: B] :
      ( aa(B,$o,aTP_Lamp_tc(fun(B,fun(C,$o)),fun(B,$o),Uu),Uua)
    <=> ? [X_1: C] : aa(C,$o,aa(B,fun(C,$o),Uu,Uua),X_1) ) ).

% ATP.lambda_228
tff(fact_6221_ATP_Olambda__229,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,fun(C,$o)),Uua: C] :
      ( aa(C,$o,aTP_Lamp_td(fun(B,fun(C,$o)),fun(C,$o),Uu),Uua)
    <=> ? [A7: B] : aa(C,$o,aa(B,fun(C,$o),Uu,A7),Uua) ) ).

% ATP.lambda_229
tff(fact_6222_ATP_Olambda__230,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B)] :
      ( aa(set(B),$o,aTP_Lamp_sr(set(product_prod(B,B)),fun(set(B),$o),Uu),Uua)
    <=> ! [X4: B] :
          ( member(B,X4,Uua)
         => ! [Xa2: B] :
              ( member(B,Xa2,Uua)
             => ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),Uu)
                | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),Uu) ) ) ) ) ).

% ATP.lambda_230
tff(fact_6223_ATP_Olambda__231,axiom,
    ! [C: $tType,B: $tType,Uu: set(product_prod(B,C)),Uua: B] :
      ( aa(B,$o,aTP_Lamp_tt(set(product_prod(B,C)),fun(B,$o),Uu),Uua)
    <=> ? [Y3: C] : member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),Y3),Uu) ) ).

% ATP.lambda_231
tff(fact_6224_ATP_Olambda__232,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,heap_Time_Heap(C)),Uua: fun(B,heap_Time_Heap(C))] :
      ( aa(fun(B,heap_Time_Heap(C)),$o,aTP_Lamp_yd(fun(B,heap_Time_Heap(C)),fun(fun(B,heap_Time_Heap(C)),$o),Uu),Uua)
    <=> ! [X4: B] : refine_Imp_refines(C,aa(B,heap_Time_Heap(C),Uu,X4),aa(B,heap_Time_Heap(C),Uua,X4)) ) ).

% ATP.lambda_232
tff(fact_6225_ATP_Olambda__233,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,option(B)),Uua: B] :
      ( aa(B,$o,aTP_Lamp_lp(fun(C,option(B)),fun(B,$o),Uu),Uua)
    <=> ? [A7: C] : aa(C,option(B),Uu,A7) = aa(B,option(B),some(B),Uua) ) ).

% ATP.lambda_233
tff(fact_6226_ATP_Olambda__234,axiom,
    ! [B: $tType,C: $tType,Uu: B,Uua: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aTP_Lamp_lw(B,fun(product_prod(B,C),$o),Uu),Uua)
    <=> ? [V7: C] : Uua = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uu),V7) ) ).

% ATP.lambda_234
tff(fact_6227_ATP_Olambda__235,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,fun(C,$o)),Uua: fun(B,option(C))] :
      ( aa(fun(B,option(C)),$o,aTP_Lamp_xr(fun(B,fun(C,$o)),fun(fun(B,option(C)),$o),Uu),Uua)
    <=> ! [X4: B,Y3: C] :
          ( ( aa(B,option(C),Uua,X4) = aa(C,option(C),some(C),Y3) )
         => aa(C,$o,aa(B,fun(C,$o),Uu,X4),Y3) ) ) ).

% ATP.lambda_235
tff(fact_6228_ATP_Olambda__236,axiom,
    ! [C: $tType,B: $tType,Uu: set(product_prod(B,C)),Uua: product_prod(product_prod($o,B),product_prod($o,C))] :
      ( aa(product_prod(product_prod($o,B),product_prod($o,C)),$o,aTP_Lamp_lx(set(product_prod(B,C)),fun(product_prod(product_prod($o,B),product_prod($o,C)),$o),Uu),Uua)
    <=> ? [X4: B,Y3: C] :
          ( ( Uua = aa(product_prod($o,C),product_prod(product_prod($o,B),product_prod($o,C)),aa(product_prod($o,B),fun(product_prod($o,C),product_prod(product_prod($o,B),product_prod($o,C))),product_Pair(product_prod($o,B),product_prod($o,C)),aa(B,product_prod($o,B),aa($o,fun(B,product_prod($o,B)),product_Pair($o,B),$false),X4)),aa(C,product_prod($o,C),aa($o,fun(C,product_prod($o,C)),product_Pair($o,C),$false),Y3)) )
          & member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),X4),Y3),Uu) ) ) ).

% ATP.lambda_236
tff(fact_6229_ATP_Olambda__237,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,option(C)),Uua: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aTP_Lamp_lu(fun(B,option(C)),fun(product_prod(B,C),$o),Uu),Uua)
    <=> ? [A7: B,B7: C] :
          ( ( Uua = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A7),B7) )
          & ( aa(B,option(C),Uu,A7) = aa(C,option(C),some(C),B7) ) ) ) ).

% ATP.lambda_237
tff(fact_6230_ATP_Olambda__238,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: product_prod(set(B),set(B))] :
      ( aa(product_prod(set(B),set(B)),$o,aTP_Lamp_sp(set(product_prod(B,B)),fun(product_prod(set(B),set(B)),$o),Uu),Uua)
    <=> ? [X9: set(B),Y8: set(B)] :
          ( ( Uua = aa(set(B),product_prod(set(B),set(B)),aa(set(B),fun(set(B),product_prod(set(B),set(B))),product_Pair(set(B),set(B)),X9),Y8) )
          & ( X9 != bot_bot(set(B)) )
          & ! [X4: B] :
              ( member(B,X4,Y8)
             => ? [Xa2: B] :
                  ( member(B,Xa2,X9)
                  & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Xa2),X4),Uu) ) ) ) ) ).

% ATP.lambda_238
tff(fact_6231_ATP_Olambda__239,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))))),Uua: fun(B,heap_Time_Heap(C))] :
      ( aa(fun(B,heap_Time_Heap(C)),$o,aTP_Lamp_yh(fun(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))))),fun(fun(B,heap_Time_Heap(C)),$o),Uu),Uua)
    <=> ! [X4: B,H6: heap_ext(product_unit),H7: heap_ext(product_unit),R5: C,N7: nat] :
          ( heap_Time_effect(C,aa(B,heap_Time_Heap(C),Uua,X4),H6,H7,R5,N7)
         => aa(nat,$o,aa(C,fun(nat,$o),aa(heap_ext(product_unit),fun(C,fun(nat,$o)),aa(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o))),aa(B,fun(heap_ext(product_unit),fun(heap_ext(product_unit),fun(C,fun(nat,$o)))),Uu,X4),H6),H7),R5),N7) ) ) ).

% ATP.lambda_239
tff(fact_6232_ATP_Olambda__240,axiom,
    ! [B: $tType,C: $tType,Uu: set(C),Uua: B] : aa(B,set(C),aTP_Lamp_jo(set(C),fun(B,set(C)),Uu),Uua) = aa(set(C),set(C),uminus_uminus(set(C)),Uu) ).

% ATP.lambda_240
tff(fact_6233_ATP_Olambda__241,axiom,
    ! [B: $tType,Uu: set(B),Uua: B] : aa(B,set(B),aTP_Lamp_np(set(B),fun(B,set(B)),Uu),Uua) = aa(set(B),set(B),uminus_uminus(set(B)),Uu) ).

% ATP.lambda_241
tff(fact_6234_ATP_Olambda__242,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B),Uua: array(B)] : aa(array(B),heap_Time_Heap(array(B)),aTP_Lamp_rv(array(B),fun(array(B),heap_Time_Heap(array(B))),Uu),Uua) = aa(array(B),heap_Time_Heap(array(B)),heap_Time_ureturn(array(B)),Uu) ) ).

% ATP.lambda_242
tff(fact_6235_ATP_Olambda__243,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: B,Uua: product_unit] : aa(product_unit,heap_Time_Heap(B),aTP_Lamp_bb(B,fun(product_unit,heap_Time_Heap(B)),Uu),Uua) = aa(B,heap_Time_Heap(B),heap_Time_return(B),Uu) ) ).

% ATP.lambda_243
tff(fact_6236_ATP_Olambda__244,axiom,
    ! [B: $tType,Uu: B,Uua: list(B)] : aa(list(B),option(B),aa(B,fun(list(B),option(B)),aTP_Lamp_sa(B,fun(list(B),option(B))),Uu),Uua) = aa(B,option(B),some(B),Uu) ).

% ATP.lambda_244
tff(fact_6237_ATP_Olambda__245,axiom,
    ! [D: $tType,C: $tType,Uu: set(product_prod(C,C)),Uua: D] : aa(D,set(C),aTP_Lamp_uz(set(product_prod(C,C)),fun(D,set(C)),Uu),Uua) = field2(C,Uu) ).

% ATP.lambda_245
tff(fact_6238_ATP_Olambda__246,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(C,C)),Uua: B] : aa(B,set(C),aTP_Lamp_vc(set(product_prod(C,C)),fun(B,set(C)),Uu),Uua) = field2(C,Uu) ).

% ATP.lambda_246
tff(fact_6239_ATP_Olambda__247,axiom,
    ! [D: $tType,B: $tType,Uu: set(product_prod(B,B)),Uua: D] : aa(D,set(B),aTP_Lamp_uy(set(product_prod(B,B)),fun(D,set(B)),Uu),Uua) = field2(B,Uu) ).

% ATP.lambda_247
tff(fact_6240_ATP_Olambda__248,axiom,
    ! [C: $tType,B: $tType,Uu: set(product_prod(B,B)),Uua: C] : aa(C,set(B),aTP_Lamp_vb(set(product_prod(B,B)),fun(C,set(B)),Uu),Uua) = field2(B,Uu) ).

% ATP.lambda_248
tff(fact_6241_ATP_Olambda__249,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B] : aa(B,set(B),aTP_Lamp_kw(set(product_prod(B,B)),fun(B,set(B)),Uu),Uua) = field2(B,Uu) ).

% ATP.lambda_249
tff(fact_6242_ATP_Olambda__250,axiom,
    ! [B: $tType,C: $tType,Uu: list(C),Uua: B] : aa(B,set(C),aTP_Lamp_qn(list(C),fun(B,set(C)),Uu),Uua) = aa(list(C),set(C),set2(C),Uu) ).

% ATP.lambda_250
tff(fact_6243_ATP_Olambda__251,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,$o),Uua: B] : aa(B,set(C),aTP_Lamp_jk(fun(C,$o),fun(B,set(C)),Uu),Uua) = aa(fun(C,$o),set(C),collect(C),Uu) ).

% ATP.lambda_251
tff(fact_6244_ATP_Olambda__252,axiom,
    ! [B: $tType,Uu: nat,Uua: B] : aa(B,nat,aa(nat,fun(B,nat),aTP_Lamp_ok(nat,fun(B,nat)),Uu),Uua) = aa(nat,nat,suc,Uu) ).

% ATP.lambda_252
tff(fact_6245_ATP_Olambda__253,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,fun(C,$o)),Uua: option(B),Uub: option(C)] :
      ( aa(option(C),$o,aa(option(B),fun(option(C),$o),aTP_Lamp_ty(fun(B,fun(C,$o)),fun(option(B),fun(option(C),$o)),Uu),Uua),Uub)
    <=> aa(option(B),$o,aa(fun(B,$o),fun(option(B),$o),aa($o,fun(fun(B,$o),fun(option(B),$o)),case_option($o,B),aa(option(C),$o,aa(fun(C,$o),fun(option(C),$o),aa($o,fun(fun(C,$o),fun(option(C),$o)),case_option($o,C),$true),aTP_Lamp_tw(C,$o)),Uub)),aa(option(C),fun(B,$o),aTP_Lamp_tx(fun(B,fun(C,$o)),fun(option(C),fun(B,$o)),Uu),Uub)),Uua) ) ).

% ATP.lambda_253
tff(fact_6246_ATP_Olambda__254,axiom,
    ! [Uu: num,Uua: code_integer,Uub: code_integer] :
      aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_de(num,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),Uu),Uua),Uub) = $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less_eq(code_integer),aa(num,code_integer,numeral_numeral(code_integer),Uu)),Uub),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),plus_plus(code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))),Uua)),one_one(code_integer))),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),Uub),aa(num,code_integer,numeral_numeral(code_integer),Uu))),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),times_times(code_integer),aa(num,code_integer,numeral_numeral(code_integer),aa(num,num,bit0,one2))),Uua)),Uub)) ).

% ATP.lambda_254
tff(fact_6247_ATP_Olambda__255,axiom,
    ! [Uu: num,Uua: nat,Uub: nat] :
      aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),aTP_Lamp_cz(num,fun(nat,fun(nat,product_prod(nat,nat))),Uu),Uua),Uub) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(num,nat,numeral_numeral(nat),Uu)),Uub),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,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),aa(num,num,bit0,one2))),Uua)),one_one(nat))),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uub),aa(num,nat,numeral_numeral(nat),Uu))),aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uua)),Uub)) ).

% ATP.lambda_255
tff(fact_6248_ATP_Olambda__256,axiom,
    ! [Uu: num,Uua: int,Uub: int] :
      aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_da(num,fun(int,fun(int,product_prod(int,int))),Uu),Uua),Uub) = $ite(aa(int,$o,aa(int,fun(int,$o),ord_less_eq(int),aa(num,int,numeral_numeral(int),Uu)),Uub),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),Uua)),one_one(int))),aa(int,int,aa(int,fun(int,int),minus_minus(int),Uub),aa(num,int,numeral_numeral(int),Uu))),aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),times_times(int),aa(num,int,numeral_numeral(int),aa(num,num,bit0,one2))),Uua)),Uub)) ).

% ATP.lambda_256
tff(fact_6249_ATP_Olambda__257,axiom,
    ! [B: $tType] :
      ( unique1627219031080169319umeral(B)
     => ! [Uu: num,Uua: B,Uub: B] :
          aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),aTP_Lamp_cy(num,fun(B,fun(B,product_prod(B,B))),Uu),Uua),Uub) = $ite(aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),aa(num,B,numeral_numeral(B),Uu)),Uub),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Uua)),one_one(B))),aa(B,B,aa(B,fun(B,B),minus_minus(B),Uub),aa(num,B,numeral_numeral(B),Uu))),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(num,B,numeral_numeral(B),aa(num,num,bit0,one2))),Uua)),Uub)) ) ).

% ATP.lambda_257
tff(fact_6250_ATP_Olambda__258,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(B,C),Uua: set(B),Uub: B] :
          aa(B,C,aa(set(B),fun(B,C),aTP_Lamp_mu(fun(B,C),fun(set(B),fun(B,C)),Uu),Uua),Uub) = $ite(member(B,Uub,Uua),aa(B,C,Uu,Uub),one_one(C)) ) ).

% ATP.lambda_258
tff(fact_6251_ATP_Olambda__259,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: B,Uua: fun(B,C),Uub: B] :
          aa(B,C,aa(fun(B,C),fun(B,C),aTP_Lamp_hr(B,fun(fun(B,C),fun(B,C)),Uu),Uua),Uub) = $ite(Uu = Uub,aa(B,C,Uua,Uub),one_one(C)) ) ).

% ATP.lambda_259
tff(fact_6252_ATP_Olambda__260,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: B,Uua: fun(B,C),Uub: B] :
          aa(B,C,aa(fun(B,C),fun(B,C),aTP_Lamp_hq(B,fun(fun(B,C),fun(B,C)),Uu),Uua),Uub) = $ite(Uub = Uu,aa(B,C,Uua,Uub),one_one(C)) ) ).

% ATP.lambda_260
tff(fact_6253_ATP_Olambda__261,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: C,Uua: B,Uub: C] :
          aa(C,B,aa(B,fun(C,B),aTP_Lamp_tj(C,fun(B,fun(C,B)),Uu),Uua),Uub) = $ite(Uu = Uub,Uua,one_one(B)) ) ).

% ATP.lambda_261
tff(fact_6254_ATP_Olambda__262,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: C,Uua: B,Uub: C] :
          aa(C,B,aa(B,fun(C,B),aTP_Lamp_tk(C,fun(B,fun(C,B)),Uu),Uua),Uub) = $ite(Uub = Uu,Uua,one_one(B)) ) ).

% ATP.lambda_262
tff(fact_6255_ATP_Olambda__263,axiom,
    ! [Uu: code_integer,Uua: code_integer,Uub: code_integer] :
      aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_gb(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),Uu),Uua),Uub) = $ite(Uub = zero_zero(code_integer),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),zero_zero(code_integer)),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),one_one(code_integer))),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uu)),Uub))) ).

% ATP.lambda_263
tff(fact_6256_ATP_Olambda__264,axiom,
    ! [Uu: code_integer,Uua: code_integer,Uub: code_integer] :
      aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_fi(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),Uu),Uua),Uub) = $ite(Uub = zero_zero(code_integer),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),zero_zero(code_integer)),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),one_one(code_integer))),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,abs_abs(code_integer),Uu)),Uub))) ).

% ATP.lambda_264
tff(fact_6257_ATP_Olambda__265,axiom,
    ! [Uu: code_integer,Uua: code_integer,Uub: code_integer] :
      aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),aTP_Lamp_ga(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,code_integer))),Uu),Uua),Uub) = $ite(Uub = zero_zero(code_integer),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),zero_zero(code_integer)),aa(code_integer,product_prod(code_integer,code_integer),aa(code_integer,fun(code_integer,product_prod(code_integer,code_integer)),product_Pair(code_integer,code_integer),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),one_one(code_integer))),aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),Uu),Uub))) ).

% ATP.lambda_265
tff(fact_6258_ATP_Olambda__266,axiom,
    ! [B: $tType,Uu: fun(B,$o),Uua: B,Uub: list(B)] :
      aa(list(B),list(B),aa(B,fun(list(B),list(B)),aTP_Lamp_pe(fun(B,$o),fun(B,fun(list(B),list(B))),Uu),Uua),Uub) = $ite(aa(B,$o,Uu,Uua),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uua),Uub),Uub) ).

% ATP.lambda_266
tff(fact_6259_ATP_Olambda__267,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(B,C),Uua: fun(B,$o),Uub: B] :
          aa(B,C,aa(fun(B,$o),fun(B,C),aTP_Lamp_ib(fun(B,C),fun(fun(B,$o),fun(B,C)),Uu),Uua),Uub) = $ite(aa(B,$o,Uua,Uub),aa(B,C,Uu,Uub),one_one(C)) ) ).

% ATP.lambda_267
tff(fact_6260_ATP_Olambda__268,axiom,
    ! [B: $tType,Uu: fun(heap_ext(product_unit),$o),Uua: fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),Uub: heap_ext(product_unit)] :
      aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_aq(fun(heap_ext(product_unit),$o),fun(fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),Uu),Uua),Uub) = $ite(aa(heap_ext(product_unit),$o,Uu,Uub),aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),Uua,Uub)),none(product_prod(B,product_prod(heap_ext(product_unit),nat)))) ).

% ATP.lambda_268
tff(fact_6261_ATP_Olambda__269,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,B),Uua: fun(C,$o),Uub: C] :
      aa(C,option(B),aa(fun(C,$o),fun(C,option(B)),aTP_Lamp_op(fun(C,B),fun(fun(C,$o),fun(C,option(B))),Uu),Uua),Uub) = $ite(aa(C,$o,Uua,Uub),aa(B,option(B),some(B),aa(C,B,Uu,Uub)),none(B)) ).

% ATP.lambda_269
tff(fact_6262_ATP_Olambda__270,axiom,
    ! [B: $tType,C: $tType,Uu: set(C),Uua: B,Uub: set(product_prod(B,C))] : aa(set(product_prod(B,C)),set(product_prod(B,C)),aa(B,fun(set(product_prod(B,C)),set(product_prod(B,C))),aTP_Lamp_kz(set(C),fun(B,fun(set(product_prod(B,C)),set(product_prod(B,C)))),Uu),Uua),Uub) = finite_fold(C,set(product_prod(B,C)),aTP_Lamp_ky(B,fun(C,fun(set(product_prod(B,C)),set(product_prod(B,C)))),Uua),Uub,Uu) ).

% ATP.lambda_270
tff(fact_6263_ATP_Olambda__271,axiom,
    ! [C: $tType,B: $tType,Uu: set(B),Uua: C,Uub: set(product_prod(C,B))] : aa(set(product_prod(C,B)),set(product_prod(C,B)),aa(C,fun(set(product_prod(C,B)),set(product_prod(C,B))),aTP_Lamp_lh(set(B),fun(C,fun(set(product_prod(C,B)),set(product_prod(C,B)))),Uu),Uua),Uub) = finite_fold(B,set(product_prod(C,B)),aTP_Lamp_kv(C,fun(B,fun(set(product_prod(C,B)),set(product_prod(C,B)))),Uua),Uub,Uu) ).

% ATP.lambda_271
tff(fact_6264_ATP_Olambda__272,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: option(B),Uub: B] : aa(B,option(B),aa(option(B),fun(B,option(B)),aTP_Lamp_aj(fun(B,fun(B,B)),fun(option(B),fun(B,option(B))),Uu),Uua),Uub) = aa(option(B),option(B),aa(fun(B,option(B)),fun(option(B),option(B)),aa(option(B),fun(fun(B,option(B)),fun(option(B),option(B))),case_option(option(B),B),aa(B,option(B),some(B),Uub)),aa(B,fun(B,option(B)),aTP_Lamp_ai(fun(B,fun(B,B)),fun(B,fun(B,option(B))),Uu),Uub)),Uua) ).

% ATP.lambda_272
tff(fact_6265_ATP_Olambda__273,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,$o)),Uua: list(B),Uub: list(B)] : aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),aTP_Lamp_pb(fun(B,fun(B,$o)),fun(list(B),fun(list(B),list(B))),Uu),Uua),Uub) = merges9089515139780605204_merge(B,Uu,aa(list(B),list(B),mergesort_by_rel(B,Uu),Uua),aa(list(B),list(B),mergesort_by_rel(B,Uu),Uub)) ).

% ATP.lambda_273
tff(fact_6266_ATP_Olambda__274,axiom,
    ! [B: $tType] :
      ( sup(B)
     => ! [Uu: option(B),Uua: option(B),Uub: B] : aa(B,option(B),aa(option(B),fun(B,option(B)),aTP_Lamp_kr(option(B),fun(option(B),fun(B,option(B))),Uu),Uua),Uub) = aa(option(B),option(B),aa(fun(B,option(B)),fun(option(B),option(B)),aa(option(B),fun(fun(B,option(B)),fun(option(B),option(B))),case_option(option(B),B),Uu),aTP_Lamp_kq(B,fun(B,option(B)),Uub)),Uua) ) ).

% ATP.lambda_274
tff(fact_6267_ATP_Olambda__275,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B),Uua: list(B),Uub: fun(typerep,fun(nat,list(nat)))] : aa(fun(typerep,fun(nat,list(nat))),fun(typerep,fun(nat,list(nat))),aa(list(B),fun(fun(typerep,fun(nat,list(nat))),fun(typerep,fun(nat,list(nat)))),aTP_Lamp_wg(array(B),fun(list(B),fun(fun(typerep,fun(nat,list(nat))),fun(typerep,fun(nat,list(nat))))),Uu),Uua),Uub) = fun_upd(typerep,fun(nat,list(nat)),Uub,typerep_typerep(B,type2(B)),fun_upd(nat,list(nat),aa(typerep,fun(nat,list(nat)),Uub,typerep_typerep(B,type2(B))),addr_of_array(B,Uu),aa(list(B),list(nat),map(B,nat,to_nat(B)),Uua))) ) ).

% ATP.lambda_275
tff(fact_6268_ATP_Olambda__276,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,option(C)),Uua: B,Uub: C] : aa(C,fun(B,option(C)),aa(B,fun(C,fun(B,option(C))),aTP_Lamp_qo(fun(B,option(C)),fun(B,fun(C,fun(B,option(C)))),Uu),Uua),Uub) = fun_upd(B,option(C),Uu,Uua,aa(C,option(C),some(C),Uub)) ).

% ATP.lambda_276
tff(fact_6269_ATP_Olambda__277,axiom,
    ! [B: $tType,C: $tType,Uu: B,Uua: C,Uub: fun(B,option(C))] : aa(fun(B,option(C)),fun(B,option(C)),aa(C,fun(fun(B,option(C)),fun(B,option(C))),aa(B,fun(C,fun(fun(B,option(C)),fun(B,option(C)))),aTP_Lamp_oj(B,fun(C,fun(fun(B,option(C)),fun(B,option(C))))),Uu),Uua),Uub) = fun_upd(B,option(C),Uub,Uu,aa(C,option(C),some(C),Uua)) ).

% ATP.lambda_277
tff(fact_6270_ATP_Olambda__278,axiom,
    ! [B: $tType,Uu: fun(B,B),Uua: B,Uub: nat] : aa(nat,B,aa(B,fun(nat,B),aTP_Lamp_tp(fun(B,B),fun(B,fun(nat,B)),Uu),Uua),Uub) = aa(B,B,compow(fun(B,B),Uub,Uu),Uua) ).

% ATP.lambda_278
tff(fact_6271_ATP_Olambda__279,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,fun(C,$o)),Uua: option(C),Uub: B] :
      ( aa(B,$o,aa(option(C),fun(B,$o),aTP_Lamp_tx(fun(B,fun(C,$o)),fun(option(C),fun(B,$o)),Uu),Uua),Uub)
    <=> aa(option(C),$o,aa(fun(C,$o),fun(option(C),$o),aa($o,fun(fun(C,$o),fun(option(C),$o)),case_option($o,C),$false),aa(B,fun(C,$o),Uu,Uub)),Uua) ) ).

% ATP.lambda_279
tff(fact_6272_ATP_Olambda__280,axiom,
    ! [B: $tType,C: $tType,Uu: heap_Time_Heap(C),Uua: fun(C,heap_Time_Heap(B)),Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(fun(C,heap_Time_Heap(B)),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_cn(heap_Time_Heap(C),fun(fun(C,heap_Time_Heap(B)),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),Uu),Uua),Uub) = aa(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),fun(fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(option(product_prod(C,product_prod(heap_ext(product_unit),nat))),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),case_option(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),product_prod(C,product_prod(heap_ext(product_unit),nat))),none(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(fun(C,fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),fun(product_prod(C,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),product_case_prod(C,product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_cl(fun(C,heap_Time_Heap(B)),fun(C,fun(product_prod(heap_ext(product_unit),nat),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),Uua))),aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(C),fun(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(C),Uu),Uub)) ).

% ATP.lambda_280
tff(fact_6273_ATP_Olambda__281,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: fun(nat,B),Uub: nat] : aa(nat,B,aa(fun(nat,B),fun(nat,B),aTP_Lamp_wt(fun(B,fun(B,B)),fun(fun(nat,B),fun(nat,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),Uu,aa(nat,B,Uua,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uub))),aa(nat,B,Uua,aa(nat,nat,suc,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2))),Uub)))) ).

% ATP.lambda_281
tff(fact_6274_ATP_Olambda__282,axiom,
    ! [E: $tType,D: $tType,C: $tType,B: $tType,Uu: fun(E,fun(C,D)),Uua: fun(B,E),Uub: product_prod(B,C)] : aa(product_prod(B,C),D,aa(fun(B,E),fun(product_prod(B,C),D),aTP_Lamp_iq(fun(E,fun(C,D)),fun(fun(B,E),fun(product_prod(B,C),D)),Uu),Uua),Uub) = aa(C,D,aa(E,fun(C,D),Uu,aa(B,E,Uua,aa(product_prod(B,C),B,product_fst(B,C),Uub))),aa(product_prod(B,C),C,product_snd(B,C),Uub)) ).

% ATP.lambda_282
tff(fact_6275_ATP_Olambda__283,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_gj(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(nat,fun(nat,B),Uu,Uub),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),Uub)) ) ).

% ATP.lambda_283
tff(fact_6276_ATP_Olambda__284,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_dt(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(nat,fun(nat,B),Uu,Uub),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),Uub)) ) ).

% ATP.lambda_284
tff(fact_6277_ATP_Olambda__285,axiom,
    ! [B: $tType,Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_wu(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(nat,fun(nat,B),Uu,Uub),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),Uub)) ).

% ATP.lambda_285
tff(fact_6278_ATP_Olambda__286,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_fs(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(nat,fun(nat,B),Uu,Uub),Uua) ) ).

% ATP.lambda_286
tff(fact_6279_ATP_Olambda__287,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_eo(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(nat,fun(nat,B),Uu,Uub),Uua) ) ).

% ATP.lambda_287
tff(fact_6280_ATP_Olambda__288,axiom,
    ! [B: $tType,Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_wn(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(nat,fun(nat,B),Uu,Uub),Uua) ).

% ATP.lambda_288
tff(fact_6281_ATP_Olambda__289,axiom,
    ! [C: $tType,B: $tType,Uu: fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),Uua: B,Uub: fun(B,heap_Time_Heap(C))] : aa(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C),aa(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)),aTP_Lamp_yg(fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))),Uu),Uua),Uub) = aa(B,heap_Time_Heap(C),aa(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)),Uu,Uub),Uua) ).

% ATP.lambda_289
tff(fact_6282_ATP_Olambda__290,axiom,
    ! [C: $tType,B: $tType,Uu: fun(fun(B,option(C)),fun(B,option(C))),Uua: B,Uub: fun(B,option(C))] : aa(fun(B,option(C)),option(C),aa(B,fun(fun(B,option(C)),option(C)),aTP_Lamp_xx(fun(fun(B,option(C)),fun(B,option(C))),fun(B,fun(fun(B,option(C)),option(C))),Uu),Uua),Uub) = aa(B,option(C),aa(fun(B,option(C)),fun(B,option(C)),Uu,Uub),Uua) ).

% ATP.lambda_290
tff(fact_6283_ATP_Olambda__291,axiom,
    ! [D: $tType,E: $tType,C: $tType,B: $tType,Uu: fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),Uua: fun(B,heap_Time_Heap(C)),Uub: D] : aa(D,heap_Time_Heap(E),aa(fun(B,heap_Time_Heap(C)),fun(D,heap_Time_Heap(E)),aTP_Lamp_xz(fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),fun(fun(B,heap_Time_Heap(C)),fun(D,heap_Time_Heap(E))),Uu),Uua),Uub) = aa(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E),aa(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E)),Uu,Uub),Uua) ).

% ATP.lambda_291
tff(fact_6284_ATP_Olambda__292,axiom,
    ! [D: $tType,E: $tType,C: $tType,B: $tType,Uu: fun(D,fun(fun(B,option(C)),option(E))),Uua: fun(B,option(C)),Uub: D] : aa(D,option(E),aa(fun(B,option(C)),fun(D,option(E)),aTP_Lamp_xs(fun(D,fun(fun(B,option(C)),option(E))),fun(fun(B,option(C)),fun(D,option(E))),Uu),Uua),Uub) = aa(fun(B,option(C)),option(E),aa(D,fun(fun(B,option(C)),option(E)),Uu,Uub),Uua) ).

% ATP.lambda_292
tff(fact_6285_ATP_Olambda__293,axiom,
    ! [D: $tType,B: $tType,C: $tType,Uu: fun(D,fun(C,B)),Uua: C,Uub: D] : aa(D,B,aa(C,fun(D,B),aTP_Lamp_mf(fun(D,fun(C,B)),fun(C,fun(D,B)),Uu),Uua),Uub) = aa(C,B,aa(D,fun(C,B),Uu,Uub),Uua) ).

% ATP.lambda_293
tff(fact_6286_ATP_Olambda__294,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,fun(B,$o)),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_tf(fun(C,fun(B,$o)),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> aa(B,$o,aa(C,fun(B,$o),Uu,Uub),Uua) ) ).

% ATP.lambda_294
tff(fact_6287_ATP_Olambda__295,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,fun(C,C)),Uua: C,Uub: B] : aa(B,C,aa(C,fun(B,C),aTP_Lamp_om(fun(B,fun(C,C)),fun(C,fun(B,C)),Uu),Uua),Uub) = aa(C,C,aa(B,fun(C,C),Uu,Uub),Uua) ).

% ATP.lambda_295
tff(fact_6288_ATP_Olambda__296,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,$o)),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_rf(fun(B,fun(B,$o)),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> aa(B,$o,aa(B,fun(B,$o),Uu,Uub),Uua) ) ).

% ATP.lambda_296
tff(fact_6289_ATP_Olambda__297,axiom,
    ! [Uu: code_integer,Uua: code_integer,Uub: code_integer] :
      aa(code_integer,product_prod(code_integer,$o),aa(code_integer,fun(code_integer,product_prod(code_integer,$o)),aTP_Lamp_gc(code_integer,fun(code_integer,fun(code_integer,product_prod(code_integer,$o))),Uu),Uua),Uub) = aa($o,product_prod(code_integer,$o),
        aa(code_integer,fun($o,product_prod(code_integer,$o)),product_Pair(code_integer,$o),
          $ite(aa(code_integer,$o,aa(code_integer,fun(code_integer,$o),ord_less(code_integer),zero_zero(code_integer)),Uu),Uua,aa(code_integer,code_integer,aa(code_integer,fun(code_integer,code_integer),minus_minus(code_integer),aa(code_integer,code_integer,uminus_uminus(code_integer),Uua)),Uub))),
        Uub = one_one(code_integer)) ).

% ATP.lambda_297
tff(fact_6290_ATP_Olambda__298,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_ft(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),aa(nat,fun(nat,B),aTP_Lamp_fs(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uub)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,Uub),Uua)) ) ).

% ATP.lambda_298
tff(fact_6291_ATP_Olambda__299,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,fun(nat,B)),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_ep(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),aa(nat,fun(nat,B),aTP_Lamp_eo(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uu),Uub)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,Uub),Uua)) ) ).

% ATP.lambda_299
tff(fact_6292_ATP_Olambda__300,axiom,
    ! [Uu: product_prod(code_natural,code_natural),Uua: code_natural,Uub: code_natural] : aa(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),aa(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),aTP_Lamp_sc(product_prod(code_natural,code_natural),fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)))),Uu),Uua),Uub) = aa(product_prod(code_natural,code_natural),product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),aa(fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)))),fun(product_prod(code_natural,code_natural),product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),product_case_prod(code_natural,code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),aa(code_natural,fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)))),aTP_Lamp_sb(code_natural,fun(code_natural,fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))))),Uua),Uub)),aa(product_prod(code_natural,product_prod(code_natural,code_natural)),product_prod(code_natural,code_natural),product_snd(code_natural,product_prod(code_natural,code_natural)),aa(product_prod(code_natural,code_natural),product_prod(code_natural,product_prod(code_natural,code_natural)),next,Uu))) ).

% ATP.lambda_300
tff(fact_6293_ATP_Olambda__301,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uua: pred(C),Uub: product_prod(code_natural,code_natural)] : aa(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(pred(C),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aTP_Lamp_um(fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(pred(C),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uu),Uua),Uub) = aa(product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(fun(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural))),product_case_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aa(pred(C),fun(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),aTP_Lamp_ul(fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(pred(C),fun(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))))),Uu),Uua)),split_seed(Uub)) ).

% ATP.lambda_301
tff(fact_6294_ATP_Olambda__302,axiom,
    ! [Uu: rat,Uua: int,Uub: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_hc(rat,fun(int,fun(int,product_prod(int,int))),Uu),Uua),Uub) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_hb(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uua),Uub)),quotient_of(Uu)) ).

% ATP.lambda_302
tff(fact_6295_ATP_Olambda__303,axiom,
    ! [Uu: rat,Uua: int,Uub: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_ha(rat,fun(int,fun(int,product_prod(int,int))),Uu),Uua),Uub) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_gz(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uua),Uub)),quotient_of(Uu)) ).

% ATP.lambda_303
tff(fact_6296_ATP_Olambda__304,axiom,
    ! [Uu: rat,Uua: int,Uub: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_gt(rat,fun(int,fun(int,product_prod(int,int))),Uu),Uua),Uub) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_gs(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uua),Uub)),quotient_of(Uu)) ).

% ATP.lambda_304
tff(fact_6297_ATP_Olambda__305,axiom,
    ! [Uu: rat,Uua: int,Uub: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aTP_Lamp_gr(rat,fun(int,fun(int,product_prod(int,int))),Uu),Uua),Uub) = aa(product_prod(int,int),product_prod(int,int),aa(fun(int,fun(int,product_prod(int,int))),fun(product_prod(int,int),product_prod(int,int)),product_case_prod(int,int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_gq(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uua),Uub)),quotient_of(Uu)) ).

% ATP.lambda_305
tff(fact_6298_ATP_Olambda__306,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B),Uua: nat,Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(nat,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_rp(array(B),fun(nat,fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))),Uu),Uua),Uub) = aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(nat,B,nth(B,array_get(B,Uub,Uu)),Uua)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uub),one_one(nat))) ) ).

% ATP.lambda_306
tff(fact_6299_ATP_Olambda__307,axiom,
    ! [Uu: nat,Uua: nat,Uub: list(nat)] :
      ( aa(list(nat),$o,aa(nat,fun(list(nat),$o),aTP_Lamp_sx(nat,fun(nat,fun(list(nat),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(nat),nat,size_size(list(nat)),Uub) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uu),one_one(nat)) )
        & ( aa(list(nat),nat,groups8242544230860333062m_list(nat),Uub) = Uua ) ) ) ).

% ATP.lambda_307
tff(fact_6300_ATP_Olambda__308,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: list(B),Uub: list(B)] :
      ( aa(list(B),$o,aa(list(B),fun(list(B),$o),aTP_Lamp_pq(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(list(B),nat,size_size(list(B)),Uua)),aa(list(B),nat,size_size(list(B)),Uub))
        | ( ( aa(list(B),nat,size_size(list(B)),Uua) = aa(list(B),nat,size_size(list(B)),Uub) )
          & member(product_prod(list(B),list(B)),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Uua),Uub),lex(B,Uu)) ) ) ) ).

% ATP.lambda_308
tff(fact_6301_ATP_Olambda__309,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: list(B),Uub: list(B)] :
      ( aa(list(B),$o,aa(list(B),fun(list(B),$o),aTP_Lamp_pk(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(B),nat,size_size(list(B)),Uua) = aa(list(B),nat,size_size(list(B)),Uub) )
        & ? [Xys2: list(B),X4: B,Y3: B,Xs6: list(B),Ys5: list(B)] :
            ( ( Uua = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xys2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X4),Xs6)) )
            & ( Uub = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xys2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y3),Ys5)) )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Y3),Uu) ) ) ) ).

% ATP.lambda_309
tff(fact_6302_ATP_Olambda__310,axiom,
    ! [Uu: nat,Uua: nat,Uub: list(nat)] :
      ( aa(list(nat),$o,aa(nat,fun(list(nat),$o),aTP_Lamp_sy(nat,fun(nat,fun(list(nat),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(nat),nat,size_size(list(nat)),Uub) = Uu )
        & ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(list(nat),nat,groups8242544230860333062m_list(nat),Uub)),one_one(nat)) = Uua ) ) ) ).

% ATP.lambda_310
tff(fact_6303_ATP_Olambda__311,axiom,
    ! [B: $tType,Uu: nat,Uua: set(B),Uub: list(B)] :
      ( aa(list(B),$o,aa(set(B),fun(list(B),$o),aTP_Lamp_oi(nat,fun(set(B),fun(list(B),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(B),nat,size_size(list(B)),Uub) = Uu )
        & distinct(B,Uub)
        & aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),Uub)),Uua) ) ) ).

% ATP.lambda_311
tff(fact_6304_ATP_Olambda__312,axiom,
    ! [B: $tType,Uu: set(B),Uua: nat,Uub: list(B)] :
      ( aa(list(B),$o,aa(nat,fun(list(B),$o),aTP_Lamp_oh(set(B),fun(nat,fun(list(B),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(B),nat,size_size(list(B)),Uub) = Uua )
        & distinct(B,Uub)
        & aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(list(B),set(B),set2(B),Uub)),Uu) ) ) ).

% ATP.lambda_312
tff(fact_6305_ATP_Olambda__313,axiom,
    ! [Uu: nat,Uua: nat,Uub: list(nat)] :
      ( aa(list(nat),$o,aa(nat,fun(list(nat),$o),aTP_Lamp_sw(nat,fun(nat,fun(list(nat),$o)),Uu),Uua),Uub)
    <=> ( ( aa(list(nat),nat,size_size(list(nat)),Uub) = Uu )
        & ( aa(list(nat),nat,groups8242544230860333062m_list(nat),Uub) = Uua ) ) ) ).

% ATP.lambda_313
tff(fact_6306_ATP_Olambda__314,axiom,
    ! [Uu: set(nat),Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_ih(set(nat),fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> ( member(nat,aa(nat,nat,suc,Uub),Uu)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),Uua) ) ) ).

% ATP.lambda_314
tff(fact_6307_ATP_Olambda__315,axiom,
    ! [B: $tType,Uu: set(nat),Uua: nat,Uub: product_prod(B,nat)] :
      ( aa(product_prod(B,nat),$o,aa(nat,fun(product_prod(B,nat),$o),aTP_Lamp_qx(set(nat),fun(nat,fun(product_prod(B,nat),$o)),Uu),Uua),Uub)
    <=> member(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(product_prod(B,nat),nat,product_snd(B,nat),Uub)),Uua),Uu) ) ).

% ATP.lambda_315
tff(fact_6308_ATP_Olambda__316,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: list(B),Uua: fun(B,$o),Uub: B] :
          ( aa(B,$o,aa(fun(B,$o),fun(B,$o),aTP_Lamp_ps(list(B),fun(fun(B,$o),fun(B,$o)),Uu),Uua),Uub)
        <=> ( member(B,Uub,aa(list(B),set(B),set2(B),Uu))
            & aa(B,$o,Uua,Uub) ) ) ) ).

% ATP.lambda_316
tff(fact_6309_ATP_Olambda__317,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,option(C)),Uua: B,Uub: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(B,fun(product_prod(B,C),$o),aTP_Lamp_le(fun(B,option(C)),fun(B,fun(product_prod(B,C),$o)),Uu),Uua),Uub)
    <=> ( member(product_prod(B,C),Uub,graph(B,C,Uu))
        & ( aa(product_prod(B,C),B,product_fst(B,C),Uub) != Uua ) ) ) ).

% ATP.lambda_317
tff(fact_6310_ATP_Olambda__318,axiom,
    ! [Uu: heap_ext(product_unit),Uua: set(nat),Uub: nat] :
      ( aa(nat,$o,aa(set(nat),fun(nat,$o),aTP_Lamp_wc(heap_ext(product_unit),fun(set(nat),fun(nat,$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),lim(product_unit,Uu))
        & ~ member(nat,Uub,Uua) ) ) ).

% ATP.lambda_318
tff(fact_6311_ATP_Olambda__319,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B),Uub: B] :
      ( aa(B,$o,aa(set(B),fun(B,$o),aTP_Lamp_rl(set(product_prod(B,B)),fun(set(B),fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uub,field2(B,Uu))
        & ! [X4: B] :
            ( member(B,X4,Uua)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),X4),Uu) ) ) ) ).

% ATP.lambda_319
tff(fact_6312_ATP_Olambda__320,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B),Uub: B] :
      ( aa(B,$o,aa(set(B),fun(B,$o),aTP_Lamp_rn(set(product_prod(B,B)),fun(set(B),fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uub,field2(B,Uu))
        & ! [X4: B] :
            ( member(B,X4,Uua)
           => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Uub),Uu) ) ) ) ).

% ATP.lambda_320
tff(fact_6313_ATP_Olambda__321,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B),Uub: B] :
      ( aa(B,$o,aa(set(B),fun(B,$o),aTP_Lamp_rm(set(product_prod(B,B)),fun(set(B),fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uub,field2(B,Uu))
        & ! [X4: B] :
            ( member(B,X4,Uua)
           => ( ( Uub != X4 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),X4),Uu) ) ) ) ) ).

% ATP.lambda_321
tff(fact_6314_ATP_Olambda__322,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B),Uub: B] :
      ( aa(B,$o,aa(set(B),fun(B,$o),aTP_Lamp_ss(set(product_prod(B,B)),fun(set(B),fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uub,field2(B,Uu))
        & ! [X4: B] :
            ( member(B,X4,Uua)
           => ( ( Uub != X4 )
              & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Uub),Uu) ) ) ) ) ).

% ATP.lambda_322
tff(fact_6315_ATP_Olambda__323,axiom,
    ! [B: $tType,Uu: list(B),Uua: set(nat),Uub: nat] :
      ( aa(nat,$o,aa(set(nat),fun(nat,$o),aTP_Lamp_tu(list(B),fun(set(nat),fun(nat,$o)),Uu),Uua),Uub)
    <=> member(nat,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),aa(list(B),nat,size_size(list(B)),Uu)),Uua) ) ).

% ATP.lambda_323
tff(fact_6316_ATP_Olambda__324,axiom,
    ! [Uu: set(nat),Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_ii(set(nat),fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> ( member(nat,Uub,Uu)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),aa(nat,nat,suc,Uua)) ) ) ).

% ATP.lambda_324
tff(fact_6317_ATP_Olambda__325,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(B,B)),Uua: set(product_prod(B,B)),Uub: fun(C,B)] : aa(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C))),aa(set(product_prod(B,B)),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C))))),aTP_Lamp_hd(set(product_prod(B,B)),fun(set(product_prod(B,B)),fun(fun(C,B),product_prod(set(product_prod(C,C)),set(product_prod(C,C)))))),Uu),Uua),Uub) = 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))),inv_image(B,C,Uu,Uub)),inv_image(B,C,Uua,Uub)) ).

% ATP.lambda_325
tff(fact_6318_ATP_Olambda__326,axiom,
    ! [B: $tType,Uu: set(B),Uua: set(B),Uub: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),aTP_Lamp_mj(set(B),fun(set(B),fun(set(B),$o)),Uu),Uua),Uub)
    <=> ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less(set(B)),Uub),Uua)
        & aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),Uua),Uu) ) ) ).

% ATP.lambda_326
tff(fact_6319_ATP_Olambda__327,axiom,
    ! [B: $tType,Uu: set(B),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_rk(set(B),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uua,Uu)
        & member(B,Uub,Uu) ) ) ).

% ATP.lambda_327
tff(fact_6320_ATP_Olambda__328,axiom,
    ! [B: $tType,Uu: set(B),Uua: set(B),Uub: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),aTP_Lamp_hs(set(B),fun(set(B),fun(set(B),$o)),Uu),Uua),Uub)
    <=> ( aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),Uub),Uu) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),Uua),Uu) ) ) ).

% ATP.lambda_328
tff(fact_6321_ATP_Olambda__329,axiom,
    ! [B: $tType,Uu: set(B),Uua: fun(B,$o),Uub: B] :
      ( aa(B,$o,aa(fun(B,$o),fun(B,$o),aTP_Lamp_ia(set(B),fun(fun(B,$o),fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uub,Uu)
        & aa(B,$o,Uua,Uub) ) ) ).

% ATP.lambda_329
tff(fact_6322_ATP_Olambda__330,axiom,
    ! [B: $tType,C: $tType,Uu: set(B),Uua: fun(B,set(C)),Uub: B] :
      ( aa(B,$o,aa(fun(B,set(C)),fun(B,$o),aTP_Lamp_ke(set(B),fun(fun(B,set(C)),fun(B,$o)),Uu),Uua),Uub)
    <=> ( member(B,Uub,Uu)
        & ( aa(B,set(C),Uua,Uub) != bot_bot(set(C)) ) ) ) ).

% ATP.lambda_330
tff(fact_6323_ATP_Olambda__331,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(C)
     => ! [Uu: set(B),Uua: fun(B,C),Uub: B] :
          ( aa(B,$o,aa(fun(B,C),fun(B,$o),aTP_Lamp_hv(set(B),fun(fun(B,C),fun(B,$o)),Uu),Uua),Uub)
        <=> ( member(B,Uub,Uu)
            & ( aa(B,C,Uua,Uub) != zero_zero(C) ) ) ) ) ).

% ATP.lambda_331
tff(fact_6324_ATP_Olambda__332,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: set(B),Uua: fun(B,C),Uub: B] :
          ( aa(B,$o,aa(fun(B,C),fun(B,$o),aTP_Lamp_hx(set(B),fun(fun(B,C),fun(B,$o)),Uu),Uua),Uub)
        <=> ( member(B,Uub,Uu)
            & ( aa(B,C,Uua,Uub) != one_one(C) ) ) ) ) ).

% ATP.lambda_332
tff(fact_6325_ATP_Olambda__333,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(C,B),Uua: set(C),Uub: C] :
          ( aa(C,$o,aa(set(C),fun(C,$o),aTP_Lamp_ij(fun(C,B),fun(set(C),fun(C,$o)),Uu),Uua),Uub)
        <=> ( member(C,Uub,Uua)
            & ( aa(C,B,Uu,Uub) != one_one(B) ) ) ) ) ).

% ATP.lambda_333
tff(fact_6326_ATP_Olambda__334,axiom,
    ! [B: $tType,C: $tType,Uu: list(product_prod(B,C)),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_og(list(product_prod(B,C)),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(B,option(C),map_of(B,C,Uu),Uua) = aa(C,option(C),some(C),Uub) ) ) ).

% ATP.lambda_334
tff(fact_6327_ATP_Olambda__335,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_ds(nat,fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uub)),Uu) ) ).

% ATP.lambda_335
tff(fact_6328_ATP_Olambda__336,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_ej(nat,fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uub)),Uu) ) ).

% ATP.lambda_336
tff(fact_6329_ATP_Olambda__337,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [Uu: B,Uua: B,Uub: B] : aa(B,B,aa(B,fun(B,B),aTP_Lamp_hg(B,fun(B,fun(B,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),Uub),Uu)),Uua) ) ).

% ATP.lambda_337
tff(fact_6330_ATP_Olambda__338,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [Uu: B,Uua: B,Uub: B] : aa(B,B,aa(B,fun(B,B),aTP_Lamp_hi(B,fun(B,fun(B,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),times_times(B),Uu),Uub)),Uua) ) ).

% ATP.lambda_338
tff(fact_6331_ATP_Olambda__339,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [Uu: B,Uua: B,Uub: B] : aa(B,B,aa(B,fun(B,B),aTP_Lamp_hh(B,fun(B,fun(B,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),divide_divide(B),Uub),Uu)),Uua) ) ).

% ATP.lambda_339
tff(fact_6332_ATP_Olambda__340,axiom,
    ! [B: $tType] :
      ( linordered_field(B)
     => ! [Uu: B,Uua: B,Uub: B] : aa(B,B,aa(B,fun(B,B),aTP_Lamp_hl(B,fun(B,fun(B,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(B,B,aa(B,fun(B,B),times_times(B),Uu),Uub)),Uua) ) ).

% ATP.lambda_340
tff(fact_6333_ATP_Olambda__341,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_uo(set(product_prod(D,C)),fun(D,fun(C,$o)),Uu),Uua),Uub)
    <=> member(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_341
tff(fact_6334_ATP_Olambda__342,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_ur(set(product_prod(C,D)),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> member(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_342
tff(fact_6335_ATP_Olambda__343,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(C,B)),Uua: C,Uub: B] :
      ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_au(set(product_prod(C,B)),fun(C,fun(B,$o)),Uu),Uua),Uub)
    <=> member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Uua),Uub),Uu) ) ).

% ATP.lambda_343
tff(fact_6336_ATP_Olambda__344,axiom,
    ! [D: $tType,B: $tType,Uu: set(product_prod(B,D)),Uua: B,Uub: D] :
      ( aa(D,$o,aa(B,fun(D,$o),aTP_Lamp_un(set(product_prod(B,D)),fun(B,fun(D,$o)),Uu),Uua),Uub)
    <=> member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),Uua),Uub),Uu) ) ).

% ATP.lambda_344
tff(fact_6337_ATP_Olambda__345,axiom,
    ! [C: $tType,B: $tType,Uu: set(product_prod(B,C)),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(set(product_prod(B,C)),fun(B,fun(C,$o)),aTP_Lamp_bg(set(product_prod(B,C)),fun(B,fun(C,$o))),Uu),Uua),Uub)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),Uub),Uu) ) ).

% ATP.lambda_345
tff(fact_6338_ATP_Olambda__346,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_in(set(product_prod(B,B)),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uua),Uub),Uu) ) ).

% ATP.lambda_346
tff(fact_6339_ATP_Olambda__347,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(C,B)),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_tg(set(product_prod(C,B)),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),Uub),Uua),Uu) ) ).

% ATP.lambda_347
tff(fact_6340_ATP_Olambda__348,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_sl(set(product_prod(B,B)),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uua),Uu) ) ).

% ATP.lambda_348
tff(fact_6341_ATP_Olambda__349,axiom,
    ! [D: $tType,E: $tType,C: $tType,B: $tType,Uu: fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(D)),Uua: fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),Uub: fun(B,heap_Time_Heap(C))] : aa(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E),aa(fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E)),aTP_Lamp_ya(fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(D)),fun(fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),Uu),Uua),Uub) = heap_Time_bind(D,E,aa(fun(B,heap_Time_Heap(C)),heap_Time_Heap(D),Uu,Uub),aa(fun(B,heap_Time_Heap(C)),fun(D,heap_Time_Heap(E)),aTP_Lamp_xz(fun(D,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(E))),fun(fun(B,heap_Time_Heap(C)),fun(D,heap_Time_Heap(E))),Uua),Uub)) ).

% ATP.lambda_349
tff(fact_6342_ATP_Olambda__350,axiom,
    ! [D: $tType,E: $tType,C: $tType,B: $tType,Uu: fun(fun(B,option(C)),option(D)),Uua: fun(D,fun(fun(B,option(C)),option(E))),Uub: fun(B,option(C))] : aa(fun(B,option(C)),option(E),aa(fun(D,fun(fun(B,option(C)),option(E))),fun(fun(B,option(C)),option(E)),aTP_Lamp_xt(fun(fun(B,option(C)),option(D)),fun(fun(D,fun(fun(B,option(C)),option(E))),fun(fun(B,option(C)),option(E))),Uu),Uua),Uub) = aa(fun(D,option(E)),option(E),aa(option(D),fun(fun(D,option(E)),option(E)),bind(D,E),aa(fun(B,option(C)),option(D),Uu,Uub)),aa(fun(B,option(C)),fun(D,option(E)),aTP_Lamp_xs(fun(D,fun(fun(B,option(C)),option(E))),fun(fun(B,option(C)),fun(D,option(E))),Uua),Uub)) ).

% ATP.lambda_350
tff(fact_6343_ATP_Olambda__351,axiom,
    ! [Uu: fun(nat,$o),Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_ht(fun(nat,$o),fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> ( aa(nat,$o,Uu,Uub)
        & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uub),Uua) ) ) ).

% ATP.lambda_351
tff(fact_6344_ATP_Olambda__352,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: fun(B,C),Uua: fun(B,C),Uub: B] : aa(B,C,aa(fun(B,C),fun(B,C),aTP_Lamp_ik(fun(B,C),fun(fun(B,C),fun(B,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(B,C,Uu,Uub)),aa(B,C,Uua,Uub)) ) ).

% ATP.lambda_352
tff(fact_6345_ATP_Olambda__353,axiom,
    ! [C: $tType,B: $tType] :
      ( linordered_idom(C)
     => ! [Uu: fun(B,C),Uua: fun(B,C),Uub: B] : aa(B,C,aa(fun(B,C),fun(B,C),aTP_Lamp_by(fun(B,C),fun(fun(B,C),fun(B,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),times_times(C),aa(B,C,Uua,Uub)),aa(B,C,Uu,Uub)) ) ).

% ATP.lambda_353
tff(fact_6346_ATP_Olambda__354,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(C)),Uua: fun(B,set(C)),Uub: B] : aa(B,set(C),aa(fun(B,set(C)),fun(B,set(C)),aTP_Lamp_ju(fun(B,set(C)),fun(fun(B,set(C)),fun(B,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),minus_minus(set(C)),aa(B,set(C),Uu,Uub)),aa(B,set(C),Uua,Uub)) ).

% ATP.lambda_354
tff(fact_6347_ATP_Olambda__355,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [Uu: fun(B,nat),Uua: fun(B,nat),Uub: B] : aa(B,nat,aa(fun(B,nat),fun(B,nat),aTP_Lamp_em(fun(B,nat),fun(fun(B,nat),fun(B,nat)),Uu),Uua),Uub) = aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(B,nat,Uua,Uub)),aa(B,nat,Uu,Uub)) ) ).

% ATP.lambda_355
tff(fact_6348_ATP_Olambda__356,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(C)),Uua: fun(B,set(C)),Uub: B] : aa(B,set(C),aa(fun(B,set(C)),fun(B,set(C)),aTP_Lamp_kp(fun(B,set(C)),fun(fun(B,set(C)),fun(B,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),aa(set(C),fun(set(C),set(C)),sup_sup(set(C)),aa(B,set(C),Uu,Uub)),aa(B,set(C),Uua,Uub)) ).

% ATP.lambda_356
tff(fact_6349_ATP_Olambda__357,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,set(C)),Uua: fun(B,set(C)),Uub: B] : aa(B,set(C),aa(fun(B,set(C)),fun(B,set(C)),aTP_Lamp_mp(fun(B,set(C)),fun(fun(B,set(C)),fun(B,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),inf_inf(set(C),aa(B,set(C),Uu,Uub)),aa(B,set(C),Uua,Uub)) ).

% ATP.lambda_357
tff(fact_6350_ATP_Olambda__358,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(C,B),Uua: fun(C,B),Uub: C] : aa(C,B,aa(fun(C,B),fun(C,B),aTP_Lamp_cb(fun(C,B),fun(fun(C,B),fun(C,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(C,B,Uu,Uub)),aa(C,B,Uua,Uub)) ) ).

% ATP.lambda_358
tff(fact_6351_ATP_Olambda__359,axiom,
    ! [B: $tType,Uu: fun(B,nat),Uua: fun(B,nat),Uub: B] : aa(B,nat,aa(fun(B,nat),fun(B,nat),aa(fun(B,nat),fun(fun(B,nat),fun(B,nat)),aTP_Lamp_tq(fun(B,nat),fun(fun(B,nat),fun(B,nat))),Uu),Uua),Uub) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(B,nat,Uu,Uub)),aa(B,nat,Uua,Uub)) ).

% ATP.lambda_359
tff(fact_6352_ATP_Olambda__360,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [Uu: fun(B,C),Uua: fun(B,C),Uub: B] : aa(B,C,aa(fun(B,C),fun(B,C),aTP_Lamp_il(fun(B,C),fun(fun(B,C),fun(B,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,Uu,Uub)),aa(B,C,Uua,Uub)) ) ).

% ATP.lambda_360
tff(fact_6353_ATP_Olambda__361,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(D,B),Uua: fun(D,C),Uub: D] : aa(D,product_prod(B,C),aa(fun(D,C),fun(D,product_prod(B,C)),aTP_Lamp_mx(fun(D,B),fun(fun(D,C),fun(D,product_prod(B,C))),Uu),Uua),Uub) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,Uu,Uub)),aa(D,C,Uua,Uub)) ).

% ATP.lambda_361
tff(fact_6354_ATP_Olambda__362,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_vo(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_362
tff(fact_6355_ATP_Olambda__363,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,C),Uua: fun(B,C),Uub: B] :
      ( aa(B,$o,aa(fun(B,C),fun(B,$o),aTP_Lamp_uf(fun(B,C),fun(fun(B,C),fun(B,$o)),Uu),Uua),Uub)
    <=> ( aa(B,C,Uu,Uub) = aa(B,C,Uua,Uub) ) ) ).

% ATP.lambda_363
tff(fact_6356_ATP_Olambda__364,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,option(C)),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_mb(fun(B,option(C)),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> ( aa(B,option(C),Uu,Uua) = aa(C,option(C),some(C),Uub) ) ) ).

% ATP.lambda_364
tff(fact_6357_ATP_Olambda__365,axiom,
    ! [Uu: fun(b,b),Uua: ref(b),Uub: b] :
      aa(b,heap_Time_Heap(b),aa(ref(b),fun(b,heap_Time_Heap(b)),aTP_Lamp_bc(fun(b,b),fun(ref(b),fun(b,heap_Time_Heap(b))),Uu),Uua),Uub) = $let(
        y: b,
        y:= aa(b,b,Uu,Uub),
        heap_Time_bind(product_unit,b,ref_update(b,Uua,y),aTP_Lamp_bb(b,fun(product_unit,heap_Time_Heap(b)),y)) ) ).

% ATP.lambda_365
tff(fact_6358_ATP_Olambda__366,axiom,
    ! [Uu: fun(nat,nat),Uua: nat,Uub: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aTP_Lamp_hu(fun(nat,nat),fun(nat,fun(nat,$o)),Uu),Uua),Uub)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,Uu,Uub)),Uua) ) ).

% ATP.lambda_366
tff(fact_6359_ATP_Olambda__367,axiom,
    ! [B: $tType,C: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] : aa(B,C,aa(C,fun(B,C),aTP_Lamp_ml(fun(B,C),fun(C,fun(B,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),divide_divide(C),aa(B,C,Uu,Uub)),Uua) ) ).

% ATP.lambda_367
tff(fact_6360_ATP_Olambda__368,axiom,
    ! [B: $tType,C: $tType] :
      ( linorder(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] :
          ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_pt(fun(B,C),fun(C,fun(B,$o)),Uu),Uua),Uub)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),aa(B,C,Uu,Uub)),Uua) ) ) ).

% ATP.lambda_368
tff(fact_6361_ATP_Olambda__369,axiom,
    ! [B: $tType,C: $tType] :
      ( linord4140545234300271783up_add(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] : aa(B,C,aa(C,fun(B,C),aTP_Lamp_lv(fun(B,C),fun(C,fun(B,C)),Uu),Uua),Uub) = aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,Uu,Uub)),Uua) ) ).

% ATP.lambda_369
tff(fact_6362_ATP_Olambda__370,axiom,
    ! [D: $tType,B: $tType,C: $tType,Uu: fun(D,heap_Time_Heap(C)),Uua: fun(C,heap_Time_Heap(B)),Uub: D] : aa(D,heap_Time_Heap(B),aa(fun(C,heap_Time_Heap(B)),fun(D,heap_Time_Heap(B)),aTP_Lamp_ab(fun(D,heap_Time_Heap(C)),fun(fun(C,heap_Time_Heap(B)),fun(D,heap_Time_Heap(B))),Uu),Uua),Uub) = heap_Time_bind(C,B,aa(D,heap_Time_Heap(C),Uu,Uub),Uua) ).

% ATP.lambda_370
tff(fact_6363_ATP_Olambda__371,axiom,
    ! [F4: $tType,G2: $tType,C: $tType,E: $tType,D: $tType,Uu: fun(F4,fun(G2,product_prod(D,E))),Uua: fun(D,fun(E,C)),Uub: F4] : aa(F4,fun(G2,C),aa(fun(D,fun(E,C)),fun(F4,fun(G2,C)),aTP_Lamp_sh(fun(F4,fun(G2,product_prod(D,E))),fun(fun(D,fun(E,C)),fun(F4,fun(G2,C))),Uu),Uua),Uub) = product_scomp(G2,D,E,C,aa(F4,fun(G2,product_prod(D,E)),Uu,Uub),Uua) ).

% ATP.lambda_371
tff(fact_6364_ATP_Olambda__372,axiom,
    ! [D: $tType,B: $tType,C: $tType,Uu: fun(D,option(C)),Uua: fun(C,option(B)),Uub: D] : aa(D,option(B),aa(fun(C,option(B)),fun(D,option(B)),aTP_Lamp_be(fun(D,option(C)),fun(fun(C,option(B)),fun(D,option(B))),Uu),Uua),Uub) = aa(fun(C,option(B)),option(B),aa(option(C),fun(fun(C,option(B)),option(B)),bind(C,B),aa(D,option(C),Uu,Uub)),Uua) ).

% ATP.lambda_372
tff(fact_6365_ATP_Olambda__373,axiom,
    ! [C: $tType,B: $tType,Uu: set(B),Uua: fun(C,B),Uub: C] :
      ( aa(C,$o,aa(fun(C,B),fun(C,$o),aTP_Lamp_nk(set(B),fun(fun(C,B),fun(C,$o)),Uu),Uua),Uub)
    <=> member(B,aa(C,B,Uua,Uub),Uu) ) ).

% ATP.lambda_373
tff(fact_6366_ATP_Olambda__374,axiom,
    ! [E: $tType,F4: $tType,C: $tType,D: $tType,Uu: fun(E,fun(F4,D)),Uua: fun(D,C),Uub: E] : aa(E,fun(F4,C),aa(fun(D,C),fun(E,fun(F4,C)),aTP_Lamp_ww(fun(E,fun(F4,D)),fun(fun(D,C),fun(E,fun(F4,C))),Uu),Uua),Uub) = fcomp(F4,D,C,aa(E,fun(F4,D),Uu,Uub),Uua) ).

% ATP.lambda_374
tff(fact_6367_ATP_Olambda__375,axiom,
    ! [B: $tType,C: $tType] :
      ( linorder(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] :
          ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_pu(fun(B,C),fun(C,fun(B,$o)),Uu),Uua),Uub)
        <=> ( aa(B,C,Uu,Uub) = Uua ) ) ) ).

% ATP.lambda_375
tff(fact_6368_ATP_Olambda__376,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,C),Uua: C,Uub: B] :
      ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_nq(fun(B,C),fun(C,fun(B,$o)),Uu),Uua),Uub)
    <=> ( aa(B,C,Uu,Uub) = Uua ) ) ).

% ATP.lambda_376
tff(fact_6369_ATP_Olambda__377,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: fun(nat,B),Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(nat,B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ov(nat,fun(fun(nat,B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu),Uua),Uub) = aa(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(array(B),heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ou(nat,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu)),array_alloc(B,aa(list(nat),list(B),map(nat,B,Uua),upt(zero_zero(nat),Uu)),Uub)) ) ).

% ATP.lambda_377
tff(fact_6370_ATP_Olambda__378,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: B,Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(B,fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ow(nat,fun(B,fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu),Uua),Uub) = aa(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),fun(product_prod(array(B),heap_ext(product_unit)),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_case_prod(array(B),heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ou(nat,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu)),array_alloc(B,replicate(B,Uu,Uua),Uub)) ) ).

% ATP.lambda_378
tff(fact_6371_ATP_Olambda__379,axiom,
    ! [B: $tType,Uu: fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),Uua: pred(B),Uub: product_prod(code_natural,code_natural)] : aa(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aTP_Lamp_uj(fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),fun(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uu),Uua),Uub) = aa(product_prod(pred(B),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(fun(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(product_prod(pred(B),product_prod(code_natural,code_natural)),product_prod(pred(B),product_prod(code_natural,code_natural))),product_case_prod(pred(B),product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aTP_Lamp_ui(pred(B),fun(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uua)),aa(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)),Uu,Uub)) ).

% ATP.lambda_379
tff(fact_6372_ATP_Olambda__380,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_th(set(product_prod(B,B)),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> ( ( Uub != Uua )
        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uua),Uub),Uu) ) ) ).

% ATP.lambda_380
tff(fact_6373_ATP_Olambda__381,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_su(set(product_prod(B,B)),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> ( ( Uub != Uua )
        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uua),Uu) ) ) ).

% ATP.lambda_381
tff(fact_6374_ATP_Olambda__382,axiom,
    ! [B: $tType,Uu: B,Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_rj(B,fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> ( ( Uua != Uu )
        & ( Uub != Uu ) ) ) ).

% ATP.lambda_382
tff(fact_6375_ATP_Olambda__383,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B),Uub: set(B)] :
      ( aa(set(B),$o,aa(set(B),fun(set(B),$o),aTP_Lamp_sm(set(product_prod(B,B)),fun(set(B),fun(set(B),$o)),Uu),Uua),Uub)
    <=> ( finite_finite2(B,Uua)
        & finite_finite2(B,Uub)
        & ( Uub != bot_bot(set(B)) )
        & ! [X4: B] :
            ( member(B,X4,Uua)
           => ? [Xa2: B] :
                ( member(B,Xa2,Uub)
                & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Xa2),Uu) ) ) ) ) ).

% ATP.lambda_383
tff(fact_6376_ATP_Olambda__384,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_fu(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7121269368397514597t_prod(nat,B),Uu),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uub),Uua),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uub),Uua)),Uua))) ) ).

% ATP.lambda_384
tff(fact_6377_ATP_Olambda__385,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_fd(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups7311177749621191930dd_sum(nat,B),Uu),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uub),Uua),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uub),Uua)),Uua))) ) ).

% ATP.lambda_385
tff(fact_6378_ATP_Olambda__386,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,B),Uua: list(B),Uub: C] : aa(C,list(B),aa(list(B),fun(C,list(B)),aTP_Lamp_pi(fun(C,B),fun(list(B),fun(C,list(B))),Uu),Uua),Uub) = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Uua),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),aa(C,B,Uu,Uub)),nil(B))) ).

% ATP.lambda_386
tff(fact_6379_ATP_Olambda__387,axiom,
    ! [B: $tType] :
      ( euclid5411537665997757685th_nat(B)
     => ! [Uu: B,Uua: B,Uub: nat] : aa(nat,B,aa(B,fun(nat,B),aTP_Lamp_cp(B,fun(B,fun(nat,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),Uub)),Uua)) ) ).

% ATP.lambda_387
tff(fact_6380_ATP_Olambda__388,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Uu: B,Uua: B,Uub: nat] : aa(nat,B,aa(B,fun(nat,B),aTP_Lamp_co(B,fun(B,fun(nat,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),Uub)),Uua)) ) ).

% ATP.lambda_388
tff(fact_6381_ATP_Olambda__389,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: array(B),Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ou(nat,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu),Uua),Uub) = aa(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_Pair(array(B),product_prod(heap_ext(product_unit),nat)),Uua),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uub),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),one_one(nat)))) ) ).

% ATP.lambda_389
tff(fact_6382_ATP_Olambda__390,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: list(B),Uua: array(B),Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aTP_Lamp_or(list(B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),Uu),Uua),Uub) = aa(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_Pair(array(B),product_prod(heap_ext(product_unit),nat)),Uua),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uub),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),one_one(nat)),aa(list(B),nat,size_size(list(B)),Uu)))) ) ).

% ATP.lambda_390
tff(fact_6383_ATP_Olambda__391,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: fun(nat,B),Uub: array(B)] : aa(array(B),assn,aa(fun(nat,B),fun(array(B),assn),aTP_Lamp_vy(nat,fun(fun(nat,B),fun(array(B),assn)),Uu),Uua),Uub) = snga_assn(B,Uub,aa(list(nat),list(B),map(nat,B,Uua),upt(zero_zero(nat),Uu))) ) ).

% ATP.lambda_391
tff(fact_6384_ATP_Olambda__392,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [Uu: B,Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_ew(B,fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(B,fun(nat,B),power_power(B),Uu),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),aa(nat,nat,suc,Uub))) ) ).

% ATP.lambda_392
tff(fact_6385_ATP_Olambda__393,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: array(B),Uub: heap_ext(product_unit)] :
          ( aa(heap_ext(product_unit),$o,aa(array(B),fun(heap_ext(product_unit),$o),aTP_Lamp_rr(nat,fun(array(B),fun(heap_ext(product_unit),$o)),Uu),Uua),Uub)
        <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uu),aa(array(B),nat,array_length(B,Uub),Uua)) ) ) ).

% ATP.lambda_393
tff(fact_6386_ATP_Olambda__394,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: array(B),Uua: nat,Uub: heap_ext(product_unit)] :
          ( aa(heap_ext(product_unit),$o,aa(nat,fun(heap_ext(product_unit),$o),aTP_Lamp_ro(array(B),fun(nat,fun(heap_ext(product_unit),$o)),Uu),Uua),Uub)
        <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uua),aa(array(B),nat,array_length(B,Uub),Uu)) ) ) ).

% ATP.lambda_394
tff(fact_6387_ATP_Olambda__395,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [Uu: B,Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_bu(B,fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,aa(B,fun(nat,B),power_power(B),Uu),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uub)) ) ).

% ATP.lambda_395
tff(fact_6388_ATP_Olambda__396,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat] : aa(nat,nat,aa(nat,fun(nat,nat),aTP_Lamp_ca(nat,fun(nat,fun(nat,nat)),Uu),Uua),Uub) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uub),Uua)) ).

% ATP.lambda_396
tff(fact_6389_ATP_Olambda__397,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: B,Uub: array(B)] : aa(array(B),assn,aa(B,fun(array(B),assn),aTP_Lamp_wb(nat,fun(B,fun(array(B),assn)),Uu),Uua),Uub) = snga_assn(B,Uub,replicate(B,Uu,Uua)) ) ).

% ATP.lambda_397
tff(fact_6390_ATP_Olambda__398,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: B,Uua: C,Uub: D] : aa(D,product_prod(B,product_prod(C,D)),aa(C,fun(D,product_prod(B,product_prod(C,D))),aa(B,fun(C,fun(D,product_prod(B,product_prod(C,D)))),aTP_Lamp_qk(B,fun(C,fun(D,product_prod(B,product_prod(C,D))))),Uu),Uua),Uub) = aa(product_prod(C,D),product_prod(B,product_prod(C,D)),aa(B,fun(product_prod(C,D),product_prod(B,product_prod(C,D))),product_Pair(B,product_prod(C,D)),Uu),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uua),Uub)) ).

% ATP.lambda_398
tff(fact_6391_ATP_Olambda__399,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: C,Uua: B,Uub: D] : aa(D,product_prod(B,product_prod(C,D)),aa(B,fun(D,product_prod(B,product_prod(C,D))),aTP_Lamp_ql(C,fun(B,fun(D,product_prod(B,product_prod(C,D)))),Uu),Uua),Uub) = aa(product_prod(C,D),product_prod(B,product_prod(C,D)),aa(B,fun(product_prod(C,D),product_prod(B,product_prod(C,D))),product_Pair(B,product_prod(C,D)),Uua),aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uu),Uub)) ).

% ATP.lambda_399
tff(fact_6392_ATP_Olambda__400,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,option(B)),Uua: list(C),Uub: B] : aa(B,list(B),aa(list(C),fun(B,list(B)),aTP_Lamp_pd(fun(C,option(B)),fun(list(C),fun(B,list(B))),Uu),Uua),Uub) = aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uub),map_filter(C,B,Uu,Uua)) ).

% ATP.lambda_400
tff(fact_6393_ATP_Olambda__401,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] :
          ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_pv(fun(B,C),fun(C,fun(B,$o)),Uu),Uua),Uub)
        <=> aa(C,$o,aa(C,fun(C,$o),ord_less(C),Uua),aa(B,C,Uu,Uub)) ) ) ).

% ATP.lambda_401
tff(fact_6394_ATP_Olambda__402,axiom,
    ! [C: $tType,Uu: assn,Uua: fun(C,assn),Uub: C] : aa(C,assn,aa(fun(C,assn),fun(C,assn),aTP_Lamp_vz(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_402
tff(fact_6395_ATP_Olambda__403,axiom,
    ! [C: $tType,B: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] :
          ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_mm(fun(B,C),fun(C,fun(B,$o)),Uu),Uua),Uub)
        <=> dvd_dvd(C,Uua,aa(B,C,Uu,Uub)) ) ) ).

% ATP.lambda_403
tff(fact_6396_ATP_Olambda__404,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(D,C),Uua: B,Uub: D] : aa(D,product_prod(B,C),aa(B,fun(D,product_prod(B,C)),aTP_Lamp_od(fun(D,C),fun(B,fun(D,product_prod(B,C))),Uu),Uua),Uub) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),aa(D,C,Uu,Uub)) ).

% ATP.lambda_404
tff(fact_6397_ATP_Olambda__405,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Uu: B,Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_fy(B,fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(B,B,aa(B,fun(B,B),plus_plus(B),Uu),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),Uub))) ) ).

% ATP.lambda_405
tff(fact_6398_ATP_Olambda__406,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: set(B),Uua: set(D),Uub: fun(B,C)] : aa(fun(B,C),set(fun(B,D)),aa(set(D),fun(fun(B,C),set(fun(B,D))),aTP_Lamp_vf(set(B),fun(set(D),fun(fun(B,C),set(fun(B,D)))),Uu),Uua),Uub) = bNF_Wellorder_Func(B,D,Uu,Uua) ).

% ATP.lambda_406
tff(fact_6399_ATP_Olambda__407,axiom,
    ! [B: $tType,Uu: set(B),Uua: set(B),Uub: B] : aa(B,set(B),aa(set(B),fun(B,set(B)),aTP_Lamp_no(set(B),fun(set(B),fun(B,set(B))),Uu),Uua),Uub) = aa(set(B),set(B),aa(set(B),fun(set(B),set(B)),minus_minus(set(B)),Uu),Uua) ).

% ATP.lambda_407
tff(fact_6400_ATP_Olambda__408,axiom,
    ! [B: $tType,C: $tType,Uu: set(C),Uua: set(C),Uub: B] : aa(B,set(C),aa(set(C),fun(B,set(C)),aTP_Lamp_mq(set(C),fun(set(C),fun(B,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),inf_inf(set(C),Uu),Uua) ).

% ATP.lambda_408
tff(fact_6401_ATP_Olambda__409,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] : aa(B,set(B),aa(B,fun(B,set(B)),aTP_Lamp_st(set(product_prod(B,B)),fun(B,fun(B,set(B))),Uu),Uua),Uub) = order_underS(B,Uu,Uua) ).

% ATP.lambda_409
tff(fact_6402_ATP_Olambda__410,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: set(C),Uua: set(D),Uub: B] : aa(B,set(sum_sum(C,D)),aa(set(D),fun(B,set(sum_sum(C,D))),aTP_Lamp_ux(set(C),fun(set(D),fun(B,set(sum_sum(C,D)))),Uu),Uua),Uub) = sum_Plus(C,D,Uu,Uua) ).

% ATP.lambda_410
tff(fact_6403_ATP_Olambda__411,axiom,
    ! [B: $tType,C: $tType,Uu: C,Uua: set(C),Uub: B] : aa(B,set(C),aa(set(C),fun(B,set(C)),aTP_Lamp_ko(C,fun(set(C),fun(B,set(C))),Uu),Uua),Uub) = aa(set(C),set(C),insert2(C,Uu),Uua) ).

% ATP.lambda_411
tff(fact_6404_ATP_Olambda__412,axiom,
    ! [B: $tType,C: $tType,E: $tType,Uu: fun(E,C),Uua: set(E),Uub: B] : aa(B,set(C),aa(set(E),fun(B,set(C)),aTP_Lamp_kd(fun(E,C),fun(set(E),fun(B,set(C))),Uu),Uua),Uub) = aa(set(E),set(C),image2(E,C,Uu),Uua) ).

% ATP.lambda_412
tff(fact_6405_ATP_Olambda__413,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,B),Uua: set(C),Uub: B] : aa(B,set(B),aa(set(C),fun(B,set(B)),aTP_Lamp_jq(fun(C,B),fun(set(C),fun(B,set(B))),Uu),Uua),Uub) = aa(set(C),set(B),image2(C,B,Uu),Uua) ).

% ATP.lambda_413
tff(fact_6406_ATP_Olambda__414,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: ref(B),Uua: B,Uub: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),aa(B,fun(heap_ext(product_unit),product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_mk(ref(B),fun(B,fun(heap_ext(product_unit),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)))),Uu),Uua),Uub) = aa(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat)),aa(product_unit,fun(product_prod(heap_ext(product_unit),nat),product_prod(product_unit,product_prod(heap_ext(product_unit),nat))),product_Pair(product_unit,product_prod(heap_ext(product_unit),nat)),product_Unity),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),ref_set(B,Uu,Uua,Uub)),one_one(nat))) ) ).

% ATP.lambda_414
tff(fact_6407_ATP_Olambda__415,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),Uua: fun(B,D),Uub: fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))))] : aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C,aa(fun(B,D),fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C),aTP_Lamp_vi(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(B,D),fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),C)),Uu),Uua),Uub) = aa(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C,Uu,aa(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),aa(fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),fun(fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat))))),comp(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(D,product_prod(heap_ext(product_unit),nat))),heap_ext(product_unit)),aa(fun(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(D,product_prod(heap_ext(product_unit),nat))),fun(option(product_prod(B,product_prod(heap_ext(product_unit),nat))),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),map_option(product_prod(B,product_prod(heap_ext(product_unit),nat)),product_prod(D,product_prod(heap_ext(product_unit),nat))),product_map_prod(B,D,product_prod(heap_ext(product_unit),nat),product_prod(heap_ext(product_unit),nat),Uua,id(product_prod(heap_ext(product_unit),nat))))),Uub)) ).

% ATP.lambda_415
tff(fact_6408_ATP_Olambda__416,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_fp(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),aa(nat,nat,suc,Uub))) ) ).

% ATP.lambda_416
tff(fact_6409_ATP_Olambda__417,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_el(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),aa(nat,nat,suc,Uub))) ) ).

% ATP.lambda_417
tff(fact_6410_ATP_Olambda__418,axiom,
    ! [B: $tType,Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_wp(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),aa(nat,nat,suc,Uub))) ).

% ATP.lambda_418
tff(fact_6411_ATP_Olambda__419,axiom,
    ! [B: $tType,Uu: fun(nat,set(B)),Uua: nat,Uub: nat] : aa(nat,set(B),aa(nat,fun(nat,set(B)),aTP_Lamp_jd(fun(nat,set(B)),fun(nat,fun(nat,set(B))),Uu),Uua),Uub) = aa(nat,set(B),Uu,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)) ).

% ATP.lambda_419
tff(fact_6412_ATP_Olambda__420,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_fn(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)) ) ).

% ATP.lambda_420
tff(fact_6413_ATP_Olambda__421,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_bq(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)) ) ).

% ATP.lambda_421
tff(fact_6414_ATP_Olambda__422,axiom,
    ! [B: $tType,Uu: fun(nat,B),Uua: nat,Uub: nat] : aa(nat,B,aa(nat,fun(nat,B),aTP_Lamp_wr(fun(nat,B),fun(nat,fun(nat,B)),Uu),Uua),Uub) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)) ).

% ATP.lambda_422
tff(fact_6415_ATP_Olambda__423,axiom,
    ! [B: $tType,C: $tType,Uu: fun(product_prod(B,C),$o),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_tb(fun(product_prod(B,C),$o),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> aa(product_prod(B,C),$o,Uu,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),Uub)) ) ).

% ATP.lambda_423
tff(fact_6416_ATP_Olambda__424,axiom,
    ! [D: $tType,B: $tType,C: $tType,Uu: fun(product_prod(B,C),D),Uua: B,Uub: C] : aa(C,D,aa(B,fun(C,D),aTP_Lamp_br(fun(product_prod(B,C),D),fun(B,fun(C,D)),Uu),Uua),Uub) = aa(product_prod(B,C),D,Uu,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uua),Uub)) ).

% ATP.lambda_424
tff(fact_6417_ATP_Olambda__425,axiom,
    ! [B: $tType,Uu: fun(B,$o),Uua: list(B),Uub: nat] :
      ( aa(nat,$o,aa(list(B),fun(nat,$o),aTP_Lamp_ph(fun(B,$o),fun(list(B),fun(nat,$o)),Uu),Uua),Uub)
    <=> aa(B,$o,Uu,aa(nat,B,nth(B,Uua),Uub)) ) ).

% ATP.lambda_425
tff(fact_6418_ATP_Olambda__426,axiom,
    ! [C: $tType,D: $tType,E: $tType,B: $tType,Uu: fun(E,fun(C,D)),Uua: fun(B,E),Uub: B] : aa(B,fun(C,D),aa(fun(B,E),fun(B,fun(C,D)),aTP_Lamp_ir(fun(E,fun(C,D)),fun(fun(B,E),fun(B,fun(C,D))),Uu),Uua),Uub) = aa(E,fun(C,D),Uu,aa(B,E,Uua,Uub)) ).

% ATP.lambda_426
tff(fact_6419_ATP_Olambda__427,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: fun(D,C),Uua: fun(B,D),Uub: B] : aa(B,C,aa(fun(B,D),fun(B,C),aTP_Lamp_az(fun(D,C),fun(fun(B,D),fun(B,C)),Uu),Uua),Uub) = aa(D,C,Uu,aa(B,D,Uua,Uub)) ).

% ATP.lambda_427
tff(fact_6420_ATP_Olambda__428,axiom,
    ! [D: $tType,C: $tType,E: $tType,Uu: fun(C,fun(D,$o)),Uua: fun(E,C),Uub: E] : aa(E,fun(D,$o),aa(fun(E,C),fun(E,fun(D,$o)),aTP_Lamp_js(fun(C,fun(D,$o)),fun(fun(E,C),fun(E,fun(D,$o))),Uu),Uua),Uub) = aa(C,fun(D,$o),Uu,aa(E,C,Uua,Uub)) ).

% ATP.lambda_428
tff(fact_6421_ATP_Olambda__429,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(C,B),Uua: fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),Uub: fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat))))] : aa(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),B,aa(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),B),aTP_Lamp_vn(fun(C,B),fun(fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C),fun(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),B)),Uu),Uua),Uub) = aa(C,B,Uu,aa(fun(heap_ext(product_unit),option(product_prod(D,product_prod(heap_ext(product_unit),nat)))),C,Uua,Uub)) ).

% ATP.lambda_429
tff(fact_6422_ATP_Olambda__430,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(C,B),Uua: fun(D,C),Uub: D] : aa(D,B,aa(fun(D,C),fun(D,B),aTP_Lamp_ag(fun(C,B),fun(fun(D,C),fun(D,B)),Uu),Uua),Uub) = aa(C,B,Uu,aa(D,C,Uua,Uub)) ).

% ATP.lambda_430
tff(fact_6423_ATP_Olambda__431,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(B,fun(C,$o)),Uua: fun(D,B),Uub: D] : aa(D,fun(C,$o),aa(fun(D,B),fun(D,fun(C,$o)),aTP_Lamp_tz(fun(B,fun(C,$o)),fun(fun(D,B),fun(D,fun(C,$o))),Uu),Uua),Uub) = aa(B,fun(C,$o),Uu,aa(D,B,Uua,Uub)) ).

% ATP.lambda_431
tff(fact_6424_ATP_Olambda__432,axiom,
    ! [E: $tType,D: $tType,Uu: fun(D,E),Uua: fun(E,$o),Uub: D] :
      ( aa(D,$o,aa(fun(E,$o),fun(D,$o),aTP_Lamp_us(fun(D,E),fun(fun(E,$o),fun(D,$o)),Uu),Uua),Uub)
    <=> aa(E,$o,Uua,aa(D,E,Uu,Uub)) ) ).

% ATP.lambda_432
tff(fact_6425_ATP_Olambda__433,axiom,
    ! [D: $tType,C: $tType,B: $tType] :
      ( comm_monoid_mult(D)
     => ! [Uu: fun(B,C),Uua: fun(C,D),Uub: B] : aa(B,D,aa(fun(C,D),fun(B,D),aTP_Lamp_tl(fun(B,C),fun(fun(C,D),fun(B,D)),Uu),Uua),Uub) = aa(C,D,Uua,aa(B,C,Uu,Uub)) ) ).

% ATP.lambda_433
tff(fact_6426_ATP_Olambda__434,axiom,
    ! [B: $tType,Uu: fun(code_natural,B),Uua: code_natural,Uub: B] : aa(B,B,aa(code_natural,fun(B,B),aTP_Lamp_ri(fun(code_natural,B),fun(code_natural,fun(B,B)),Uu),Uua),Uub) = aa(code_natural,B,Uu,Uua) ).

% ATP.lambda_434
tff(fact_6427_ATP_Olambda__435,axiom,
    ! [B: $tType,C: $tType,E: $tType,Uu: fun(E,set(C)),Uua: E,Uub: B] : aa(B,set(C),aa(E,fun(B,set(C)),aTP_Lamp_jy(fun(E,set(C)),fun(E,fun(B,set(C))),Uu),Uua),Uub) = aa(E,set(C),Uu,Uua) ).

% ATP.lambda_435
tff(fact_6428_ATP_Olambda__436,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(D,fun(B,D)),Uua: D,Uub: C] : aa(C,fun(B,D),aa(D,fun(C,fun(B,D)),aTP_Lamp_qs(fun(D,fun(B,D)),fun(D,fun(C,fun(B,D))),Uu),Uua),Uub) = aa(D,fun(B,D),Uu,Uua) ).

% ATP.lambda_436
tff(fact_6429_ATP_Olambda__437,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,$o),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_vs(fun(B,$o),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> aa(B,$o,Uu,Uua) ) ).

% ATP.lambda_437
tff(fact_6430_ATP_Olambda__438,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: fun(B,D),Uua: B,Uub: C] : aa(C,D,aa(B,fun(C,D),aTP_Lamp_iy(fun(B,D),fun(B,fun(C,D)),Uu),Uua),Uub) = aa(B,D,Uu,Uua) ).

% ATP.lambda_438
tff(fact_6431_ATP_Olambda__439,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: fun(B,C),Uua: B,Uub: D] : aa(D,C,aa(B,fun(D,C),aTP_Lamp_nf(fun(B,C),fun(B,fun(D,C)),Uu),Uua),Uub) = aa(B,C,Uu,Uua) ).

% ATP.lambda_439
tff(fact_6432_ATP_Olambda__440,axiom,
    ! [B: $tType,C: $tType,Uu: C,Uua: fun(C,heap_Time_Heap(B)),Uub: product_unit] : aa(product_unit,heap_Time_Heap(B),aa(fun(C,heap_Time_Heap(B)),fun(product_unit,heap_Time_Heap(B)),aTP_Lamp_as(C,fun(fun(C,heap_Time_Heap(B)),fun(product_unit,heap_Time_Heap(B))),Uu),Uua),Uub) = aa(C,heap_Time_Heap(B),Uua,Uu) ).

% ATP.lambda_440
tff(fact_6433_ATP_Olambda__441,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] : aa(B,fun(product_prod(B,B),$o),aa(B,fun(B,fun(product_prod(B,B),$o)),aTP_Lamp_mi(set(product_prod(B,B)),fun(B,fun(B,fun(product_prod(B,B),$o))),Uu),Uua),Uub) = aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(B,fun(B,fun(B,$o)),aa(B,fun(B,fun(B,fun(B,$o))),aTP_Lamp_mh(set(product_prod(B,B)),fun(B,fun(B,fun(B,fun(B,$o)))),Uu),Uua),Uub)) ).

% ATP.lambda_441
tff(fact_6434_ATP_Olambda__442,axiom,
    ! [B: $tType,Uu: heap_Time_Heap(B),Uua: heap_ext(product_unit),Uub: B] : aa(B,fun(product_prod(heap_ext(product_unit),nat),$o),aa(heap_ext(product_unit),fun(B,fun(product_prod(heap_ext(product_unit),nat),$o)),aTP_Lamp_md(heap_Time_Heap(B),fun(heap_ext(product_unit),fun(B,fun(product_prod(heap_ext(product_unit),nat),$o))),Uu),Uua),Uub) = aa(fun(heap_ext(product_unit),fun(nat,$o)),fun(product_prod(heap_ext(product_unit),nat),$o),product_case_prod(heap_ext(product_unit),nat,$o),aa(B,fun(heap_ext(product_unit),fun(nat,$o)),aa(heap_ext(product_unit),fun(B,fun(heap_ext(product_unit),fun(nat,$o))),aTP_Lamp_mc(heap_Time_Heap(B),fun(heap_ext(product_unit),fun(B,fun(heap_ext(product_unit),fun(nat,$o)))),Uu),Uua),Uub)) ).

% ATP.lambda_442
tff(fact_6435_ATP_Olambda__443,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: option(B)] : aa(option(B),option(B),aa(B,fun(option(B),option(B)),aTP_Lamp_vw(fun(B,fun(B,B)),fun(B,fun(option(B),option(B))),Uu),Uua),Uub) = aa(B,option(B),some(B),aa(option(B),B,aa(fun(B,B),fun(option(B),B),aa(B,fun(fun(B,B),fun(option(B),B)),case_option(B,B),Uua),aa(B,fun(B,B),Uu,Uua)),Uub)) ).

% ATP.lambda_443
tff(fact_6436_ATP_Olambda__444,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uua: product_prod(code_natural,code_natural),Uub: C] : aa(C,pred(B),aa(product_prod(code_natural,code_natural),fun(C,pred(B)),aTP_Lamp_uk(fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(product_prod(code_natural,code_natural),fun(C,pred(B))),Uu),Uua),Uub) = aa(product_prod(pred(B),product_prod(code_natural,code_natural)),pred(B),product_fst(pred(B),product_prod(code_natural,code_natural)),aa(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)),aa(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),Uu,Uub),Uua)) ).

% ATP.lambda_444
tff(fact_6437_ATP_Olambda__445,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: B] : aa(B,option(B),aa(B,fun(B,option(B)),aTP_Lamp_ai(fun(B,fun(B,B)),fun(B,fun(B,option(B))),Uu),Uua),Uub) = aa(B,option(B),some(B),aa(B,B,aa(B,fun(B,B),Uu,Uua),Uub)) ).

% ATP.lambda_445
tff(fact_6438_ATP_Olambda__446,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(B,fun(C,fun(D,$o))),Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_vt(fun(B,fun(C,fun(D,$o))),fun(B,fun(C,$o)),Uu),Uua),Uub)
    <=> ? [X_1: D] : aa(D,$o,aa(C,fun(D,$o),aa(B,fun(C,fun(D,$o)),Uu,Uua),Uub),X_1) ) ).

% ATP.lambda_446
tff(fact_6439_ATP_Olambda__447,axiom,
    ! [C: $tType,B: $tType,Uu: set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),Uua: set(old_node(B,C)),Uub: set(old_node(B,C))] : aa(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aTP_Lamp_xp(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),Uu),Uua),Uub) = aa(set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),complete_Sup_Sup(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),image2(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),fun(product_prod(set(old_node(B,C)),set(old_node(B,C))),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),product_case_prod(set(old_node(B,C)),set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),aTP_Lamp_xo(set(old_node(B,C)),fun(set(old_node(B,C)),fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))))),Uua),Uub))),Uu)) ).

% ATP.lambda_447
tff(fact_6440_ATP_Olambda__448,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),Uua: pred(C),Uub: product_prod(code_natural,code_natural)] : aa(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),aa(pred(C),fun(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),aTP_Lamp_ul(fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(pred(C),fun(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))))),Uu),Uua),Uub) = aa(pred(B),fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural))),product_Pair(pred(B),product_prod(code_natural,code_natural)),bind2(C,B,Uua,aa(product_prod(code_natural,code_natural),fun(C,pred(B)),aTP_Lamp_uk(fun(C,fun(product_prod(code_natural,code_natural),product_prod(pred(B),product_prod(code_natural,code_natural)))),fun(product_prod(code_natural,code_natural),fun(C,pred(B))),Uu),Uub))) ).

% ATP.lambda_448
tff(fact_6441_ATP_Olambda__449,axiom,
    ! [C: $tType,B: $tType] :
      ( euclid4440199948858584721cancel(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B] :
          ( aa(B,$o,aa(C,fun(B,$o),aTP_Lamp_mn(fun(B,C),fun(C,fun(B,$o)),Uu),Uua),Uub)
        <=> ~ dvd_dvd(C,Uua,aa(B,C,Uu,Uub)) ) ) ).

% ATP.lambda_449
tff(fact_6442_ATP_Olambda__450,axiom,
    ! [B: $tType,C: $tType,E: $tType,Uu: fun(E,set(C)),Uua: set(E),Uub: B] : aa(B,set(C),aa(set(E),fun(B,set(C)),aTP_Lamp_kb(fun(E,set(C)),fun(set(E),fun(B,set(C))),Uu),Uua),Uub) = aa(set(set(C)),set(C),complete_Sup_Sup(set(C)),aa(set(E),set(set(C)),image2(E,set(C),Uu),Uua)) ).

% ATP.lambda_450
tff(fact_6443_ATP_Olambda__451,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(B,fun(C,fun(D,$o))),Uua: B,Uub: D] :
      ( aa(D,$o,aa(B,fun(D,$o),aTP_Lamp_vu(fun(B,fun(C,fun(D,$o))),fun(B,fun(D,$o)),Uu),Uua),Uub)
    <=> ? [B7: C] : aa(D,$o,aa(C,fun(D,$o),aa(B,fun(C,fun(D,$o)),Uu,Uua),B7),Uub) ) ).

% ATP.lambda_451
tff(fact_6444_ATP_Olambda__452,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(B,fun(C,fun(D,$o))),Uua: C,Uub: D] :
      ( aa(D,$o,aa(C,fun(D,$o),aTP_Lamp_vv(fun(B,fun(C,fun(D,$o))),fun(C,fun(D,$o)),Uu),Uua),Uub)
    <=> ? [A7: B] : aa(D,$o,aa(C,fun(D,$o),aa(B,fun(C,fun(D,$o)),Uu,A7),Uua),Uub) ) ).

% ATP.lambda_452
tff(fact_6445_ATP_Olambda__453,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(B,fun(C,D)),Uua: set(D),Uub: B] :
      ( aa(B,$o,aa(set(D),fun(B,$o),aTP_Lamp_lr(fun(B,fun(C,D)),fun(set(D),fun(B,$o)),Uu),Uua),Uub)
    <=> ? [B7: C] : member(D,aa(C,D,aa(B,fun(C,D),Uu,Uub),B7),Uua) ) ).

% ATP.lambda_453
tff(fact_6446_ATP_Olambda__454,axiom,
    ! [B: $tType,C: $tType,Uu: list(B),Uua: list(C),Uub: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(list(C),fun(product_prod(B,C),$o),aTP_Lamp_qi(list(B),fun(list(C),fun(product_prod(B,C),$o)),Uu),Uua),Uub)
    <=> ? [I3: nat] :
          ( ( Uub = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(nat,B,nth(B,Uu),I3)),aa(nat,C,nth(C,Uua),I3)) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(nat,nat,ord_min(nat,aa(list(B),nat,size_size(list(B)),Uu)),aa(list(C),nat,size_size(list(C)),Uua))) ) ) ).

% ATP.lambda_454
tff(fact_6447_ATP_Olambda__455,axiom,
    ! [C: $tType,B: $tType,Uu: set(B),Uua: fun(B,C),Uub: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(fun(B,C),fun(product_prod(B,C),$o),aTP_Lamp_vh(set(B),fun(fun(B,C),fun(product_prod(B,C),$o)),Uu),Uua),Uub)
    <=> ? [A7: B] :
          ( ( Uub = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),A7),aa(B,C,Uua,A7)) )
          & member(B,A7,Uu) ) ) ).

% ATP.lambda_455
tff(fact_6448_ATP_Olambda__456,axiom,
    ! [B: $tType,Uu: nat,Uua: list(B),Uub: B] :
      ( aa(B,$o,aa(list(B),fun(B,$o),aTP_Lamp_pf(nat,fun(list(B),fun(B,$o)),Uu),Uua),Uub)
    <=> ? [I3: nat] :
          ( ( Uub = aa(nat,B,nth(B,Uua),I3) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),Uu),I3)
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(B),nat,size_size(list(B)),Uua)) ) ) ).

% ATP.lambda_456
tff(fact_6449_ATP_Olambda__457,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,set(B)),Uua: list(C),Uub: set(B)] :
      ( aa(set(B),$o,aa(list(C),fun(set(B),$o),aTP_Lamp_qe(fun(C,set(B)),fun(list(C),fun(set(B),$o)),Uu),Uua),Uub)
    <=> ? [I3: nat] :
          ( ( Uub = aa(C,set(B),Uu,aa(nat,C,nth(C,Uua),I3)) )
          & aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),I3),aa(list(C),nat,size_size(list(C)),Uua)) ) ) ).

% ATP.lambda_457
tff(fact_6450_ATP_Olambda__458,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,set(B)),Uua: list(C),Uub: set(B)] :
      ( aa(set(B),$o,aa(list(C),fun(set(B),$o),aTP_Lamp_qf(fun(C,set(B)),fun(list(C),fun(set(B),$o)),Uu),Uua),Uub)
    <=> ? [A7: C] :
          ( ( Uub = aa(C,set(B),Uu,A7) )
          & member(C,A7,aa(list(C),set(C),set2(C),Uua)) ) ) ).

% ATP.lambda_458
tff(fact_6451_ATP_Olambda__459,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,B),Uua: set(C),Uub: B] :
      ( aa(B,$o,aa(set(C),fun(B,$o),aTP_Lamp_ln(fun(C,B),fun(set(C),fun(B,$o)),Uu),Uua),Uub)
    <=> ? [L3: C] :
          ( ( Uub = aa(C,B,Uu,L3) )
          & member(C,L3,Uua) ) ) ).

% ATP.lambda_459
tff(fact_6452_ATP_Olambda__460,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,option(B)),Uua: list(C),Uub: B] :
      ( aa(B,$o,aa(list(C),fun(B,$o),aTP_Lamp_ob(fun(C,option(B)),fun(list(C),fun(B,$o)),Uu),Uua),Uub)
    <=> ? [X4: C] :
          ( member(C,X4,aa(list(C),set(C),set2(C),Uua))
          & ( aa(C,option(B),Uu,X4) = aa(B,option(B),some(B),Uub) ) ) ) ).

% ATP.lambda_460
tff(fact_6453_ATP_Olambda__461,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aTP_Lamp_sk(set(product_prod(B,B)),fun(B,fun(B,$o)),Uu),Uua),Uub)
    <=> ! [X4: product_prod(B,B)] :
          ( member(product_prod(B,B),X4,Uu)
         => aa(product_prod(B,B),$o,aa(fun(B,fun(B,$o)),fun(product_prod(B,B),$o),product_case_prod(B,B,$o),aa(B,fun(B,fun(B,$o)),aa(B,fun(B,fun(B,fun(B,$o))),aTP_Lamp_sj(set(product_prod(B,B)),fun(B,fun(B,fun(B,fun(B,$o)))),Uu),Uua),Uub)),X4) ) ) ).

% ATP.lambda_461
tff(fact_6454_ATP_Olambda__462,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(B,fun(C,D)),Uua: set(D),Uub: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(set(D),fun(product_prod(B,C),$o),aTP_Lamp_lq(fun(B,fun(C,D)),fun(set(D),fun(product_prod(B,C),$o)),Uu),Uua),Uub)
    <=> ? [P6: product_prod(B,C)] :
          ( ( Uub = P6 )
          & member(D,aa(C,D,aa(B,fun(C,D),Uu,aa(product_prod(B,C),B,product_fst(B,C),P6)),aa(product_prod(B,C),C,product_snd(B,C),P6)),Uua) ) ) ).

% ATP.lambda_462
tff(fact_6455_ATP_Olambda__463,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(C,B)),Uua: set(C),Uub: B] :
      ( aa(B,$o,aa(set(C),fun(B,$o),aTP_Lamp_so(set(product_prod(C,B)),fun(set(C),fun(B,$o)),Uu),Uua),Uub)
    <=> ? [X4: C] :
          ( member(C,X4,Uua)
          & member(product_prod(C,B),aa(B,product_prod(C,B),aa(C,fun(B,product_prod(C,B)),product_Pair(C,B),X4),Uub),Uu) ) ) ).

% ATP.lambda_463
tff(fact_6456_ATP_Olambda__464,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,option(B)),Uua: set(C),Uub: B] :
      ( aa(B,$o,aa(set(C),fun(B,$o),aTP_Lamp_sq(fun(C,option(B)),fun(set(C),fun(B,$o)),Uu),Uua),Uub)
    <=> ? [X4: C] :
          ( member(C,X4,Uua)
          & ( aa(C,option(B),Uu,X4) = aa(B,option(B),some(B),Uub) ) ) ) ).

% ATP.lambda_464
tff(fact_6457_ATP_Olambda__465,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,B),Uua: fun(C,fun(C,$o)),Uub: product_prod(B,B)] :
      ( aa(product_prod(B,B),$o,aa(fun(C,fun(C,$o)),fun(product_prod(B,B),$o),aTP_Lamp_ll(fun(C,B),fun(fun(C,fun(C,$o)),fun(product_prod(B,B),$o)),Uu),Uua),Uub)
    <=> ? [A7: C,B7: C] :
          ( ( Uub = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(C,B,Uu,A7)),aa(C,B,Uu,B7)) )
          & aa(C,$o,aa(C,fun(C,$o),Uua,A7),B7) ) ) ).

% ATP.lambda_465
tff(fact_6458_ATP_Olambda__466,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(C,C)),Uua: fun(C,B),Uub: product_prod(B,B)] :
      ( aa(product_prod(B,B),$o,aa(fun(C,B),fun(product_prod(B,B),$o),aTP_Lamp_oa(set(product_prod(C,C)),fun(fun(C,B),fun(product_prod(B,B),$o)),Uu),Uua),Uub)
    <=> ? [A18: C,A26: C] :
          ( ( Uub = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),aa(C,B,Uua,A18)),aa(C,B,Uua,A26)) )
          & member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),A18),A26),Uu) ) ) ).

% ATP.lambda_466
tff(fact_6459_ATP_Olambda__467,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: list(B),Uub: list(B)] :
      ( aa(list(B),$o,aa(list(B),fun(list(B),$o),aTP_Lamp_qd(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),Uu),Uua),Uub)
    <=> ? [A7: B,V3: list(B)] :
          ( ( Uub = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Uua),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),A7),V3)) )
          | ? [U5: list(B),Aa4: B,B7: B,Va3: list(B),W4: list(B)] :
              ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Aa4),B7),Uu)
              & ( Uua = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),U5),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Aa4),Va3)) )
              & ( Uub = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),U5),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),B7),W4)) ) ) ) ) ).

% ATP.lambda_467
tff(fact_6460_ATP_Olambda__468,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: multiset(B),Uub: multiset(B)] :
      ( aa(multiset(B),$o,aa(multiset(B),fun(multiset(B),$o),aTP_Lamp_si(set(product_prod(B,B)),fun(multiset(B),fun(multiset(B),$o)),Uu),Uua),Uub)
    <=> ? [A7: B,M03: multiset(B),K10: multiset(B)] :
          ( ( Uub = aa(multiset(B),multiset(B),aa(B,fun(multiset(B),multiset(B)),add_mset(B),A7),M03) )
          & ( Uua = aa(multiset(B),multiset(B),aa(multiset(B),fun(multiset(B),multiset(B)),plus_plus(multiset(B)),M03),K10) )
          & ! [B7: B] :
              ( member(B,B7,set_mset(B,K10))
             => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),B7),A7),Uu) ) ) ) ).

% ATP.lambda_468
tff(fact_6461_ATP_Olambda__469,axiom,
    ! [C: $tType,B: $tType,F4: $tType,D: $tType,E: $tType,Uu: fun(F4,fun(B,fun(D,fun(C,fun(E,$o))))),Uua: F4,Uub: fun(B,option(product_prod(C,product_prod(D,E))))] :
      ( aa(fun(B,option(product_prod(C,product_prod(D,E)))),$o,aa(F4,fun(fun(B,option(product_prod(C,product_prod(D,E)))),$o),aTP_Lamp_xq(fun(F4,fun(B,fun(D,fun(C,fun(E,$o))))),fun(F4,fun(fun(B,option(product_prod(C,product_prod(D,E)))),$o)),Uu),Uua),Uub)
    <=> ! [H6: B,H7: D,R5: C,N7: E] :
          ( ( aa(B,option(product_prod(C,product_prod(D,E))),Uub,H6) = aa(product_prod(C,product_prod(D,E)),option(product_prod(C,product_prod(D,E))),some(product_prod(C,product_prod(D,E))),aa(product_prod(D,E),product_prod(C,product_prod(D,E)),aa(C,fun(product_prod(D,E),product_prod(C,product_prod(D,E))),product_Pair(C,product_prod(D,E)),R5),aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),H7),N7))) )
         => aa(E,$o,aa(C,fun(E,$o),aa(D,fun(C,fun(E,$o)),aa(B,fun(D,fun(C,fun(E,$o))),aa(F4,fun(B,fun(D,fun(C,fun(E,$o)))),Uu,Uua),H6),H7),R5),N7) ) ) ).

% ATP.lambda_469
tff(fact_6462_ATP_Olambda__470,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: list(B),Uub: list(B)] :
      ( aa(list(B),$o,aa(list(B),fun(list(B),$o),aTP_Lamp_qg(set(product_prod(B,B)),fun(list(B),fun(list(B),$o)),Uu),Uua),Uub)
    <=> ? [Us3: list(B),Z4: B,Z10: B,Vs3: list(B)] :
          ( ( Uua = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Z4),Vs3)) )
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Z4),Z10),Uu)
          & ( Uub = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Us3),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Z10),Vs3)) ) ) ) ).

% ATP.lambda_470
tff(fact_6463_ATP_Olambda__471,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: fun(nat,fun(nat,B)),Uuc: nat] : aa(nat,B,aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_wv(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,Uu,Uua),aa(nat,fun(nat,B),aTP_Lamp_wu(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uub),Uuc)),aa(nat,set(nat),set_ord_atMost(nat),Uuc)) ).

% ATP.lambda_471
tff(fact_6464_ATP_Olambda__472,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: fun(nat,fun(nat,B)),Uuc: nat] : aa(nat,B,aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_wm(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,Uu,Uua),aa(nat,fun(nat,B),Uub,Uuc)),set_or7035219750837199246ssThan(nat,zero_zero(nat),Uuc)) ).

% ATP.lambda_472
tff(fact_6465_ATP_Olambda__473,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: fun(nat,fun(nat,B)),Uuc: nat] : aa(nat,B,aa(fun(nat,fun(nat,B)),fun(nat,B),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,B)),aTP_Lamp_ws(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,Uu,Uua),aa(nat,fun(nat,B),Uub,Uuc)),aa(nat,set(nat),set_ord_lessThan(nat),Uuc)) ).

% ATP.lambda_473
tff(fact_6466_ATP_Olambda__474,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,Uu: fun(C,fun(D,fun(E,B))),Uua: E,Uub: C,Uuc: D] : aa(D,B,aa(C,fun(D,B),aa(E,fun(C,fun(D,B)),aTP_Lamp_bm(fun(C,fun(D,fun(E,B))),fun(E,fun(C,fun(D,B))),Uu),Uua),Uub),Uuc) = aa(E,B,aa(D,fun(E,B),aa(C,fun(D,fun(E,B)),Uu,Uub),Uuc),Uua) ).

% ATP.lambda_474
tff(fact_6467_ATP_Olambda__475,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: product_prod(D,B),Uua: B,Uub: C,Uuc: set(product_prod(D,C))] :
      aa(set(product_prod(D,C)),set(product_prod(D,C)),aa(C,fun(set(product_prod(D,C)),set(product_prod(D,C))),aa(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aTP_Lamp_lb(product_prod(D,B),fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),Uu),Uua),Uub),Uuc) = $ite(aa(product_prod(D,B),B,product_snd(D,B),Uu) = Uua,aa(set(product_prod(D,C)),set(product_prod(D,C)),insert2(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),aa(product_prod(D,B),D,product_fst(D,B),Uu)),Uub)),Uuc),Uuc) ).

% ATP.lambda_475
tff(fact_6468_ATP_Olambda__476,axiom,
    ! [C: $tType,B: $tType,Uu: set(B),Uua: fun(B,C),Uub: B,Uuc: C] :
      aa(C,B,aa(B,fun(C,B),aa(fun(B,C),fun(B,fun(C,B)),aTP_Lamp_nr(set(B),fun(fun(B,C),fun(B,fun(C,B))),Uu),Uua),Uub),Uuc) = $ite(member(C,Uuc,aa(set(B),set(C),image2(B,C,Uua),Uu)),aa(C,B,the_inv_into(B,C,Uu,Uua),Uuc),Uub) ).

% ATP.lambda_476
tff(fact_6469_ATP_Olambda__477,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: nat,Uua: fun(nat,B),Uub: fun(nat,B),Uuc: nat] :
          aa(nat,B,aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_dv(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),Uu),Uua),Uub),Uuc) = $ite(
            aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),
            aa(nat,B,Uua,Uuc),
            $ite(Uuc = Uu,zero_zero(B),aa(nat,B,Uub,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uuc),aa(nat,nat,suc,zero_zero(nat))))) ) ) ).

% ATP.lambda_477
tff(fact_6470_ATP_Olambda__478,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: nat,Uua: fun(nat,B),Uub: fun(nat,B),Uuc: nat] :
          aa(nat,B,aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_gd(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),Uu),Uua),Uub),Uuc) = $ite(
            aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),
            aa(nat,B,Uua,Uuc),
            $ite(Uuc = Uu,one_one(B),aa(nat,B,Uub,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uuc),aa(nat,nat,suc,zero_zero(nat))))) ) ) ).

% ATP.lambda_478
tff(fact_6471_ATP_Olambda__479,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: nat,Uua: fun(nat,B),Uub: fun(nat,B),Uuc: nat] :
          aa(nat,B,aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_ge(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),Uu),Uua),Uub),Uuc) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),aa(nat,B,Uua,Uuc),aa(nat,B,Uub,Uuc)) ) ).

% ATP.lambda_479
tff(fact_6472_ATP_Olambda__480,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: nat,Uua: fun(nat,B),Uub: fun(nat,B),Uuc: nat] :
          aa(nat,B,aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_dw(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),Uu),Uua),Uub),Uuc) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),aa(nat,B,Uua,Uuc),aa(nat,B,Uub,Uuc)) ) ).

% ATP.lambda_480
tff(fact_6473_ATP_Olambda__481,axiom,
    ! [B: $tType,Uu: nat,Uua: fun(nat,B),Uub: fun(nat,B),Uuc: nat] :
      aa(nat,B,aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aTP_Lamp_wi(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),Uu),Uua),Uub),Uuc) = $ite(aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uuc),Uu),aa(nat,B,Uua,Uuc),aa(nat,B,Uub,Uuc)) ).

% ATP.lambda_481
tff(fact_6474_ATP_Olambda__482,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,C),Uua: set(B),Uub: fun(B,C),Uuc: B] :
      aa(B,C,aa(fun(B,C),fun(B,C),aa(set(B),fun(fun(B,C),fun(B,C)),aTP_Lamp_nn(fun(B,C),fun(set(B),fun(fun(B,C),fun(B,C))),Uu),Uua),Uub),Uuc) = $ite(member(B,Uuc,Uua),aa(B,C,Uu,Uuc),aa(B,C,Uub,Uuc)) ).

% ATP.lambda_482
tff(fact_6475_ATP_Olambda__483,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [Uu: B,Uua: fun(B,C),Uub: fun(B,C),Uuc: B] :
          aa(B,C,aa(fun(B,C),fun(B,C),aa(fun(B,C),fun(fun(B,C),fun(B,C)),aTP_Lamp_if(B,fun(fun(B,C),fun(fun(B,C),fun(B,C))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(B,C,Uua,Uuc),aa(B,C,Uub,Uuc)) ) ).

% ATP.lambda_483
tff(fact_6476_ATP_Olambda__484,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: B,Uua: fun(B,C),Uub: C,Uuc: B] :
          aa(B,C,aa(C,fun(B,C),aa(fun(B,C),fun(C,fun(B,C)),aTP_Lamp_ic(B,fun(fun(B,C),fun(C,fun(B,C))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(B,C,Uua,Uuc),Uub) ) ).

% ATP.lambda_484
tff(fact_6477_ATP_Olambda__485,axiom,
    ! [C: $tType,B: $tType,Uu: B,Uua: C,Uub: fun(B,option(C)),Uuc: B] :
      aa(B,option(C),aa(fun(B,option(C)),fun(B,option(C)),aa(C,fun(fun(B,option(C)),fun(B,option(C))),aTP_Lamp_nu(B,fun(C,fun(fun(B,option(C)),fun(B,option(C)))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uu,aa(C,option(C),some(C),Uua),aa(B,option(C),Uub,Uuc)) ).

% ATP.lambda_485
tff(fact_6478_ATP_Olambda__486,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,option(B)),Uua: C,Uub: B,Uuc: C] :
      aa(C,option(B),aa(B,fun(C,option(B)),aa(C,fun(B,fun(C,option(B))),aTP_Lamp_lo(fun(C,option(B)),fun(C,fun(B,fun(C,option(B)))),Uu),Uua),Uub),Uuc) = $ite(Uuc = Uua,aa(B,option(B),some(B),Uub),aa(C,option(B),Uu,Uuc)) ).

% ATP.lambda_486
tff(fact_6479_ATP_Olambda__487,axiom,
    ! [B: $tType,Uu: fun(code_natural,B),Uua: code_natural,Uub: code_natural,Uuc: product_unit] :
      aa(product_unit,seq(B),aa(code_natural,fun(product_unit,seq(B)),aa(code_natural,fun(code_natural,fun(product_unit,seq(B))),aTP_Lamp_vx(fun(code_natural,B),fun(code_natural,fun(code_natural,fun(product_unit,seq(B)))),Uu),Uua),Uub),Uuc) = $ite(aa(code_natural,$o,aa(code_natural,fun(code_natural,$o),ord_less(code_natural),Uub),Uua),empty(B),insert(B,aa(code_natural,B,Uu,Uua),iterate_upto(B,Uu,aa(code_natural,code_natural,aa(code_natural,fun(code_natural,code_natural),plus_plus(code_natural),Uua),one_one(code_natural)),Uub))) ).

% ATP.lambda_487
tff(fact_6480_ATP_Olambda__488,axiom,
    ! [B: $tType,Uu: fun(B,$o),Uua: B,Uub: list(B),Uuc: list(B)] :
      aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),aa(B,fun(list(B),fun(list(B),product_prod(list(B),list(B)))),aTP_Lamp_rc(fun(B,$o),fun(B,fun(list(B),fun(list(B),product_prod(list(B),list(B))))),Uu),Uua),Uub),Uuc) = $ite(aa(B,$o,Uu,Uua),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uua),Uub)),Uuc),aa(list(B),product_prod(list(B),list(B)),aa(list(B),fun(list(B),product_prod(list(B),list(B))),product_Pair(list(B),list(B)),Uub),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uua),Uuc))) ).

% ATP.lambda_488
tff(fact_6481_ATP_Olambda__489,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,$o),Uua: fun(C,B),Uub: fun(C,B),Uuc: C] :
      aa(C,B,aa(fun(C,B),fun(C,B),aa(fun(C,B),fun(fun(C,B),fun(C,B)),aTP_Lamp_wx(fun(C,$o),fun(fun(C,B),fun(fun(C,B),fun(C,B))),Uu),Uua),Uub),Uuc) = $ite(aa(C,$o,Uu,Uuc),aa(C,B,Uua,Uuc),aa(C,B,Uub,Uuc)) ).

% ATP.lambda_489
tff(fact_6482_ATP_Olambda__490,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_add(C)
     => ! [Uu: fun(B,$o),Uua: fun(B,C),Uub: fun(B,C),Uuc: B] :
          aa(B,C,aa(fun(B,C),fun(B,C),aa(fun(B,C),fun(fun(B,C),fun(B,C)),aTP_Lamp_mv(fun(B,$o),fun(fun(B,C),fun(fun(B,C),fun(B,C))),Uu),Uua),Uub),Uuc) = $ite(aa(B,$o,Uu,Uuc),aa(B,C,Uua,Uuc),aa(B,C,Uub,Uuc)) ) ).

% ATP.lambda_490
tff(fact_6483_ATP_Olambda__491,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: set(product_prod(B,C)),Uua: D,Uub: B,Uuc: set(product_prod(D,C))] : aa(set(product_prod(D,C)),set(product_prod(D,C)),aa(B,fun(set(product_prod(D,C)),set(product_prod(D,C))),aa(D,fun(B,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aTP_Lamp_lg(set(product_prod(B,C)),fun(D,fun(B,fun(set(product_prod(D,C)),set(product_prod(D,C))))),Uu),Uua),Uub),Uuc) = finite_fold(product_prod(B,C),set(product_prod(D,C)),aa(fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),fun(product_prod(B,C),fun(set(product_prod(D,C)),set(product_prod(D,C)))),product_case_prod(B,C,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aa(B,fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),aTP_Lamp_lf(D,fun(B,fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C)))))),Uua),Uub)),Uuc,Uu) ).

% ATP.lambda_491
tff(fact_6484_ATP_Olambda__492,axiom,
    ! [B: $tType,D: $tType,C: $tType,Uu: set(product_prod(C,D)),Uua: B,Uub: C,Uuc: set(product_prod(B,D))] : aa(set(product_prod(B,D)),set(product_prod(B,D)),aa(C,fun(set(product_prod(B,D)),set(product_prod(B,D))),aa(B,fun(C,fun(set(product_prod(B,D)),set(product_prod(B,D)))),aTP_Lamp_ld(set(product_prod(C,D)),fun(B,fun(C,fun(set(product_prod(B,D)),set(product_prod(B,D))))),Uu),Uua),Uub),Uuc) = finite_fold(product_prod(C,D),set(product_prod(B,D)),aa(fun(C,fun(D,fun(set(product_prod(B,D)),set(product_prod(B,D))))),fun(product_prod(C,D),fun(set(product_prod(B,D)),set(product_prod(B,D)))),product_case_prod(C,D,fun(set(product_prod(B,D)),set(product_prod(B,D)))),aa(C,fun(C,fun(D,fun(set(product_prod(B,D)),set(product_prod(B,D))))),aTP_Lamp_lc(B,fun(C,fun(C,fun(D,fun(set(product_prod(B,D)),set(product_prod(B,D)))))),Uua),Uub)),Uuc,Uu) ).

% ATP.lambda_492
tff(fact_6485_ATP_Olambda__493,axiom,
    ! [C: $tType,D: $tType,E: $tType,Uu: fun(C,fun(D,$o)),Uua: fun(E,D),Uub: C,Uuc: E] :
      ( aa(E,$o,aa(C,fun(E,$o),aa(fun(E,D),fun(C,fun(E,$o)),aTP_Lamp_jt(fun(C,fun(D,$o)),fun(fun(E,D),fun(C,fun(E,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(D,$o,aa(C,fun(D,$o),Uu,Uub),aa(E,D,Uua,Uuc)) ) ).

% ATP.lambda_493
tff(fact_6486_ATP_Olambda__494,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(B,fun(C,$o)),Uua: fun(D,C),Uub: B,Uuc: D] :
      ( aa(D,$o,aa(B,fun(D,$o),aa(fun(D,C),fun(B,fun(D,$o)),aTP_Lamp_ua(fun(B,fun(C,$o)),fun(fun(D,C),fun(B,fun(D,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(C,$o,aa(B,fun(C,$o),Uu,Uub),aa(D,C,Uua,Uuc)) ) ).

% ATP.lambda_494
tff(fact_6487_ATP_Olambda__495,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,fun(C,$o)),Uua: fun(B,fun(C,$o)),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aTP_Lamp_vq(fun(B,fun(C,$o)),fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( aa(C,$o,aa(B,fun(C,$o),Uu,Uub),Uuc)
        & aa(C,$o,aa(B,fun(C,$o),Uua,Uub),Uuc) ) ) ).

% ATP.lambda_495
tff(fact_6488_ATP_Olambda__496,axiom,
    ! [Uu: code_natural,Uua: code_natural,Uub: code_natural,Uuc: code_natural] : aa(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),aa(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),aa(code_natural,fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)))),aTP_Lamp_sb(code_natural,fun(code_natural,fun(code_natural,fun(code_natural,product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))))),Uu),Uua),Uub),Uuc) = aa(product_prod(code_natural,code_natural),product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),aa(product_prod(code_natural,code_natural),fun(product_prod(code_natural,code_natural),product_prod(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural))),product_Pair(product_prod(code_natural,code_natural),product_prod(code_natural,code_natural)),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),inc_shift(aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2))))))))))))))))))))))))))))))),Uu)),Uuc)),aa(code_natural,product_prod(code_natural,code_natural),aa(code_natural,fun(code_natural,product_prod(code_natural,code_natural)),product_Pair(code_natural,code_natural),Uub),inc_shift(aa(num,code_natural,numeral_numeral(code_natural),aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit0,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,aa(num,num,bit1,one2))))))))))))))))))))))))))))))),Uua))) ).

% ATP.lambda_496
tff(fact_6489_ATP_Olambda__497,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,$o)),Uua: set(B),Uub: B,Uuc: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(set(B),fun(B,fun(B,$o)),aTP_Lamp_me(fun(B,fun(B,$o)),fun(set(B),fun(B,fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uuc),product_Sigma(B,B,Uua,aTP_Lamp_ma(set(B),fun(B,set(B)),Uua)))
        & aa(B,$o,aa(B,fun(B,$o),Uu,Uub),Uuc) ) ) ).

% ATP.lambda_497
tff(fact_6490_ATP_Olambda__498,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] : aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),aa(nat,fun(nat,fun(nat,product_prod(nat,nat))),aTP_Lamp_cu(nat,fun(nat,fun(nat,fun(nat,product_prod(nat,nat)))),Uu),Uua),Uub),Uuc) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uu),Uub)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uua),Uuc))),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uu),Uuc)),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uua),Uub))) ).

% ATP.lambda_498
tff(fact_6491_ATP_Olambda__499,axiom,
    ! [C: $tType,B: $tType,Uu: set(old_node(B,C)),Uua: set(old_node(B,C)),Uub: set(old_node(B,C)),Uuc: set(old_node(B,C))] : aa(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))),aTP_Lamp_xo(set(old_node(B,C)),fun(set(old_node(B,C)),fun(set(old_node(B,C)),fun(set(old_node(B,C)),set(product_prod(set(old_node(B,C)),set(old_node(B,C))))))),Uu),Uua),Uub),Uuc) = aa(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),set(product_prod(set(old_node(B,C)),set(old_node(B,C)))),insert2(product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C))),aa(set(old_node(B,C)),fun(set(old_node(B,C)),product_prod(set(old_node(B,C)),set(old_node(B,C)))),product_Pair(set(old_node(B,C)),set(old_node(B,C))),old_Scons(B,C,Uu,Uub)),old_Scons(B,C,Uua,Uuc))),bot_bot(set(product_prod(set(old_node(B,C)),set(old_node(B,C)))))) ).

% ATP.lambda_499
tff(fact_6492_ATP_Olambda__500,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: B,Uub: array(B),Uuc: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(B,fun(array(B),fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_rt(nat,fun(B,fun(array(B),fun(heap_ext(product_unit),product_prod(B,product_prod(heap_ext(product_unit),nat))))),Uu),Uua),Uub),Uuc) = aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),aa(nat,B,nth(B,array_get(B,Uuc,Uub)),Uu)),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),array_update(B,Uub,Uu,Uua,Uuc)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) ) ).

% ATP.lambda_500
tff(fact_6493_ATP_Olambda__501,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: set(B),Uub: B,Uuc: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(set(B),fun(B,fun(B,$o)),aTP_Lamp_nl(set(product_prod(B,B)),fun(set(B),fun(B,fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uuc),Uu)
        & ~ member(B,Uub,Uua)
        & ~ member(B,Uuc,Uua) ) ) ).

% ATP.lambda_501
tff(fact_6494_ATP_Olambda__502,axiom,
    ! [B: $tType,Uu: fun(B,nat),Uua: set(product_prod(B,B)),Uub: B,Uuc: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aTP_Lamp_db(fun(B,nat),fun(set(product_prod(B,B)),fun(B,fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(B,nat,Uu,Uub)),aa(B,nat,Uu,Uuc))
        | ( aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(B,nat,Uu,Uub)),aa(B,nat,Uu,Uuc))
          & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uuc),Uua) ) ) ) ).

% ATP.lambda_502
tff(fact_6495_ATP_Olambda__503,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(C,C)),Uua: fun(B,C),Uub: B,Uuc: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(fun(B,C),fun(B,fun(B,$o)),aTP_Lamp_gu(set(product_prod(C,C)),fun(fun(B,C),fun(B,fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,Uua,Uub)),aa(B,C,Uua,Uuc)),Uu) ) ).

% ATP.lambda_503
tff(fact_6496_ATP_Olambda__504,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,option(C)),Uua: fun(product_prod(B,C),$o),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(product_prod(B,C),$o),fun(B,fun(C,$o)),aTP_Lamp_df(fun(B,option(C)),fun(fun(product_prod(B,C),$o),fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( ( aa(B,option(C),Uu,Uub) = aa(C,option(C),some(C),Uuc) )
        & aa(product_prod(B,C),$o,Uua,aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uub),Uuc)) ) ) ).

% ATP.lambda_504
tff(fact_6497_ATP_Olambda__505,axiom,
    ! [B: $tType] :
      ( comm_ring_1(B)
     => ! [Uu: B,Uua: B,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(B,fun(nat,fun(nat,B)),aTP_Lamp_fe(B,fun(B,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,binomial(Uub),Uuc))),comm_s3205402744901411588hammer(B,Uu,Uuc))),comm_s3205402744901411588hammer(B,Uua,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uub),Uuc))) ) ).

% ATP.lambda_505
tff(fact_6498_ATP_Olambda__506,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] : aa(nat,nat,aa(nat,fun(nat,nat),aa(nat,fun(nat,fun(nat,nat)),aTP_Lamp_ev(nat,fun(nat,fun(nat,fun(nat,nat))),Uu),Uua),Uub),Uuc) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,semiring_1_of_nat(nat),aa(nat,nat,binomial(Uub),Uuc))),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),Uu),Uuc))),aa(nat,nat,aa(nat,fun(nat,nat),power_power(nat),Uua),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uub),Uuc))) ).

% ATP.lambda_506
tff(fact_6499_ATP_Olambda__507,axiom,
    ! [B: $tType] :
      ( comm_semiring_1(B)
     => ! [Uu: B,Uua: B,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(B,fun(nat,fun(nat,B)),aTP_Lamp_ex(B,fun(B,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,semiring_1_of_nat(B),aa(nat,nat,binomial(Uub),Uuc))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uu),Uuc))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uua),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uub),Uuc))) ) ).

% ATP.lambda_507
tff(fact_6500_ATP_Olambda__508,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: nat,Uub: list(B),Uuc: list(B)] :
      ( aa(list(B),$o,aa(list(B),fun(list(B),$o),aa(nat,fun(list(B),fun(list(B),$o)),aTP_Lamp_pj(set(product_prod(B,B)),fun(nat,fun(list(B),fun(list(B),$o))),Uu),Uua),Uub),Uuc)
    <=> ( ( aa(list(B),nat,size_size(list(B)),Uub) = Uua )
        & ( aa(list(B),nat,size_size(list(B)),Uuc) = Uua )
        & ? [Xys2: list(B),X4: B,Y3: B,Xs6: list(B),Ys5: list(B)] :
            ( ( Uub = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xys2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),X4),Xs6)) )
            & ( Uuc = aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Xys2),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Y3),Ys5)) )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),X4),Y3),Uu) ) ) ) ).

% ATP.lambda_508
tff(fact_6501_ATP_Olambda__509,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [Uu: B,Uua: nat,Uub: B,Uuc: nat] : aa(nat,B,aa(B,fun(nat,B),aa(nat,fun(B,fun(nat,B)),aTP_Lamp_et(B,fun(nat,fun(B,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uub),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),aa(nat,nat,suc,Uuc)))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uu),Uuc)) ) ).

% ATP.lambda_509
tff(fact_6502_ATP_Olambda__510,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,C),Uua: set(B),Uub: B,Uuc: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(set(B),fun(B,fun(B,$o)),aTP_Lamp_wz(fun(B,C),fun(set(B),fun(B,fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member(B,Uuc,Uua)
        & ( aa(B,C,Uu,Uub) = aa(B,C,Uu,Uuc) ) ) ) ).

% ATP.lambda_510
tff(fact_6503_ATP_Olambda__511,axiom,
    ! [C: $tType,B: $tType,Uu: set(C),Uua: fun(C,B),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(C,B),fun(B,fun(C,$o)),aTP_Lamp_nx(set(C),fun(fun(C,B),fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member(C,Uuc,Uu)
        & ( aa(C,B,Uua,Uuc) = Uub ) ) ) ).

% ATP.lambda_511
tff(fact_6504_ATP_Olambda__512,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,C),Uua: set(B),Uub: C,Uuc: B] :
      ( aa(B,$o,aa(C,fun(B,$o),aa(set(B),fun(C,fun(B,$o)),aTP_Lamp_nd(fun(B,C),fun(set(B),fun(C,fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> ( member(B,Uuc,Uua)
        & ( aa(B,C,Uu,Uuc) = Uub ) ) ) ).

% ATP.lambda_512
tff(fact_6505_ATP_Olambda__513,axiom,
    ! [B: $tType] :
      ( ( monoid_mult(B)
        & comm_ring(B) )
     => ! [Uu: B,Uua: nat,Uub: B,Uuc: nat] : aa(nat,B,aa(B,fun(nat,B),aa(nat,fun(B,fun(nat,B)),aTP_Lamp_eu(B,fun(nat,fun(B,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uu),Uuc)),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uub),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uua),Uuc))) ) ).

% ATP.lambda_513
tff(fact_6506_ATP_Olambda__514,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] : aa(nat,nat,aa(nat,fun(nat,nat),aa(nat,fun(nat,fun(nat,nat)),aTP_Lamp_es(nat,fun(nat,fun(nat,fun(nat,nat))),Uu),Uua),Uub),Uuc) = aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),aa(nat,nat,binomial(Uu),Uuc)),aa(nat,nat,binomial(Uua),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uub),Uuc))) ).

% ATP.lambda_514
tff(fact_6507_ATP_Olambda__515,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aa(nat,fun(nat,fun(nat,$o)),aTP_Lamp_ci(nat,fun(nat,fun(nat,fun(nat,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less_eq(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uuc)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)) ) ).

% ATP.lambda_515
tff(fact_6508_ATP_Olambda__516,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aa(nat,fun(nat,fun(nat,$o)),aTP_Lamp_cg(nat,fun(nat,fun(nat,fun(nat,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uuc)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)) ) ).

% ATP.lambda_516
tff(fact_6509_ATP_Olambda__517,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] : aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),aa(nat,fun(nat,fun(nat,product_prod(nat,nat))),aTP_Lamp_cq(nat,fun(nat,fun(nat,fun(nat,product_prod(nat,nat)))),Uu),Uua),Uub),Uuc) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uub)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uuc)) ).

% ATP.lambda_517
tff(fact_6510_ATP_Olambda__518,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] : aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),aa(nat,fun(nat,fun(nat,product_prod(nat,nat))),aTP_Lamp_cs(nat,fun(nat,fun(nat,fun(nat,product_prod(nat,nat)))),Uu),Uua),Uub),Uuc) = aa(nat,product_prod(nat,nat),aa(nat,fun(nat,product_prod(nat,nat)),product_Pair(nat,nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uuc)),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uua),Uub)) ).

% ATP.lambda_518
tff(fact_6511_ATP_Olambda__519,axiom,
    ! [B: $tType,C: $tType,Uu: B,Uua: list(B),Uub: C,Uuc: list(C)] : aa(list(C),list(product_prod(B,C)),aa(C,fun(list(C),list(product_prod(B,C))),aa(list(B),fun(C,fun(list(C),list(product_prod(B,C)))),aTP_Lamp_qz(B,fun(list(B),fun(C,fun(list(C),list(product_prod(B,C))))),Uu),Uua),Uub),Uuc) = aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uu),Uub)),zip(B,C,Uua,Uuc)) ).

% ATP.lambda_519
tff(fact_6512_ATP_Olambda__520,axiom,
    ! [B: $tType,C: $tType,Uu: C,Uua: list(C),Uub: B,Uuc: list(B)] : aa(list(B),list(product_prod(B,C)),aa(B,fun(list(B),list(product_prod(B,C))),aa(list(C),fun(B,fun(list(B),list(product_prod(B,C)))),aTP_Lamp_ra(C,fun(list(C),fun(B,fun(list(B),list(product_prod(B,C))))),Uu),Uua),Uub),Uuc) = aa(list(product_prod(B,C)),list(product_prod(B,C)),aa(product_prod(B,C),fun(list(product_prod(B,C)),list(product_prod(B,C))),cons(product_prod(B,C)),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uub),Uu)),zip(B,C,Uuc,Uua)) ).

% ATP.lambda_520
tff(fact_6513_ATP_Olambda__521,axiom,
    ! [B: $tType,C: $tType,Uu: B,Uua: C,Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(C,fun(B,fun(C,$o)),aTP_Lamp_ne(B,fun(C,fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( ( Uu = Uub )
        & ( Uua = Uuc ) ) ) ).

% ATP.lambda_521
tff(fact_6514_ATP_Olambda__522,axiom,
    ! [Uu: nat,Uua: nat,Uub: nat,Uuc: nat] :
      ( aa(nat,$o,aa(nat,fun(nat,$o),aa(nat,fun(nat,fun(nat,$o)),aTP_Lamp_ks(nat,fun(nat,fun(nat,fun(nat,$o))),Uu),Uua),Uub),Uuc)
    <=> ( aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uu),Uuc) = aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua) ) ) ).

% ATP.lambda_522
tff(fact_6515_ATP_Olambda__523,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: fun(D,set(product_prod(B,C))),Uua: D,Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(D,fun(B,fun(C,$o)),aTP_Lamp_jg(fun(D,set(product_prod(B,C))),fun(D,fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> member(product_prod(B,C),aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),Uub),Uuc),aa(D,set(product_prod(B,C)),Uu,Uua)) ) ).

% ATP.lambda_523
tff(fact_6516_ATP_Olambda__524,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_mult(C)
     => ! [Uu: set(B),Uua: fun(B,C),Uub: fun(B,C),Uuc: B] :
          ( aa(B,$o,aa(fun(B,C),fun(B,$o),aa(fun(B,C),fun(fun(B,C),fun(B,$o)),aTP_Lamp_hy(set(B),fun(fun(B,C),fun(fun(B,C),fun(B,$o))),Uu),Uua),Uub),Uuc)
        <=> ( member(B,Uuc,Uu)
            & ( aa(C,C,aa(C,fun(C,C),times_times(C),aa(B,C,Uua,Uuc)),aa(B,C,Uub,Uuc)) != one_one(C) ) ) ) ) ).

% ATP.lambda_524
tff(fact_6517_ATP_Olambda__525,axiom,
    ! [B: $tType,C: $tType] :
      ( comm_monoid_add(C)
     => ! [Uu: set(B),Uua: fun(B,C),Uub: fun(B,C),Uuc: B] :
          ( aa(B,$o,aa(fun(B,C),fun(B,$o),aa(fun(B,C),fun(fun(B,C),fun(B,$o)),aTP_Lamp_hw(set(B),fun(fun(B,C),fun(fun(B,C),fun(B,$o))),Uu),Uua),Uub),Uuc)
        <=> ( member(B,Uuc,Uu)
            & ( aa(C,C,aa(C,fun(C,C),plus_plus(C),aa(B,C,Uua,Uuc)),aa(B,C,Uub,Uuc)) != zero_zero(C) ) ) ) ) ).

% ATP.lambda_525
tff(fact_6518_ATP_Olambda__526,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,$o),Uua: fun(B,fun(C,$o)),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aTP_Lamp_jw(fun(B,$o),fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( aa(B,$o,Uu,Uub)
        & aa(C,$o,aa(B,fun(C,$o),Uua,Uub),Uuc) ) ) ).

% ATP.lambda_526
tff(fact_6519_ATP_Olambda__527,axiom,
    ! [D: $tType,C: $tType,B: $tType,E: $tType,Uu: fun(D,set(B)),Uua: fun(E,set(C)),Uub: D,Uuc: E] : aa(E,set(product_prod(B,C)),aa(D,fun(E,set(product_prod(B,C))),aa(fun(E,set(C)),fun(D,fun(E,set(product_prod(B,C)))),aTP_Lamp_jz(fun(D,set(B)),fun(fun(E,set(C)),fun(D,fun(E,set(product_prod(B,C))))),Uu),Uua),Uub),Uuc) = product_Sigma(B,C,aa(D,set(B),Uu,Uub),aa(E,fun(B,set(C)),aTP_Lamp_jy(fun(E,set(C)),fun(E,fun(B,set(C))),Uua),Uuc)) ).

% ATP.lambda_527
tff(fact_6520_ATP_Olambda__528,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_semiring_0(B)
     => ! [Uu: fun(C,B),Uua: B,Uub: C,Uuc: B] : aa(B,B,aa(C,fun(B,B),aa(B,fun(C,fun(B,B)),aTP_Lamp_sv(fun(C,B),fun(B,fun(C,fun(B,B))),Uu),Uua),Uub),Uuc) = aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(C,B,Uu,Uub)),aa(B,B,aa(B,fun(B,B),times_times(B),Uua),Uuc)) ) ).

% ATP.lambda_528
tff(fact_6521_ATP_Olambda__529,axiom,
    ! [D: $tType,B: $tType,C: $tType,E: $tType,Uu: fun(D,B),Uua: fun(E,C),Uub: D,Uuc: E] : aa(E,product_prod(B,C),aa(D,fun(E,product_prod(B,C)),aa(fun(E,C),fun(D,fun(E,product_prod(B,C))),aTP_Lamp_kc(fun(D,B),fun(fun(E,C),fun(D,fun(E,product_prod(B,C)))),Uu),Uua),Uub),Uuc) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,Uu,Uub)),aa(E,C,Uua,Uuc)) ).

% ATP.lambda_529
tff(fact_6522_ATP_Olambda__530,axiom,
    ! [B: $tType,D: $tType,E: $tType,C: $tType,Uu: fun(B,D),Uua: fun(C,E),Uub: B,Uuc: C] : aa(C,product_prod(D,E),aa(B,fun(C,product_prod(D,E)),aa(fun(C,E),fun(B,fun(C,product_prod(D,E))),aTP_Lamp_tm(fun(B,D),fun(fun(C,E),fun(B,fun(C,product_prod(D,E)))),Uu),Uua),Uub),Uuc) = aa(E,product_prod(D,E),aa(D,fun(E,product_prod(D,E)),product_Pair(D,E),aa(B,D,Uu,Uub)),aa(C,E,Uua,Uuc)) ).

% ATP.lambda_530
tff(fact_6523_ATP_Olambda__531,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,$o),Uua: fun(C,$o),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(C,$o),fun(B,fun(C,$o)),aTP_Lamp_jj(fun(B,$o),fun(fun(C,$o),fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ( aa(B,$o,Uu,Uub)
        & aa(C,$o,Uua,Uuc) ) ) ).

% ATP.lambda_531
tff(fact_6524_ATP_Olambda__532,axiom,
    ! [B: $tType,C: $tType,Uu: $o,Uua: fun(B,fun(C,$o)),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(fun(B,fun(C,$o)),fun(B,fun(C,$o)),aTP_Lamp_dc($o,fun(fun(B,fun(C,$o)),fun(B,fun(C,$o))),(Uu)),Uua),Uub),Uuc)
    <=> ( (Uu)
        & aa(C,$o,aa(B,fun(C,$o),Uua,Uub),Uuc) ) ) ).

% ATP.lambda_532
tff(fact_6525_ATP_Olambda__533,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: fun(B,B),Uub: array(B),Uuc: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(fun(B,B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_rs(nat,fun(fun(B,B),fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))))),Uu),Uua),Uub),Uuc) = aa(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_Pair(array(B),product_prod(heap_ext(product_unit),nat)),Uub),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),array_update(B,Uub,Uu,aa(B,B,Uua,aa(nat,B,nth(B,array_get(B,Uuc,Uub)),Uu)),Uuc)),aa(num,nat,numeral_numeral(nat),aa(num,num,bit0,one2)))) ) ).

% ATP.lambda_533
tff(fact_6526_ATP_Olambda__534,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: nat,Uua: B,Uub: array(B),Uuc: heap_ext(product_unit)] : aa(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),aa(B,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat)))),aTP_Lamp_ru(nat,fun(B,fun(array(B),fun(heap_ext(product_unit),product_prod(array(B),product_prod(heap_ext(product_unit),nat))))),Uu),Uua),Uub),Uuc) = aa(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat)),aa(array(B),fun(product_prod(heap_ext(product_unit),nat),product_prod(array(B),product_prod(heap_ext(product_unit),nat))),product_Pair(array(B),product_prod(heap_ext(product_unit),nat)),Uub),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),array_update(B,Uub,Uu,Uua,Uuc)),one_one(nat))) ) ).

% ATP.lambda_534
tff(fact_6527_ATP_Olambda__535,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(D,B),Uua: fun(D,C),Uub: set(D),Uuc: B] : aa(B,set(C),aa(set(D),fun(B,set(C)),aa(fun(D,C),fun(set(D),fun(B,set(C))),aTP_Lamp_my(fun(D,B),fun(fun(D,C),fun(set(D),fun(B,set(C)))),Uu),Uua),Uub),Uuc) = aa(set(D),set(C),image2(D,C,Uua),aa(set(D),set(D),inf_inf(set(D),aa(set(B),set(D),vimage(D,B,Uu),aa(set(B),set(B),insert2(B,Uuc),bot_bot(set(B))))),Uub)) ).

% ATP.lambda_535
tff(fact_6528_ATP_Olambda__536,axiom,
    ! [C: $tType,B: $tType,Uu: fun(C,heap_Time_Heap(B)),Uua: C,Uub: heap_ext(product_unit),Uuc: nat] : aa(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_ext(product_unit),fun(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),aa(C,fun(heap_ext(product_unit),fun(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat))))),aTP_Lamp_ck(fun(C,heap_Time_Heap(B)),fun(C,fun(heap_ext(product_unit),fun(nat,option(product_prod(B,product_prod(heap_ext(product_unit),nat)))))),Uu),Uua),Uub),Uuc) = heap_Time_timeFrame(B,Uuc,aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),aa(C,heap_Time_Heap(B),Uu,Uua)),Uub)) ).

% ATP.lambda_536
tff(fact_6529_ATP_Olambda__537,axiom,
    ! [B: $tType,Uu: list(B),Uua: list(B),Uub: B,Uuc: list(B)] : aa(list(B),option($o),aa(B,fun(list(B),option($o)),aa(list(B),fun(B,fun(list(B),option($o))),aTP_Lamp_qb(list(B),fun(list(B),fun(B,fun(list(B),option($o)))),Uu),Uua),Uub),Uuc) = subset_eq_mset_impl(B,Uu,aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),append(B),Uua),Uuc)) ).

% ATP.lambda_537
tff(fact_6530_ATP_Olambda__538,axiom,
    ! [B: $tType] :
      ( ord(B)
     => ! [Uu: B,Uua: list(B),Uub: B,Uuc: list(B)] : aa(list(B),B,aa(B,fun(list(B),B),aa(list(B),fun(B,fun(list(B),B)),aTP_Lamp_rb(B,fun(list(B),fun(B,fun(list(B),B))),Uu),Uua),Uub),Uuc) = aa(B,B,ord_min(B,Uu),min_list(B,Uua)) ) ).

% ATP.lambda_538
tff(fact_6531_ATP_Olambda__539,axiom,
    ! [B: $tType,D: $tType,C: $tType,E: $tType,Uu: fun(C,B),Uua: fun(D,fun(E,C)),Uub: D,Uuc: E] : aa(E,B,aa(D,fun(E,B),aa(fun(D,fun(E,C)),fun(D,fun(E,B)),aTP_Lamp_bn(fun(C,B),fun(fun(D,fun(E,C)),fun(D,fun(E,B))),Uu),Uua),Uub),Uuc) = aa(C,B,Uu,aa(E,C,aa(D,fun(E,C),Uua,Uub),Uuc)) ).

% ATP.lambda_539
tff(fact_6532_ATP_Olambda__540,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fq(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)),aa(nat,nat,suc,Uuc))) ) ).

% ATP.lambda_540
tff(fact_6533_ATP_Olambda__541,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fb(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)),aa(nat,nat,suc,Uuc))) ) ).

% ATP.lambda_541
tff(fact_6534_ATP_Olambda__542,axiom,
    ! [B: $tType,Uu: fun(nat,B),Uua: nat,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_wl(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)),aa(nat,nat,suc,Uuc))) ).

% ATP.lambda_542
tff(fact_6535_ATP_Olambda__543,axiom,
    ! [B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_fo(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)),Uuc)) ) ).

% ATP.lambda_543
tff(fact_6536_ATP_Olambda__544,axiom,
    ! [B: $tType] :
      ( comm_monoid_add(B)
     => ! [Uu: fun(nat,B),Uua: nat,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_bs(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)),Uuc)) ) ).

% ATP.lambda_544
tff(fact_6537_ATP_Olambda__545,axiom,
    ! [B: $tType,Uu: fun(nat,B),Uua: nat,Uub: nat,Uuc: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(nat,fun(nat,fun(nat,B)),aTP_Lamp_wq(fun(nat,B),fun(nat,fun(nat,fun(nat,B))),Uu),Uua),Uub),Uuc) = aa(nat,B,Uu,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),Uub),Uua)),Uuc)) ).

% ATP.lambda_545
tff(fact_6538_ATP_Olambda__546,axiom,
    ! [B: $tType,Uu: fun(B,$o),Uua: nat,Uub: list(B),Uuc: nat] :
      ( aa(nat,$o,aa(list(B),fun(nat,$o),aa(nat,fun(list(B),fun(nat,$o)),aTP_Lamp_rh(fun(B,$o),fun(nat,fun(list(B),fun(nat,$o))),Uu),Uua),Uub),Uuc)
    <=> aa(B,$o,Uu,aa(nat,B,nth(B,take(B,Uua,Uub)),Uuc)) ) ).

% ATP.lambda_546
tff(fact_6539_ATP_Olambda__547,axiom,
    ! [B: $tType,E: $tType,C: $tType,D: $tType,Uu: fun(product_prod(C,D),B),Uua: fun(E,C),Uub: E,Uuc: D] : aa(D,B,aa(E,fun(D,B),aa(fun(E,C),fun(E,fun(D,B)),aTP_Lamp_qq(fun(product_prod(C,D),B),fun(fun(E,C),fun(E,fun(D,B))),Uu),Uua),Uub),Uuc) = aa(product_prod(C,D),B,Uu,aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),aa(E,C,Uua,Uub)),Uuc)) ).

% ATP.lambda_547
tff(fact_6540_ATP_Olambda__548,axiom,
    ! [B: $tType,C: $tType,D: $tType,E: $tType,Uu: fun(product_prod(C,D),B),Uua: fun(E,D),Uub: C,Uuc: E] : aa(E,B,aa(C,fun(E,B),aa(fun(E,D),fun(C,fun(E,B)),aTP_Lamp_qr(fun(product_prod(C,D),B),fun(fun(E,D),fun(C,fun(E,B))),Uu),Uua),Uub),Uuc) = aa(product_prod(C,D),B,Uu,aa(D,product_prod(C,D),aa(C,fun(D,product_prod(C,D)),product_Pair(C,D),Uub),aa(E,D,Uua,Uuc))) ).

% ATP.lambda_548
tff(fact_6541_ATP_Olambda__549,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: fun(D,fun(B,heap_Time_Heap(C))),Uua: fun(D,D),Uub: fun(fun(B,heap_Time_Heap(C)),D),Uuc: fun(B,heap_Time_Heap(C))] : aa(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C)))),aTP_Lamp_yc(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(fun(B,heap_Time_Heap(C)),fun(B,heap_Time_Heap(C))))),Uu),Uua),Uub),Uuc) = aa(D,fun(B,heap_Time_Heap(C)),Uu,aa(D,D,Uua,aa(fun(B,heap_Time_Heap(C)),D,Uub,Uuc))) ).

% ATP.lambda_549
tff(fact_6542_ATP_Olambda__550,axiom,
    ! [D: $tType,C: $tType,B: $tType,Uu: fun(D,fun(B,option(C))),Uua: fun(D,D),Uub: fun(fun(B,option(C)),D),Uuc: fun(B,option(C))] : aa(fun(B,option(C)),fun(B,option(C)),aa(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C)))),aTP_Lamp_xw(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(fun(B,option(C)),fun(B,option(C))))),Uu),Uua),Uub),Uuc) = aa(D,fun(B,option(C)),Uu,aa(D,D,Uua,aa(fun(B,option(C)),D,Uub,Uuc))) ).

% ATP.lambda_550
tff(fact_6543_ATP_Olambda__551,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(C)
     => ! [Uu: fun(B,C),Uua: C,Uub: B,Uuc: list(B)] : aa(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))),aa(B,fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))))),aa(C,fun(B,fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))))),aTP_Lamp_py(fun(B,C),fun(C,fun(B,fun(list(B),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B))))))),Uu),Uua),Uub),Uuc) = aa(fun(list(B),fun(list(B),product_prod(list(B),product_prod(list(B),list(B))))),fun(product_prod(list(B),list(B)),product_prod(list(B),product_prod(list(B),list(B)))),product_case_prod(list(B),list(B),product_prod(list(B),product_prod(list(B),list(B)))),aa(list(B),fun(list(B),fun(list(B),product_prod(list(B),product_prod(list(B),list(B))))),aa(B,fun(list(B),fun(list(B),fun(list(B),product_prod(list(B),product_prod(list(B),list(B)))))),aa(C,fun(B,fun(list(B),fun(list(B),fun(list(B),product_prod(list(B),product_prod(list(B),list(B))))))),aTP_Lamp_px(fun(B,C),fun(C,fun(B,fun(list(B),fun(list(B),fun(list(B),product_prod(list(B),product_prod(list(B),list(B)))))))),Uu),Uua),Uub),Uuc)) ) ).

% ATP.lambda_551
tff(fact_6544_ATP_Olambda__552,axiom,
    ! [B: $tType,C: $tType,Uu: fun(B,$o),Uua: fun(B,set(product_prod(C,C))),Uub: B,Uuc: C] : aa(C,fun(product_prod(B,C),$o),aa(B,fun(C,fun(product_prod(B,C),$o)),aa(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(product_prod(B,C),$o))),aTP_Lamp_cf(fun(B,$o),fun(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(product_prod(B,C),$o)))),Uu),Uua),Uub),Uuc) = aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(C,fun(B,fun(C,$o)),aa(B,fun(C,fun(B,fun(C,$o))),aa(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(B,fun(C,$o)))),aTP_Lamp_ce(fun(B,$o),fun(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(B,fun(C,$o))))),Uu),Uua),Uub),Uuc)) ).

% ATP.lambda_552
tff(fact_6545_ATP_Olambda__553,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(B,B)),Uua: set(product_prod(C,C)),Uub: B,Uuc: C] : aa(C,fun(product_prod(B,C),$o),aa(B,fun(C,fun(product_prod(B,C),$o)),aa(set(product_prod(C,C)),fun(B,fun(C,fun(product_prod(B,C),$o))),aTP_Lamp_cd(set(product_prod(B,B)),fun(set(product_prod(C,C)),fun(B,fun(C,fun(product_prod(B,C),$o)))),Uu),Uua),Uub),Uuc) = aa(fun(B,fun(C,$o)),fun(product_prod(B,C),$o),product_case_prod(B,C,$o),aa(C,fun(B,fun(C,$o)),aa(B,fun(C,fun(B,fun(C,$o))),aa(set(product_prod(C,C)),fun(B,fun(C,fun(B,fun(C,$o)))),aTP_Lamp_cc(set(product_prod(B,B)),fun(set(product_prod(C,C)),fun(B,fun(C,fun(B,fun(C,$o))))),Uu),Uua),Uub),Uuc)) ).

% ATP.lambda_553
tff(fact_6546_ATP_Olambda__554,axiom,
    ! [Uu: int,Uua: int,Uub: int,Uuc: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_gq(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uu),Uua),Uub),Uuc) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),minus_minus(int),aa(int,int,aa(int,fun(int,int),times_times(int),Uu),Uuc)),aa(int,int,aa(int,fun(int,int),times_times(int),Uub),Uua))),aa(int,int,aa(int,fun(int,int),times_times(int),Uua),Uuc))) ).

% ATP.lambda_554
tff(fact_6547_ATP_Olambda__555,axiom,
    ! [Uu: int,Uua: int,Uub: int,Uuc: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_gs(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uu),Uua),Uub),Uuc) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),plus_plus(int),aa(int,int,aa(int,fun(int,int),times_times(int),Uu),Uuc)),aa(int,int,aa(int,fun(int,int),times_times(int),Uub),Uua))),aa(int,int,aa(int,fun(int,int),times_times(int),Uua),Uuc))) ).

% ATP.lambda_555
tff(fact_6548_ATP_Olambda__556,axiom,
    ! [B: $tType,Uu: fun(B,$o),Uua: list(B),Uub: B,Uuc: list(B)] : aa(list(B),option(product_prod(list(B),product_prod(B,list(B)))),aa(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B))))),aa(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B)))))),aTP_Lamp_sd(fun(B,$o),fun(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B))))))),Uu),Uua),Uub),Uuc) = aa(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B)))),some(product_prod(list(B),product_prod(B,list(B)))),aa(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B))),aa(list(B),fun(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B)))),product_Pair(list(B),product_prod(B,list(B))),takeWhile(B,aa(fun(B,$o),fun(B,$o),aa(fun($o,$o),fun(fun(B,$o),fun(B,$o)),comp($o,$o,B),fNot),Uu),Uua)),aa(list(B),product_prod(B,list(B)),aa(B,fun(list(B),product_prod(B,list(B))),product_Pair(B,list(B)),Uub),Uuc))) ).

% ATP.lambda_556
tff(fact_6549_ATP_Olambda__557,axiom,
    ! [B: $tType,Uu: B,Uua: list(B),Uub: B,Uuc: list(B)] : aa(list(B),option(product_prod(list(B),product_prod(B,list(B)))),aa(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B))))),aa(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B)))))),aTP_Lamp_pz(B,fun(list(B),fun(B,fun(list(B),option(product_prod(list(B),product_prod(B,list(B))))))),Uu),Uua),Uub),Uuc) = aa(product_prod(list(B),product_prod(B,list(B))),option(product_prod(list(B),product_prod(B,list(B)))),some(product_prod(list(B),product_prod(B,list(B)))),aa(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B))),aa(list(B),fun(product_prod(B,list(B)),product_prod(list(B),product_prod(B,list(B)))),product_Pair(list(B),product_prod(B,list(B))),aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uu),Uua)),aa(list(B),product_prod(B,list(B)),aa(B,fun(list(B),product_prod(B,list(B))),product_Pair(B,list(B)),Uub),Uuc))) ).

% ATP.lambda_557
tff(fact_6550_ATP_Olambda__558,axiom,
    ! [Uu: int,Uua: int,Uub: int,Uuc: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_gz(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uu),Uua),Uub),Uuc) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),times_times(int),Uu),Uub)),aa(int,int,aa(int,fun(int,int),times_times(int),Uua),Uuc))) ).

% ATP.lambda_558
tff(fact_6551_ATP_Olambda__559,axiom,
    ! [Uu: int,Uua: int,Uub: int,Uuc: int] : aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),aa(int,fun(int,fun(int,product_prod(int,int))),aTP_Lamp_hb(int,fun(int,fun(int,fun(int,product_prod(int,int)))),Uu),Uua),Uub),Uuc) = normalize(aa(int,product_prod(int,int),aa(int,fun(int,product_prod(int,int)),product_Pair(int,int),aa(int,int,aa(int,fun(int,int),times_times(int),Uu),Uuc)),aa(int,int,aa(int,fun(int,int),times_times(int),Uua),Uub))) ).

% ATP.lambda_559
tff(fact_6552_ATP_Olambda__560,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: set(product_prod(B,D)),Uua: set(product_prod(D,C)),Uub: B,Uuc: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(set(product_prod(D,C)),fun(B,fun(C,$o)),aTP_Lamp_lt(set(product_prod(B,D)),fun(set(product_prod(D,C)),fun(B,fun(C,$o))),Uu),Uua),Uub),Uuc)
    <=> ? [Y3: D] :
          ( member(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),Uub),Y3),Uu)
          & member(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),Y3),Uuc),Uua) ) ) ).

% ATP.lambda_560
tff(fact_6553_ATP_Olambda__561,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: set(D),Uua: fun(D,B),Uub: fun(D,C),Uuc: product_prod(B,C)] :
      ( aa(product_prod(B,C),$o,aa(fun(D,C),fun(product_prod(B,C),$o),aa(fun(D,B),fun(fun(D,C),fun(product_prod(B,C),$o)),aTP_Lamp_lz(set(D),fun(fun(D,B),fun(fun(D,C),fun(product_prod(B,C),$o))),Uu),Uua),Uub),Uuc)
    <=> ? [A7: D] :
          ( ( Uuc = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,Uua,A7)),aa(D,C,Uub,A7)) )
          & member(D,A7,Uu) ) ) ).

% ATP.lambda_561
tff(fact_6554_ATP_Olambda__562,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,B),Uua: C,Uub: set(C),Uuc: B] :
      ( aa(B,$o,aa(set(C),fun(B,$o),aa(C,fun(set(C),fun(B,$o)),aTP_Lamp_lm(fun(C,B),fun(C,fun(set(C),fun(B,$o))),Uu),Uua),Uub),Uuc)
    <=> ? [L3: C] :
          ( ( Uuc = aa(C,B,Uu,L3) )
          & ( ( L3 = Uua )
            | member(C,L3,Uub) ) ) ) ).

% ATP.lambda_562
tff(fact_6555_ATP_Olambda__563,axiom,
    ! [C: $tType,B: $tType] :
      ( linorder(B)
     => ! [Uu: B,Uua: B,Uub: fun(B,C),Uuc: C] :
          ( aa(C,$o,aa(fun(B,C),fun(C,$o),aa(B,fun(fun(B,C),fun(C,$o)),aTP_Lamp_ls(B,fun(B,fun(fun(B,C),fun(C,$o))),Uu),Uua),Uub),Uuc)
        <=> ? [I3: B] :
              ( ( Uuc = aa(B,C,Uub,I3) )
              & aa(B,$o,aa(B,fun(B,$o),ord_less_eq(B),Uu),I3)
              & aa(B,$o,aa(B,fun(B,$o),ord_less(B),I3),Uua) ) ) ) ).

% ATP.lambda_563
tff(fact_6556_ATP_Olambda__564,axiom,
    ! [B: $tType,C: $tType,Uu: set(B),Uua: set(product_prod(C,C)),Uub: fun(B,C),Uuc: product_prod(B,B)] :
      ( aa(product_prod(B,B),$o,aa(fun(B,C),fun(product_prod(B,B),$o),aa(set(product_prod(C,C)),fun(fun(B,C),fun(product_prod(B,B),$o)),aTP_Lamp_ti(set(B),fun(set(product_prod(C,C)),fun(fun(B,C),fun(product_prod(B,B),$o))),Uu),Uua),Uub),Uuc)
    <=> ? [A18: B,A26: B] :
          ( ( Uuc = aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),A18),A26) )
          & member(B,A18,Uu)
          & member(B,A26,Uu)
          & member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),aa(B,C,Uub,A18)),aa(B,C,Uub,A26)),Uua) ) ) ).

% ATP.lambda_564
tff(fact_6557_ATP_Olambda__565,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: fun(nat,fun(nat,B)),Uuc: nat,Uud: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),aa(B,fun(fun(nat,fun(nat,B)),fun(nat,fun(nat,B))),aTP_Lamp_wo(fun(B,fun(B,B)),fun(B,fun(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)))),Uu),Uua),Uub),Uuc),Uud) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,Uu,Uua),aa(nat,fun(nat,B),aTP_Lamp_wn(fun(nat,fun(nat,B)),fun(nat,fun(nat,B)),Uub),Uud)),set_or1337092689740270186AtMost(nat,aa(nat,nat,suc,Uud),Uuc)) ).

% ATP.lambda_565
tff(fact_6558_ATP_Olambda__566,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,B)),Uua: B,Uub: fun(nat,B),Uuc: nat,Uud: nat] : aa(nat,B,aa(nat,fun(nat,B),aa(fun(nat,B),fun(nat,fun(nat,B)),aa(B,fun(fun(nat,B),fun(nat,fun(nat,B))),aTP_Lamp_wj(fun(B,fun(B,B)),fun(B,fun(fun(nat,B),fun(nat,fun(nat,B)))),Uu),Uua),Uub),Uuc),Uud) = aa(set(nat),B,aa(fun(nat,B),fun(set(nat),B),groups_comm_monoid_F(B,nat,Uu,Uua),Uub),set_or7035219750837199246ssThan(nat,aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uud),Uuc),aa(nat,nat,aa(nat,fun(nat,nat),plus_plus(nat),aa(nat,nat,aa(nat,fun(nat,nat),times_times(nat),Uud),Uuc)),Uuc))) ).

% ATP.lambda_566
tff(fact_6559_ATP_Olambda__567,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: D,Uua: B,Uub: B,Uuc: C,Uud: set(product_prod(D,C))] :
      aa(set(product_prod(D,C)),set(product_prod(D,C)),aa(C,fun(set(product_prod(D,C)),set(product_prod(D,C))),aa(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C)))),aa(B,fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C))))),aTP_Lamp_lf(D,fun(B,fun(B,fun(C,fun(set(product_prod(D,C)),set(product_prod(D,C)))))),Uu),Uua),Uub),Uuc),Uud) = $ite(Uua = Uub,aa(set(product_prod(D,C)),set(product_prod(D,C)),insert2(product_prod(D,C),aa(C,product_prod(D,C),aa(D,fun(C,product_prod(D,C)),product_Pair(D,C),Uu),Uuc)),Uud),Uud) ).

% ATP.lambda_567
tff(fact_6560_ATP_Olambda__568,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: B,Uua: C,Uub: C,Uuc: D,Uud: set(product_prod(B,D))] :
      aa(set(product_prod(B,D)),set(product_prod(B,D)),aa(D,fun(set(product_prod(B,D)),set(product_prod(B,D))),aa(C,fun(D,fun(set(product_prod(B,D)),set(product_prod(B,D)))),aa(C,fun(C,fun(D,fun(set(product_prod(B,D)),set(product_prod(B,D))))),aTP_Lamp_lc(B,fun(C,fun(C,fun(D,fun(set(product_prod(B,D)),set(product_prod(B,D)))))),Uu),Uua),Uub),Uuc),Uud) = $ite(Uua = Uub,aa(set(product_prod(B,D)),set(product_prod(B,D)),insert2(product_prod(B,D),aa(D,product_prod(B,D),aa(B,fun(D,product_prod(B,D)),product_Pair(B,D),Uu),Uuc)),Uud),Uud) ).

% ATP.lambda_568
tff(fact_6561_ATP_Olambda__569,axiom,
    ! [B: $tType,Uu: B,Uua: nat,Uub: fun(nat,B),Uuc: fun(nat,B),Uud: nat] :
      aa(nat,B,aa(fun(nat,B),fun(nat,B),aa(fun(nat,B),fun(fun(nat,B),fun(nat,B)),aa(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B))),aTP_Lamp_wh(B,fun(nat,fun(fun(nat,B),fun(fun(nat,B),fun(nat,B)))),Uu),Uua),Uub),Uuc),Uud) = $ite(
        aa(nat,$o,aa(nat,fun(nat,$o),ord_less(nat),Uud),Uua),
        aa(nat,B,Uub,Uud),
        $ite(Uud = Uua,Uu,aa(nat,B,Uuc,aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uud),aa(nat,nat,suc,zero_zero(nat))))) ) ).

% ATP.lambda_569
tff(fact_6562_ATP_Olambda__570,axiom,
    ! [B: $tType,Uu: fun(B,fun(B,$o)),Uua: list(B),Uub: B,Uuc: list(B),Uud: list(B)] : aa(list(B),list(B),aa(list(B),fun(list(B),list(B)),aa(B,fun(list(B),fun(list(B),list(B))),aa(list(B),fun(B,fun(list(B),fun(list(B),list(B)))),aTP_Lamp_re(fun(B,fun(B,$o)),fun(list(B),fun(B,fun(list(B),fun(list(B),list(B))))),Uu),Uua),Uub),Uuc),Uud) = aa(list(B),list(B),quicksort_by_rel(B,Uu,aa(list(B),list(B),aa(B,fun(list(B),list(B)),cons(B),Uub),aa(list(B),list(B),quicksort_by_rel(B,Uu,Uua),Uud))),Uuc) ).

% ATP.lambda_570
tff(fact_6563_ATP_Olambda__571,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: fun(D,fun(B,heap_Time_Heap(C))),Uua: fun(D,D),Uub: fun(fun(B,heap_Time_Heap(C)),D),Uuc: B,Uud: fun(B,heap_Time_Heap(C))] : aa(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C),aa(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)),aa(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))),aa(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C)))),aTP_Lamp_yb(fun(D,fun(B,heap_Time_Heap(C))),fun(fun(D,D),fun(fun(fun(B,heap_Time_Heap(C)),D),fun(B,fun(fun(B,heap_Time_Heap(C)),heap_Time_Heap(C))))),Uu),Uua),Uub),Uuc),Uud) = aa(B,heap_Time_Heap(C),aa(D,fun(B,heap_Time_Heap(C)),Uu,aa(D,D,Uua,aa(fun(B,heap_Time_Heap(C)),D,Uub,Uud))),Uuc) ).

% ATP.lambda_571
tff(fact_6564_ATP_Olambda__572,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: fun(D,fun(B,option(C))),Uua: fun(D,D),Uub: fun(fun(B,option(C)),D),Uuc: B,Uud: fun(B,option(C))] : aa(fun(B,option(C)),option(C),aa(B,fun(fun(B,option(C)),option(C)),aa(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))),aa(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C)))),aTP_Lamp_xv(fun(D,fun(B,option(C))),fun(fun(D,D),fun(fun(fun(B,option(C)),D),fun(B,fun(fun(B,option(C)),option(C))))),Uu),Uua),Uub),Uuc),Uud) = aa(B,option(C),aa(D,fun(B,option(C)),Uu,aa(D,D,Uua,aa(fun(B,option(C)),D,Uub,Uud))),Uuc) ).

% ATP.lambda_572
tff(fact_6565_ATP_Olambda__573,axiom,
    ! [C: $tType,B: $tType,D: $tType,Uu: fun(B,fun(D,B)),Uua: fun(B,fun(C,fun(D,C))),Uub: B,Uuc: C,Uud: D] : aa(D,product_prod(B,C),aa(C,fun(D,product_prod(B,C)),aa(B,fun(C,fun(D,product_prod(B,C))),aa(fun(B,fun(C,fun(D,C))),fun(B,fun(C,fun(D,product_prod(B,C)))),aTP_Lamp_on(fun(B,fun(D,B)),fun(fun(B,fun(C,fun(D,C))),fun(B,fun(C,fun(D,product_prod(B,C))))),Uu),Uua),Uub),Uuc),Uud) = aa(C,product_prod(B,C),aa(B,fun(C,product_prod(B,C)),product_Pair(B,C),aa(D,B,aa(B,fun(D,B),Uu,Uub),Uud)),aa(D,C,aa(C,fun(D,C),aa(B,fun(C,fun(D,C)),Uua,Uub),Uuc),Uud)) ).

% ATP.lambda_573
tff(fact_6566_ATP_Olambda__574,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: nat,Uua: B,Uub: B,Uuc: B,Uud: nat] : aa(nat,B,aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ee(nat,fun(B,fun(B,fun(B,fun(nat,B)))),Uu),Uua),Uub),Uuc),Uud) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),minus_minus(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),Uud)),Uua)),one_one(B))),Uud)),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uub),Uud))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),Uub),Uuc)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uu),Uud))) ) ).

% ATP.lambda_574
tff(fact_6567_ATP_Olambda__575,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: nat,Uua: B,Uub: B,Uuc: B,Uud: nat] : aa(nat,B,aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ec(nat,fun(B,fun(B,fun(B,fun(nat,B)))),Uu),Uua),Uub),Uuc),Uud) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,aa(B,B,aa(B,fun(B,B),plus_plus(B),aa(nat,B,semiring_1_of_nat(B),Uu)),Uua)),Uud)),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uub),Uud))),aa(nat,B,aa(B,fun(nat,B),power_power(B),Uuc),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uu),Uud))) ) ).

% ATP.lambda_575
tff(fact_6568_ATP_Olambda__576,axiom,
    ! [B: $tType,Uu: B,Uua: B,Uub: set(product_prod(B,B)),Uuc: B,Uud: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aa(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o))),aTP_Lamp_nz(B,fun(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o)))),Uu),Uua),Uub),Uuc),Uud)
    <=> ( ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uuc),Uu),transitive_trancl(B,Uub))
          | ( Uuc = Uu ) )
        & ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uua),Uud),transitive_trancl(B,Uub))
          | ( Uud = Uua ) ) ) ) ).

% ATP.lambda_576
tff(fact_6569_ATP_Olambda__577,axiom,
    ! [B: $tType] :
      ( field_char_0(B)
     => ! [Uu: nat,Uua: B,Uub: B,Uuc: B,Uud: nat] : aa(nat,B,aa(B,fun(nat,B),aa(B,fun(B,fun(nat,B)),aa(B,fun(B,fun(B,fun(nat,B))),aTP_Lamp_ed(nat,fun(B,fun(B,fun(B,fun(nat,B)))),Uu),Uua),Uub),Uuc),Uud) = aa(B,B,aa(B,fun(B,B),times_times(B),aa(B,B,aa(B,fun(B,B),times_times(B),aa(nat,B,gbinomial(B,aa(B,B,uminus_uminus(B),Uua)),Uud)),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,uminus_uminus(B),Uub)),Uud))),aa(nat,B,aa(B,fun(nat,B),power_power(B),aa(B,B,aa(B,fun(B,B),plus_plus(B),Uub),Uuc)),aa(nat,nat,aa(nat,fun(nat,nat),minus_minus(nat),Uu),Uud))) ) ).

% ATP.lambda_577
tff(fact_6570_ATP_Olambda__578,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B,Uuc: B,Uud: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(B,fun(B,fun(B,$o)),aa(B,fun(B,fun(B,fun(B,$o))),aTP_Lamp_mh(set(product_prod(B,B)),fun(B,fun(B,fun(B,fun(B,$o)))),Uu),Uua),Uub),Uuc),Uud)
    <=> ( aa(set(B),$o,aa(set(B),fun(set(B),$o),ord_less_eq(set(B)),aa(set(B),set(B),insert2(B,Uua),aa(set(B),set(B),insert2(B,Uub),aa(set(B),set(B),insert2(B,Uuc),aa(set(B),set(B),insert2(B,Uud),bot_bot(set(B))))))),field2(B,Uu))
        & ( ( ( Uua = Uuc )
            & ( Uub = Uud ) )
          | member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),bNF_We1388413361240627857o_max2(B,Uu,Uua,Uub)),bNF_We1388413361240627857o_max2(B,Uu,Uuc,Uud)),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),Uu),id2(B)))
          | ( ( bNF_We1388413361240627857o_max2(B,Uu,Uua,Uub) = bNF_We1388413361240627857o_max2(B,Uu,Uuc,Uud) )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uua),Uuc),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),Uu),id2(B))) )
          | ( ( bNF_We1388413361240627857o_max2(B,Uu,Uua,Uub) = bNF_We1388413361240627857o_max2(B,Uu,Uuc,Uud) )
            & ( Uua = Uuc )
            & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uud),aa(set(product_prod(B,B)),set(product_prod(B,B)),aa(set(product_prod(B,B)),fun(set(product_prod(B,B)),set(product_prod(B,B))),minus_minus(set(product_prod(B,B))),Uu),id2(B))) ) ) ) ) ).

% ATP.lambda_578
tff(fact_6571_ATP_Olambda__579,axiom,
    ! [B: $tType,Uu: B,Uua: B,Uub: set(product_prod(B,B)),Uuc: B,Uud: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(set(product_prod(B,B)),fun(B,fun(B,$o)),aa(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o))),aTP_Lamp_nc(B,fun(B,fun(set(product_prod(B,B)),fun(B,fun(B,$o)))),Uu),Uua),Uub),Uuc),Uud)
    <=> ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uuc),Uu),transitive_rtrancl(B,Uub))
        & member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uua),Uud),transitive_rtrancl(B,Uub)) ) ) ).

% ATP.lambda_579
tff(fact_6572_ATP_Olambda__580,axiom,
    ! [B: $tType,Uu: set(product_prod(B,B)),Uua: B,Uub: B,Uuc: B,Uud: B] :
      ( aa(B,$o,aa(B,fun(B,$o),aa(B,fun(B,fun(B,$o)),aa(B,fun(B,fun(B,fun(B,$o))),aTP_Lamp_sj(set(product_prod(B,B)),fun(B,fun(B,fun(B,fun(B,$o)))),Uu),Uua),Uub),Uuc),Uud)
    <=> ( ( Uub = Uuc )
       => member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uua),Uud),Uu) ) ) ).

% ATP.lambda_580
tff(fact_6573_ATP_Olambda__581,axiom,
    ! [B: $tType,Uu: heap_Time_Heap(B),Uua: heap_ext(product_unit),Uub: B,Uuc: heap_ext(product_unit),Uud: nat] :
      ( aa(nat,$o,aa(heap_ext(product_unit),fun(nat,$o),aa(B,fun(heap_ext(product_unit),fun(nat,$o)),aa(heap_ext(product_unit),fun(B,fun(heap_ext(product_unit),fun(nat,$o))),aTP_Lamp_mc(heap_Time_Heap(B),fun(heap_ext(product_unit),fun(B,fun(heap_ext(product_unit),fun(nat,$o)))),Uu),Uua),Uub),Uuc),Uud)
    <=> ( aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(B),fun(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(B),Uu),Uua) = aa(product_prod(B,product_prod(heap_ext(product_unit),nat)),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),some(product_prod(B,product_prod(heap_ext(product_unit),nat))),aa(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat)),aa(B,fun(product_prod(heap_ext(product_unit),nat),product_prod(B,product_prod(heap_ext(product_unit),nat))),product_Pair(B,product_prod(heap_ext(product_unit),nat)),Uub),aa(nat,product_prod(heap_ext(product_unit),nat),aa(heap_ext(product_unit),fun(nat,product_prod(heap_ext(product_unit),nat)),product_Pair(heap_ext(product_unit),nat),Uuc),Uud))) ) ) ).

% ATP.lambda_581
tff(fact_6574_ATP_Olambda__582,axiom,
    ! [B: $tType,C: $tType,Uu: set(product_prod(B,B)),Uua: set(product_prod(C,C)),Uub: B,Uuc: C,Uud: B,Uue: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(C,fun(B,fun(C,$o)),aa(B,fun(C,fun(B,fun(C,$o))),aa(set(product_prod(C,C)),fun(B,fun(C,fun(B,fun(C,$o)))),aTP_Lamp_cc(set(product_prod(B,B)),fun(set(product_prod(C,C)),fun(B,fun(C,fun(B,fun(C,$o))))),Uu),Uua),Uub),Uuc),Uud),Uue)
    <=> ( member(product_prod(B,B),aa(B,product_prod(B,B),aa(B,fun(B,product_prod(B,B)),product_Pair(B,B),Uub),Uud),Uu)
        | ( ( Uub = Uud )
          & member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uuc),Uue),Uua) ) ) ) ).

% ATP.lambda_582
tff(fact_6575_ATP_Olambda__583,axiom,
    ! [C: $tType,B: $tType,Uu: fun(B,$o),Uua: fun(B,set(product_prod(C,C))),Uub: B,Uuc: C,Uud: B,Uue: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aa(C,fun(B,fun(C,$o)),aa(B,fun(C,fun(B,fun(C,$o))),aa(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(B,fun(C,$o)))),aTP_Lamp_ce(fun(B,$o),fun(fun(B,set(product_prod(C,C))),fun(B,fun(C,fun(B,fun(C,$o))))),Uu),Uua),Uub),Uuc),Uud),Uue)
    <=> ( ( Uub = Uud )
        & aa(B,$o,Uu,Uud)
        & member(product_prod(C,C),aa(C,product_prod(C,C),aa(C,fun(C,product_prod(C,C)),product_Pair(C,C),Uuc),Uue),aa(B,set(product_prod(C,C)),Uua,Uud)) ) ) ).

% ATP.lambda_583
tff(fact_6576_ATP_Olambda__584,axiom,
    ! [Uu: fun(b,c),Uua: c,Uub: b,Uuc: list(b),Uud: list(b),Uue: list(b)] :
      aa(list(b),product_prod(list(b),product_prod(list(b),list(b))),aa(list(b),fun(list(b),product_prod(list(b),product_prod(list(b),list(b)))),aa(list(b),fun(list(b),fun(list(b),product_prod(list(b),product_prod(list(b),list(b))))),aa(b,fun(list(b),fun(list(b),fun(list(b),product_prod(list(b),product_prod(list(b),list(b)))))),aa(c,fun(b,fun(list(b),fun(list(b),fun(list(b),product_prod(list(b),product_prod(list(b),list(b))))))),aTP_Lamp_px(fun(b,c),fun(c,fun(b,fun(list(b),fun(list(b),fun(list(b),product_prod(list(b),product_prod(list(b),list(b)))))))),Uu),Uua),Uub),Uuc),Uud),Uue) = $let(
        x: c,
        x:= aa(b,c,Uu,Uub),
        $ite(
          aa(c,$o,aa(c,fun(c,$o),ord_less(c),x),Uua),
          aa(product_prod(list(b),list(b)),product_prod(list(b),product_prod(list(b),list(b))),aa(list(b),fun(product_prod(list(b),list(b)),product_prod(list(b),product_prod(list(b),list(b)))),product_Pair(list(b),product_prod(list(b),list(b))),aa(list(b),list(b),aa(b,fun(list(b),list(b)),cons(b),Uub),Uuc)),aa(list(b),product_prod(list(b),list(b)),aa(list(b),fun(list(b),product_prod(list(b),list(b))),product_Pair(list(b),list(b)),Uud),Uue)),
          $ite(aa(c,$o,aa(c,fun(c,$o),ord_less(c),Uua),x),aa(product_prod(list(b),list(b)),product_prod(list(b),product_prod(list(b),list(b))),aa(list(b),fun(product_prod(list(b),list(b)),product_prod(list(b),product_prod(list(b),list(b)))),product_Pair(list(b),product_prod(list(b),list(b))),Uuc),aa(list(b),product_prod(list(b),list(b)),aa(list(b),fun(list(b),product_prod(list(b),list(b))),product_Pair(list(b),list(b)),Uud),aa(list(b),list(b),aa(b,fun(list(b),list(b)),cons(b),Uub),Uue))),aa(product_prod(list(b),list(b)),product_prod(list(b),product_prod(list(b),list(b))),aa(list(b),fun(product_prod(list(b),list(b)),product_prod(list(b),product_prod(list(b),list(b)))),product_Pair(list(b),product_prod(list(b),list(b))),Uuc),aa(list(b),product_prod(list(b),list(b)),aa(list(b),fun(list(b),product_prod(list(b),list(b))),product_Pair(list(b),list(b)),aa(list(b),list(b),aa(b,fun(list(b),list(b)),cons(b),Uub),Uud)),Uue))) ) ) ).

% ATP.lambda_584
tff(fact_6577_ATP_Olambda__585,axiom,
    ! [C: $tType,B: $tType,Uu: $o,Uua: B,Uub: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_ig($o,fun(B,fun(C,$o)),(Uu)),Uua),Uub)
    <=> (Uu) ) ).

% ATP.lambda_585
tff(fact_6578_ATP_Olambda__586,axiom,
    ! [B: $tType,Uu: B,Uua: heap_ext(product_unit),Uub: nat] : aa(nat,B,aa(heap_ext(product_unit),fun(nat,B),aTP_Lamp_dl(B,fun(heap_ext(product_unit),fun(nat,B)),Uu),Uua),Uub) = Uu ).

% ATP.lambda_586
tff(fact_6579_ATP_Olambda__587,axiom,
    ! [B: $tType,C: $tType,Uu: heap_Time_Heap(C),Uua: B] : aa(B,heap_Time_Heap(C),aTP_Lamp_xy(heap_Time_Heap(C),fun(B,heap_Time_Heap(C)),Uu),Uua) = Uu ).

% ATP.lambda_587
tff(fact_6580_ATP_Olambda__588,axiom,
    ! [B: $tType,Uu: heap_Time_Heap(B),Uua: product_unit] : aa(product_unit,heap_Time_Heap(B),aTP_Lamp_at(heap_Time_Heap(B),fun(product_unit,heap_Time_Heap(B)),Uu),Uua) = Uu ).

% ATP.lambda_588
tff(fact_6581_ATP_Olambda__589,axiom,
    ! [C: $tType,B: $tType] :
      ( heap(C)
     => ! [Uu: heap_Time_Heap(B),Uua: C] : aa(C,heap_Time_Heap(B),aTP_Lamp_aw(heap_Time_Heap(B),fun(C,heap_Time_Heap(B)),Uu),Uua) = Uu ) ).

% ATP.lambda_589
tff(fact_6582_ATP_Olambda__590,axiom,
    ! [Uu: heap_ext(product_unit),Uua: nat] : aa(nat,heap_ext(product_unit),aa(heap_ext(product_unit),fun(nat,heap_ext(product_unit)),aTP_Lamp_dp(heap_ext(product_unit),fun(nat,heap_ext(product_unit))),Uu),Uua) = Uu ).

% ATP.lambda_590
tff(fact_6583_ATP_Olambda__591,axiom,
    ! [B: $tType,C: $tType,Uu: option(C),Uua: B] : aa(B,option(C),aTP_Lamp_xu(option(C),fun(B,option(C)),Uu),Uua) = Uu ).

% ATP.lambda_591
tff(fact_6584_ATP_Olambda__592,axiom,
    ! [D: $tType,E: $tType,Uu: set(E),Uua: D] : aa(D,set(E),aTP_Lamp_ka(set(E),fun(D,set(E)),Uu),Uua) = Uu ).

% ATP.lambda_592
tff(fact_6585_ATP_Olambda__593,axiom,
    ! [C: $tType,E: $tType,Uu: set(E),Uua: C] : aa(C,set(E),aTP_Lamp_tn(set(E),fun(C,set(E)),Uu),Uua) = Uu ).

% ATP.lambda_593
tff(fact_6586_ATP_Olambda__594,axiom,
    ! [C: $tType,D: $tType,Uu: set(D),Uua: C] : aa(C,set(D),aTP_Lamp_mz(set(D),fun(C,set(D)),Uu),Uua) = Uu ).

% ATP.lambda_594
tff(fact_6587_ATP_Olambda__595,axiom,
    ! [B: $tType,D: $tType,Uu: set(D),Uua: B] : aa(B,set(D),aTP_Lamp_to(set(D),fun(B,set(D)),Uu),Uua) = Uu ).

% ATP.lambda_595
tff(fact_6588_ATP_Olambda__596,axiom,
    ! [D: $tType,C: $tType,Uu: set(C),Uua: D] : aa(D,set(C),aTP_Lamp_uv(set(C),fun(D,set(C)),Uu),Uua) = Uu ).

% ATP.lambda_596
tff(fact_6589_ATP_Olambda__597,axiom,
    ! [C: $tType,Uu: set(C),Uua: C] : aa(C,set(C),aTP_Lamp_jp(set(C),fun(C,set(C)),Uu),Uua) = Uu ).

% ATP.lambda_597
tff(fact_6590_ATP_Olambda__598,axiom,
    ! [B: $tType,C: $tType,Uu: set(C),Uua: B] : aa(B,set(C),aTP_Lamp_jm(set(C),fun(B,set(C)),Uu),Uua) = Uu ).

% ATP.lambda_598
tff(fact_6591_ATP_Olambda__599,axiom,
    ! [D: $tType,B: $tType,Uu: set(B),Uua: D] : aa(D,set(B),aTP_Lamp_uu(set(B),fun(D,set(B)),Uu),Uua) = Uu ).

% ATP.lambda_599
tff(fact_6592_ATP_Olambda__600,axiom,
    ! [C: $tType,B: $tType,Uu: set(B),Uua: C] : aa(C,set(B),aTP_Lamp_jr(set(B),fun(C,set(B)),Uu),Uua) = Uu ).

% ATP.lambda_600
tff(fact_6593_ATP_Olambda__601,axiom,
    ! [B: $tType,Uu: set(B),Uua: B] : aa(B,set(B),aTP_Lamp_ma(set(B),fun(B,set(B)),Uu),Uua) = Uu ).

% ATP.lambda_601
tff(fact_6594_ATP_Olambda__602,axiom,
    ! [B: $tType,C: $tType,Uu: fun(C,$o),Uua: B] : aa(B,fun(C,$o),aTP_Lamp_vr(fun(C,$o),fun(B,fun(C,$o)),Uu),Uua) = Uu ).

% ATP.lambda_602
tff(fact_6595_ATP_Olambda__603,axiom,
    ! [B: $tType,D: $tType,C: $tType,Uu: fun(C,D),Uua: B] : aa(B,fun(C,D),aTP_Lamp_iv(fun(C,D),fun(B,fun(C,D)),Uu),Uua) = Uu ).

% ATP.lambda_603
tff(fact_6596_ATP_Olambda__604,axiom,
    ! [C: $tType,D: $tType,B: $tType,Uu: fun(B,fun(D,D)),Uua: C] : aa(C,fun(B,fun(D,D)),aTP_Lamp_qv(fun(B,fun(D,D)),fun(C,fun(B,fun(D,D))),Uu),Uua) = Uu ).

% ATP.lambda_604
tff(fact_6597_ATP_Olambda__605,axiom,
    ! [B: $tType,C: $tType,D: $tType,Uu: D,Uua: product_prod(B,C)] : aa(product_prod(B,C),D,aTP_Lamp_ah(D,fun(product_prod(B,C),D),Uu),Uua) = Uu ).

% ATP.lambda_605
tff(fact_6598_ATP_Olambda__606,axiom,
    ! [D: $tType,C: $tType,Uu: C,Uua: D] : aa(D,C,aTP_Lamp_av(C,fun(D,C),Uu),Uua) = Uu ).

% ATP.lambda_606
tff(fact_6599_ATP_Olambda__607,axiom,
    ! [B: $tType] :
      ( heap(B)
     => ! [Uu: B,Uua: nat] : aa(nat,B,aTP_Lamp_am(B,fun(nat,B),Uu),Uua) = Uu ) ).

% ATP.lambda_607
tff(fact_6600_ATP_Olambda__608,axiom,
    ! [C: $tType,B: $tType,Uu: B,Uua: C] : aa(C,B,aa(B,fun(C,B),aTP_Lamp_iz(B,fun(C,B)),Uu),Uua) = Uu ).

% ATP.lambda_608
tff(fact_6601_ATP_Olambda__609,axiom,
    ! [Uu: heap_ext(product_unit),Uua: nat] : aa(nat,nat,aa(heap_ext(product_unit),fun(nat,nat),aTP_Lamp_fj(heap_ext(product_unit),fun(nat,nat)),Uu),Uua) = Uua ).

% ATP.lambda_609
tff(fact_6602_ATP_Olambda__610,axiom,
    ! [C: $tType,B: $tType,Uu: C,Uua: B] : aa(B,B,aa(C,fun(B,B),aTP_Lamp_iw(C,fun(B,B)),Uu),Uua) = Uua ).

% ATP.lambda_610
tff(fact_6603_ATP_Olambda__611,axiom,
    ! [C: $tType,B: $tType,Uu: B,Uua: C] :
      ( aa(C,$o,aa(B,fun(C,$o),aTP_Lamp_dd(B,fun(C,$o)),Uu),Uua)
    <=> $true ) ).

% ATP.lambda_611
tff(fact_6604_ATP_Olambda__612,axiom,
    ! [Uu: nat] : aa(nat,nat,aTP_Lamp_bz(nat,nat),Uu) = Uu ).

% ATP.lambda_612
tff(fact_6605_ATP_Olambda__613,axiom,
    ! [Uu: int] : aa(int,int,aTP_Lamp_cm(int,int),Uu) = Uu ).

% ATP.lambda_613
tff(fact_6606_ATP_Olambda__614,axiom,
    ! [C: $tType,Uu: C] : aa(C,C,aTP_Lamp_ae(C,C),Uu) = Uu ).

% ATP.lambda_614
tff(fact_6607_ATP_Olambda__615,axiom,
    ! [B: $tType] :
      ( linorder(B)
     => ! [Uu: B] : aa(B,B,aTP_Lamp_vg(B,B),Uu) = Uu ) ).

% ATP.lambda_615
tff(fact_6608_ATP_Olambda__616,axiom,
    ! [B: $tType] :
      ( monoid_mult(B)
     => ! [Uu: B] : aa(B,B,aTP_Lamp_bj(B,B),Uu) = Uu ) ).

% ATP.lambda_616
tff(fact_6609_ATP_Olambda__617,axiom,
    ! [B: $tType,Uu: B] : aa(B,B,aTP_Lamp_ay(B,B),Uu) = Uu ).

% ATP.lambda_617
tff(fact_6610_ATP_Olambda__618,axiom,
    ! [B: $tType,Uu: B] : aa(B,set($o),aTP_Lamp_uw(B,set($o)),Uu) = top_top(set($o)) ).

% ATP.lambda_618
tff(fact_6611_ATP_Olambda__619,axiom,
    ! [B: $tType,C: $tType,Uu: B] : aa(B,set(C),aTP_Lamp_jn(B,set(C)),Uu) = top_top(set(C)) ).

% ATP.lambda_619
tff(fact_6612_ATP_Olambda__620,axiom,
    ! [B: $tType,C: $tType,Uu: B] : aa(B,set(C),aTP_Lamp_jl(B,set(C)),Uu) = bot_bot(set(C)) ).

% ATP.lambda_620
tff(fact_6613_ATP_Olambda__621,axiom,
    ! [C: $tType,B: $tType] :
      ( comm_monoid_mult(B)
     => ! [Uu: C] : aa(C,B,aTP_Lamp_fl(C,B),Uu) = one_one(B) ) ).

% ATP.lambda_621
tff(fact_6614_ATP_Olambda__622,axiom,
    ! [B: $tType,Uu: B] : aa(B,nat,aTP_Lamp_hz(B,nat),Uu) = one_one(nat) ).

% ATP.lambda_622
tff(fact_6615_ATP_Olambda__623,axiom,
    ! [C: $tType,Uu: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ye(heap_ext(product_unit),option(product_prod(C,product_prod(heap_ext(product_unit),nat)))),Uu) = none(product_prod(C,product_prod(heap_ext(product_unit),nat))) ).

% ATP.lambda_623
tff(fact_6616_ATP_Olambda__624,axiom,
    ! [B: $tType,Uu: heap_ext(product_unit)] : aa(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat))),aTP_Lamp_ao(heap_ext(product_unit),option(product_prod(B,product_prod(heap_ext(product_unit),nat)))),Uu) = none(product_prod(B,product_prod(heap_ext(product_unit),nat))) ).

% ATP.lambda_624
tff(fact_6617_ATP_Olambda__625,axiom,
    ! [D: $tType,C: $tType,Uu: D] : aa(D,option(C),aTP_Lamp_bi(D,option(C)),Uu) = none(C) ).

% ATP.lambda_625
tff(fact_6618_ATP_Olambda__626,axiom,
    ! [C: $tType,B: $tType,Uu: C] : aa(C,option(B),aTP_Lamp_bf(C,option(B)),Uu) = none(B) ).

% ATP.lambda_626
tff(fact_6619_ATP_Olambda__627,axiom,
    ! [B: $tType,D: $tType,Uu: B] : aa(B,option(D),aTP_Lamp_ba(B,option(D)),Uu) = none(D) ).

% ATP.lambda_627
tff(fact_6620_ATP_Olambda__628,axiom,
    ! [B: $tType,C: $tType,Uu: B] : aa(B,option(C),aTP_Lamp_hj(B,option(C)),Uu) = none(C) ).

% ATP.lambda_628
tff(fact_6621_ATP_Olambda__629,axiom,
    ! [C: $tType,Uu: C] :
      ( aa(C,$o,aTP_Lamp_tw(C,$o),Uu)
    <=> $false ) ).

% ATP.lambda_629
tff(fact_6622_ATP_Olambda__630,axiom,
    ! [B: $tType,Uu: B] :
      ( aa(B,$o,aTP_Lamp_ad(B,$o),Uu)
    <=> $false ) ).

% ATP.lambda_630
tff(fact_6623_ATP_Olambda__631,axiom,
    ! [Uu: heap_ext(product_unit)] :
      ( aa(heap_ext(product_unit),$o,aTP_Lamp_vp(heap_ext(product_unit),$o),Uu)
    <=> $true ) ).

% ATP.lambda_631
tff(fact_6624_ATP_Olambda__632,axiom,
    ! [B: $tType,Uu: B] :
      ( aa(B,$o,aTP_Lamp_af(B,$o),Uu)
    <=> $true ) ).

% ATP.lambda_632
tff(fact_6625_ATP_Olambda__633,axiom,
    ! [B: $tType,Uu: B] : aa(B,fun(nat,nat),aTP_Lamp_ot(B,fun(nat,nat)),Uu) = suc ).

% ATP.lambda_633

% Subclasses (3)
tff(subcl_Heap_Oheap___Typerep_Otyperep,axiom,
    ! [A: $tType] :
      ( heap(A)
     => typerep2(A) ) ).

tff(subcl_Heap_Oheap___HOL_Otype,axiom,
    ! [A: $tType] :
      ( heap(A)
     => type(A) ) ).

tff(subcl_Heap_Oheap___Countable_Ocountable,axiom,
    ! [A: $tType] :
      ( heap(A)
     => countable(A) ) ).

% Type constructors (697)
tff(tcon_Heap__Time__Monad_OHeap___Code__Evaluation_Oterm__of,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(heap_Time_Heap(A19)) ) ).

tff(tcon_Heap__Time__Monad_OHeap___Typerep_Otyperep,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(heap_Time_Heap(A19)) ) ).

tff(tcon_Code__Numeral_Onatural___Code__Evaluation_Oterm__of_1,axiom,
    code_term_of(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Typerep_Otyperep_2,axiom,
    typerep2(code_natural) ).

tff(tcon_Code__Numeral_Ointeger___Code__Evaluation_Oterm__of_3,axiom,
    code_term_of(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Typerep_Otyperep_4,axiom,
    typerep2(code_integer) ).

tff(tcon_Code__Evaluation_Oterm___Code__Evaluation_Oterm__of_5,axiom,
    code_term_of(code_term) ).

tff(tcon_Code__Evaluation_Oterm___Typerep_Otyperep_6,axiom,
    typerep2(code_term) ).

tff(tcon_Heap_Oheap_Oheap__ext___Code__Evaluation_Oterm__of_7,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(heap_ext(A19)) ) ).

tff(tcon_Heap_Oheap_Oheap__ext___Typerep_Otyperep_8,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(heap_ext(A19)) ) ).

tff(tcon_Product__Type_Ounit___Code__Evaluation_Oterm__of_9,axiom,
    code_term_of(product_unit) ).

tff(tcon_Product__Type_Ounit___Enum_Oenum,axiom,
    enum(product_unit) ).

tff(tcon_Product__Type_Ounit___Typerep_Otyperep_10,axiom,
    typerep2(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__lattice__top,axiom,
    bounded_lattice_top(product_unit) ).

tff(tcon_Product__Type_Oprod___Code__Evaluation_Oterm__of_11,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => code_term_of(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Enum_Oenum_12,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( enum(A19)
        & enum(A20) )
     => enum(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Typerep_Otyperep_13,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => typerep2(product_prod(A19,A20)) ) ).

tff(tcon_Old__Datatype_Onode___Typerep_Otyperep_14,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => typerep2(old_node(A19,A20)) ) ).

tff(tcon_Multiset_Omultiset___Code__Evaluation_Oterm__of_15,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Typerep_Otyperep_16,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(multiset(A19)) ) ).

tff(tcon_Typerep_Otyperep___Code__Evaluation_Oterm__of_17,axiom,
    code_term_of(typerep) ).

tff(tcon_Typerep_Otyperep___Typerep_Otyperep_18,axiom,
    typerep2(typerep) ).

tff(tcon_Assertions_Oassn___Typerep_Otyperep_19,axiom,
    typerep2(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__lattice__top_20,axiom,
    bounded_lattice_top(assn) ).

tff(tcon_Predicate_Opred___Code__Evaluation_Oterm__of_21,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(pred(A19)) ) ).

tff(tcon_Predicate_Opred___Typerep_Otyperep_22,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(pred(A19)) ) ).

tff(tcon_Predicate_Opred___Lattices_Obounded__lattice__top_23,axiom,
    ! [A19: $tType] : bounded_lattice_top(pred(A19)) ).

tff(tcon_Predicate_Oseq___Code__Evaluation_Oterm__of_24,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(seq(A19)) ) ).

tff(tcon_Predicate_Oseq___Typerep_Otyperep_25,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(seq(A19)) ) ).

tff(tcon_Option_Ooption___Code__Evaluation_Oterm__of_26,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(option(A19)) ) ).

tff(tcon_Option_Ooption___Enum_Oenum_27,axiom,
    ! [A19: $tType] :
      ( enum(A19)
     => enum(option(A19)) ) ).

tff(tcon_Option_Ooption___Typerep_Otyperep_28,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(option(A19)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__lattice__top_29,axiom,
    ! [A19: $tType] :
      ( bounded_lattice_top(A19)
     => bounded_lattice_top(option(A19)) ) ).

tff(tcon_Sum__Type_Osum___Code__Evaluation_Oterm__of_30,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => code_term_of(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___Enum_Oenum_31,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( enum(A19)
        & enum(A20) )
     => enum(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___Typerep_Otyperep_32,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => typerep2(sum_sum(A19,A20)) ) ).

tff(tcon_String_Ochar___Code__Evaluation_Oterm__of_33,axiom,
    code_term_of(char) ).

tff(tcon_String_Ochar___Enum_Oenum_34,axiom,
    enum(char) ).

tff(tcon_String_Ochar___Typerep_Otyperep_35,axiom,
    typerep2(char) ).

tff(tcon_Heap_Oarray___Code__Evaluation_Oterm__of_36,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(array(A19)) ) ).

tff(tcon_Heap_Oarray___Typerep_Otyperep_37,axiom,
    ! [A19: $tType] : typerep2(array(A19)) ).

tff(tcon_List_Olist___Code__Evaluation_Oterm__of_38,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(list(A19)) ) ).

tff(tcon_List_Olist___Typerep_Otyperep_39,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(list(A19)) ) ).

tff(tcon_Heap_Oref___Code__Evaluation_Oterm__of_40,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(ref(A19)) ) ).

tff(tcon_Heap_Oref___Typerep_Otyperep_41,axiom,
    ! [A19: $tType] : typerep2(ref(A19)) ).

tff(tcon_HOL_Obool___Code__Evaluation_Oterm__of_42,axiom,
    code_term_of($o) ).

tff(tcon_HOL_Obool___Enum_Oenum_43,axiom,
    enum($o) ).

tff(tcon_HOL_Obool___Typerep_Otyperep_44,axiom,
    typerep2($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__lattice__top_45,axiom,
    bounded_lattice_top($o) ).

tff(tcon_Set_Oset___Code__Evaluation_Oterm__of_46,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(set(A19)) ) ).

tff(tcon_Set_Oset___Enum_Oenum_47,axiom,
    ! [A19: $tType] :
      ( enum(A19)
     => enum(set(A19)) ) ).

tff(tcon_Set_Oset___Typerep_Otyperep_48,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(set(A19)) ) ).

tff(tcon_Set_Oset___Lattices_Obounded__lattice__top_49,axiom,
    ! [A19: $tType] : bounded_lattice_top(set(A19)) ).

tff(tcon_Rat_Orat___Code__Evaluation_Oterm__of_50,axiom,
    code_term_of(rat) ).

tff(tcon_Rat_Orat___Typerep_Otyperep_51,axiom,
    typerep2(rat) ).

tff(tcon_Num_Onum___Code__Evaluation_Oterm__of_52,axiom,
    code_term_of(num) ).

tff(tcon_Num_Onum___Typerep_Otyperep_53,axiom,
    typerep2(num) ).

tff(tcon_Nat_Onat___Code__Evaluation_Oterm__of_54,axiom,
    code_term_of(nat) ).

tff(tcon_Nat_Onat___Typerep_Otyperep_55,axiom,
    typerep2(nat) ).

tff(tcon_Int_Oint___Code__Evaluation_Oterm__of_56,axiom,
    code_term_of(int) ).

tff(tcon_Int_Oint___Typerep_Otyperep_57,axiom,
    typerep2(int) ).

tff(tcon_itself___Code__Evaluation_Oterm__of_58,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => code_term_of(itself(A19)) ) ).

tff(tcon_itself___Typerep_Otyperep_59,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => typerep2(itself(A19)) ) ).

tff(tcon_fun___Code__Evaluation_Oterm__of_60,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => code_term_of(fun(A19,A20)) ) ).

tff(tcon_fun___Enum_Oenum_61,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( enum(A19)
        & enum(A20) )
     => enum(fun(A19,A20)) ) ).

tff(tcon_fun___Typerep_Otyperep_62,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( typerep2(A19)
        & typerep2(A20) )
     => typerep2(fun(A19,A20)) ) ).

tff(tcon_fun___Lattices_Obounded__lattice__top_63,axiom,
    ! [A19: $tType,A20: $tType] :
      ( bounded_lattice(A20)
     => bounded_lattice_top(fun(A19,A20)) ) ).

tff(tcon_fun___Quickcheck__Exhaustive_Ofull__exhaustive,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( cl_HOL_Oequal(A19)
        & quickc3360725361186068524ustive(A19)
        & quickc3360725361186068524ustive(A20) )
     => quickc3360725361186068524ustive(fun(A19,A20)) ) ).

tff(tcon_fun___Complete__Lattices_Ocomplete__lattice,axiom,
    ! [A19: $tType,A20: $tType] :
      ( comple6319245703460814977attice(A20)
     => comple6319245703460814977attice(fun(A19,A20)) ) ).

tff(tcon_fun___Quickcheck__Exhaustive_Oexhaustive,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( cl_HOL_Oequal(A19)
        & quickc658316121487927005ustive(A19)
        & quickc658316121487927005ustive(A20) )
     => quickc658316121487927005ustive(fun(A19,A20)) ) ).

tff(tcon_fun___Boolean__Algebras_Oboolean__algebra,axiom,
    ! [A19: $tType,A20: $tType] :
      ( boolea8198339166811842893lgebra(A20)
     => boolea8198339166811842893lgebra(fun(A19,A20)) ) ).

tff(tcon_fun___Complete__Partial__Order_Occpo,axiom,
    ! [A19: $tType,A20: $tType] :
      ( comple6319245703460814977attice(A20)
     => comple9053668089753744459l_ccpo(fun(A19,A20)) ) ).

tff(tcon_fun___Quickcheck__Random_Orandom,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( code_term_of(A19)
        & cl_HOL_Oequal(A19)
        & quickcheck_random(A20) )
     => quickcheck_random(fun(A19,A20)) ) ).

tff(tcon_fun___Lattices_Osemilattice__sup,axiom,
    ! [A19: $tType,A20: $tType] :
      ( semilattice_sup(A20)
     => semilattice_sup(fun(A19,A20)) ) ).

tff(tcon_fun___Lattices_Osemilattice__inf,axiom,
    ! [A19: $tType,A20: $tType] :
      ( semilattice_inf(A20)
     => semilattice_inf(fun(A19,A20)) ) ).

tff(tcon_fun___Lattices_Obounded__lattice,axiom,
    ! [A19: $tType,A20: $tType] :
      ( bounded_lattice(A20)
     => bounded_lattice(fun(A19,A20)) ) ).

tff(tcon_fun___Complete__Lattices_OSup,axiom,
    ! [A19: $tType,A20: $tType] :
      ( complete_Sup(A20)
     => complete_Sup(fun(A19,A20)) ) ).

tff(tcon_fun___Complete__Lattices_OInf,axiom,
    ! [A19: $tType,A20: $tType] :
      ( complete_Inf(A20)
     => complete_Inf(fun(A19,A20)) ) ).

tff(tcon_fun___Orderings_Oorder__top,axiom,
    ! [A19: $tType,A20: $tType] :
      ( order_top(A20)
     => order_top(fun(A19,A20)) ) ).

tff(tcon_fun___Orderings_Oorder__bot,axiom,
    ! [A19: $tType,A20: $tType] :
      ( order_bot(A20)
     => order_bot(fun(A19,A20)) ) ).

tff(tcon_fun___Countable_Ocountable,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( finite_finite(A19)
        & countable(A20) )
     => countable(fun(A19,A20)) ) ).

tff(tcon_fun___Orderings_Opreorder,axiom,
    ! [A19: $tType,A20: $tType] :
      ( preorder(A20)
     => preorder(fun(A19,A20)) ) ).

tff(tcon_fun___Finite__Set_Ofinite,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( finite_finite(A19)
        & finite_finite(A20) )
     => finite_finite(fun(A19,A20)) ) ).

tff(tcon_fun___Orderings_Oorder,axiom,
    ! [A19: $tType,A20: $tType] :
      ( order(A20)
     => order(fun(A19,A20)) ) ).

tff(tcon_fun___Orderings_Oord,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ord(A20)
     => ord(fun(A19,A20)) ) ).

tff(tcon_fun___Groups_Ouminus,axiom,
    ! [A19: $tType,A20: $tType] :
      ( uminus(A20)
     => uminus(fun(A19,A20)) ) ).

tff(tcon_fun___Lattices_Osup,axiom,
    ! [A19: $tType,A20: $tType] :
      ( semilattice_sup(A20)
     => sup(fun(A19,A20)) ) ).

tff(tcon_fun___Lattices_Oinf,axiom,
    ! [A19: $tType,A20: $tType] :
      ( semilattice_inf(A20)
     => inf(fun(A19,A20)) ) ).

tff(tcon_fun___HOL_Oequal,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( enum(A19)
        & cl_HOL_Oequal(A20) )
     => cl_HOL_Oequal(fun(A19,A20)) ) ).

tff(tcon_itself___Quickcheck__Random_Orandom_64,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => quickcheck_random(itself(A19)) ) ).

tff(tcon_itself___HOL_Oequal_65,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(itself(A19)) ).

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___Divides_Ounique__euclidean__semiring__numeral,axiom,
    unique1627219031080169319umeral(int) ).

tff(tcon_Int_Oint___Euclidean__Division_Oeuclidean__ring__cancel,axiom,
    euclid8851590272496341667cancel(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___Quickcheck__Exhaustive_Ofull__exhaustive_66,axiom,
    quickc3360725361186068524ustive(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___Quickcheck__Exhaustive_Oexhaustive_67,axiom,
    quickc658316121487927005ustive(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___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_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__semidom,axiom,
    linordered_semidom(int) ).

tff(tcon_Int_Oint___Quickcheck__Random_Orandom_68,axiom,
    quickcheck_random(int) ).

tff(tcon_Int_Oint___Lattices_Osemilattice__sup_69,axiom,
    semilattice_sup(int) ).

tff(tcon_Int_Oint___Lattices_Osemilattice__inf_70,axiom,
    semilattice_inf(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___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___Complete__Lattices_OSup_71,axiom,
    complete_Sup(int) ).

tff(tcon_Int_Oint___Complete__Lattices_OInf_72,axiom,
    complete_Inf(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___Countable_Ocountable_73,axiom,
    countable(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___Parity_Oring__parity,axiom,
    ring_parity(int) ).

tff(tcon_Int_Oint___Orderings_Opreorder_74,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___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_Ocomm__ring,axiom,
    comm_ring(int) ).

tff(tcon_Int_Oint___Orderings_Oorder_75,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_76,axiom,
    ord(int) ).

tff(tcon_Int_Oint___Groups_Ouminus_77,axiom,
    uminus(int) ).

tff(tcon_Int_Oint___Rings_Oring__1,axiom,
    ring_1(int) ).

tff(tcon_Int_Oint___Lattices_Osup_78,axiom,
    sup(int) ).

tff(tcon_Int_Oint___Lattices_Oinf_79,axiom,
    inf(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___Groups_Oplus,axiom,
    plus(int) ).

tff(tcon_Int_Oint___Rings_Oring,axiom,
    ring(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_Int_Oint___HOL_Oequal_80,axiom,
    cl_HOL_Oequal(int) ).

tff(tcon_Nat_Onat___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations_81,axiom,
    bit_un5681908812861735899ations(nat) ).

tff(tcon_Nat_Onat___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_82,axiom,
    semiri1453513574482234551roduct(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Ounique__euclidean__semiring__with__nat_83,axiom,
    euclid5411537665997757685th_nat(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__monoid__add__imp__le_84,axiom,
    ordere1937475149494474687imp_le(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Ounique__euclidean__semiring_85,axiom,
    euclid3128863361964157862miring(nat) ).

tff(tcon_Nat_Onat___Euclidean__Division_Oeuclidean__semiring__cancel_86,axiom,
    euclid4440199948858584721cancel(nat) ).

tff(tcon_Nat_Onat___Divides_Ounique__euclidean__semiring__numeral_87,axiom,
    unique1627219031080169319umeral(nat) ).

tff(tcon_Nat_Onat___Groups_Ostrict__ordered__ab__semigroup__add_88,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_89,axiom,
    ordere580206878836729694up_add(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add__imp__le_90,axiom,
    ordere2412721322843649153imp_le(nat) ).

tff(tcon_Nat_Onat___Bit__Operations_Osemiring__bit__operations_91,axiom,
    bit_se359711467146920520ations(nat) ).

tff(tcon_Nat_Onat___Quickcheck__Exhaustive_Ofull__exhaustive_92,axiom,
    quickc3360725361186068524ustive(nat) ).

tff(tcon_Nat_Onat___Groups_Ostrict__ordered__comm__monoid__add_93,axiom,
    strict7427464778891057005id_add(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__cancel__comm__monoid__add_94,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_95,axiom,
    euclid3725896446679973847miring(nat) ).

tff(tcon_Nat_Onat___Groups_Olinordered__ab__semigroup__add_96,axiom,
    linord4140545234300271783up_add(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__nonzero__semiring_97,axiom,
    linord181362715937106298miring(nat) ).

tff(tcon_Nat_Onat___Rings_Osemidom__divide__unit__factor_98,axiom,
    semido2269285787275462019factor(nat) ).

tff(tcon_Nat_Onat___Quickcheck__Exhaustive_Oexhaustive_99,axiom,
    quickc658316121487927005ustive(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__no__zero__divisors_100,axiom,
    semiri3467727345109120633visors(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__ab__semigroup__add_101,axiom,
    ordere6658533253407199908up_add(nat) ).

tff(tcon_Nat_Onat___Groups_Oordered__comm__monoid__add_102,axiom,
    ordere6911136660526730532id_add(nat) ).

tff(tcon_Nat_Onat___Groups_Ocancel__ab__semigroup__add_103,axiom,
    cancel2418104881723323429up_add(nat) ).

tff(tcon_Nat_Onat___Groups_Ocancel__comm__monoid__add_104,axiom,
    cancel1802427076303600483id_add(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring__1__cancel_105,axiom,
    comm_s4317794764714335236cancel(nat) ).

tff(tcon_Nat_Onat___Bit__Operations_Osemiring__bits_106,axiom,
    bit_semiring_bits(nat) ).

tff(tcon_Nat_Onat___Rings_Onormalization__semidom_107,axiom,
    normal8620421768224518004emidom(nat) ).

tff(tcon_Nat_Onat___Groups_Ocancel__semigroup__add_108,axiom,
    cancel_semigroup_add(nat) ).

tff(tcon_Nat_Onat___Rings_Olinordered__semidom_109,axiom,
    linordered_semidom(nat) ).

tff(tcon_Nat_Onat___Quickcheck__Random_Orandom_110,axiom,
    quickcheck_random(nat) ).

tff(tcon_Nat_Onat___Lattices_Osemilattice__sup_111,axiom,
    semilattice_sup(nat) ).

tff(tcon_Nat_Onat___Lattices_Osemilattice__inf_112,axiom,
    semilattice_inf(nat) ).

tff(tcon_Nat_Onat___Groups_Oab__semigroup__mult_113,axiom,
    ab_semigroup_mult(nat) ).

tff(tcon_Nat_Onat___Rings_Oalgebraic__semidom_114,axiom,
    algebraic_semidom(nat) ).

tff(tcon_Nat_Onat___Groups_Ocomm__monoid__mult_115,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_116,axiom,
    ab_semigroup_add(nat) ).

tff(tcon_Nat_Onat___Parity_Osemiring__parity_117,axiom,
    semiring_parity(nat) ).

tff(tcon_Nat_Onat___Groups_Ocomm__monoid__add_118,axiom,
    comm_monoid_add(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__modulo_119,axiom,
    semiring_modulo(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring__1_120,axiom,
    comm_semiring_1(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring__0_121,axiom,
    comm_semiring_0(nat) ).

tff(tcon_Nat_Onat___Groups_Osemigroup__mult_122,axiom,
    semigroup_mult(nat) ).

tff(tcon_Nat_Onat___Complete__Lattices_OSup_123,axiom,
    complete_Sup(nat) ).

tff(tcon_Nat_Onat___Complete__Lattices_OInf_124,axiom,
    complete_Inf(nat) ).

tff(tcon_Nat_Onat___Rings_Osemidom__modulo_125,axiom,
    semidom_modulo(nat) ).

tff(tcon_Nat_Onat___Rings_Osemidom__divide_126,axiom,
    semidom_divide(nat) ).

tff(tcon_Nat_Onat___Num_Osemiring__numeral_127,axiom,
    semiring_numeral(nat) ).

tff(tcon_Nat_Onat___Groups_Osemigroup__add_128,axiom,
    semigroup_add(nat) ).

tff(tcon_Nat_Onat___Rings_Ozero__less__one_129,axiom,
    zero_less_one(nat) ).

tff(tcon_Nat_Onat___Rings_Ocomm__semiring_130,axiom,
    comm_semiring(nat) ).

tff(tcon_Nat_Onat___Orderings_Oorder__bot_131,axiom,
    order_bot(nat) ).

tff(tcon_Nat_Onat___Nat_Osemiring__char__0_132,axiom,
    semiring_char_0(nat) ).

tff(tcon_Nat_Onat___Countable_Ocountable_133,axiom,
    countable(nat) ).

tff(tcon_Nat_Onat___Rings_Ozero__neq__one_134,axiom,
    zero_neq_one(nat) ).

tff(tcon_Nat_Onat___Orderings_Opreorder_135,axiom,
    preorder(nat) ).

tff(tcon_Nat_Onat___Orderings_Olinorder_136,axiom,
    linorder(nat) ).

tff(tcon_Nat_Onat___Groups_Omonoid__mult_137,axiom,
    monoid_mult(nat) ).

tff(tcon_Nat_Onat___Groups_Omonoid__add_138,axiom,
    monoid_add(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__1_139,axiom,
    semiring_1(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring__0_140,axiom,
    semiring_0(nat) ).

tff(tcon_Nat_Onat___Orderings_Ono__top_141,axiom,
    no_top(nat) ).

tff(tcon_Nat_Onat___GCD_Osemiring__gcd_142,axiom,
    semiring_gcd(nat) ).

tff(tcon_Nat_Onat___GCD_Osemiring__Gcd_143,axiom,
    semiring_Gcd(nat) ).

tff(tcon_Nat_Onat___Orderings_Oorder_144,axiom,
    order(nat) ).

tff(tcon_Nat_Onat___Rings_Osemiring_145,axiom,
    semiring(nat) ).

tff(tcon_Nat_Onat___Orderings_Oord_146,axiom,
    ord(nat) ).

tff(tcon_Nat_Onat___Lattices_Osup_147,axiom,
    sup(nat) ).

tff(tcon_Nat_Onat___Lattices_Oinf_148,axiom,
    inf(nat) ).

tff(tcon_Nat_Onat___Power_Opower_149,axiom,
    power(nat) ).

tff(tcon_Nat_Onat___Num_Onumeral_150,axiom,
    numeral(nat) ).

tff(tcon_Nat_Onat___Groups_Ozero_151,axiom,
    zero(nat) ).

tff(tcon_Nat_Onat___Groups_Oplus_152,axiom,
    plus(nat) ).

tff(tcon_Nat_Onat___Groups_Oone_153,axiom,
    one(nat) ).

tff(tcon_Nat_Onat___Rings_Odvd_154,axiom,
    dvd(nat) ).

tff(tcon_Nat_Onat___Heap_Oheap_155,axiom,
    heap(nat) ).

tff(tcon_Nat_Onat___HOL_Oequal_156,axiom,
    cl_HOL_Oequal(nat) ).

tff(tcon_Num_Onum___Quickcheck__Exhaustive_Ofull__exhaustive_157,axiom,
    quickc3360725361186068524ustive(num) ).

tff(tcon_Num_Onum___Quickcheck__Random_Orandom_158,axiom,
    quickcheck_random(num) ).

tff(tcon_Num_Onum___Orderings_Opreorder_159,axiom,
    preorder(num) ).

tff(tcon_Num_Onum___Orderings_Olinorder_160,axiom,
    linorder(num) ).

tff(tcon_Num_Onum___Orderings_Oorder_161,axiom,
    order(num) ).

tff(tcon_Num_Onum___Orderings_Oord_162,axiom,
    ord(num) ).

tff(tcon_Num_Onum___Groups_Oplus_163,axiom,
    plus(num) ).

tff(tcon_Num_Onum___HOL_Oequal_164,axiom,
    cl_HOL_Oequal(num) ).

tff(tcon_Rat_Orat___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_165,axiom,
    semiri1453513574482234551roduct(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__semigroup__monoid__add__imp__le_166,axiom,
    ordere1937475149494474687imp_le(rat) ).

tff(tcon_Rat_Orat___Groups_Ostrict__ordered__ab__semigroup__add_167,axiom,
    strict9044650504122735259up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__cancel__ab__semigroup__add_168,axiom,
    ordere580206878836729694up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__semigroup__add__imp__le_169,axiom,
    ordere2412721322843649153imp_le(rat) ).

tff(tcon_Rat_Orat___Quickcheck__Exhaustive_Ofull__exhaustive_170,axiom,
    quickc3360725361186068524ustive(rat) ).

tff(tcon_Rat_Orat___Groups_Ostrict__ordered__comm__monoid__add_171,axiom,
    strict7427464778891057005id_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__cancel__comm__monoid__add_172,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_173,axiom,
    linord715952674999750819strict(rat) ).

tff(tcon_Rat_Orat___Groups_Olinordered__ab__semigroup__add_174,axiom,
    linord4140545234300271783up_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__nonzero__semiring_175,axiom,
    linord181362715937106298miring(rat) ).

tff(tcon_Rat_Orat___Quickcheck__Exhaustive_Oexhaustive_176,axiom,
    quickc658316121487927005ustive(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__no__zero__divisors_177,axiom,
    semiri3467727345109120633visors(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__semigroup__add_178,axiom,
    ordere6658533253407199908up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__group__add__abs_179,axiom,
    ordere166539214618696060dd_abs(rat) ).

tff(tcon_Rat_Orat___Archimedean__Field_Ofloor__ceiling,axiom,
    archim2362893244070406136eiling(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__comm__monoid__add_180,axiom,
    ordere6911136660526730532id_add(rat) ).

tff(tcon_Rat_Orat___Groups_Olinordered__ab__group__add_181,axiom,
    linord5086331880401160121up_add(rat) ).

tff(tcon_Rat_Orat___Groups_Ocancel__ab__semigroup__add_182,axiom,
    cancel2418104881723323429up_add(rat) ).

tff(tcon_Rat_Orat___Rings_Oring__1__no__zero__divisors_183,axiom,
    ring_15535105094025558882visors(rat) ).

tff(tcon_Rat_Orat___Groups_Ocancel__comm__monoid__add_184,axiom,
    cancel1802427076303600483id_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__ring__strict_185,axiom,
    linord4710134922213307826strict(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring__1__cancel_186,axiom,
    comm_s4317794764714335236cancel(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semiring__1_187,axiom,
    linord6961819062388156250ring_1(rat) ).

tff(tcon_Rat_Orat___Groups_Oordered__ab__group__add_188,axiom,
    ordered_ab_group_add(rat) ).

tff(tcon_Rat_Orat___Groups_Ocancel__semigroup__add_189,axiom,
    cancel_semigroup_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__semidom_190,axiom,
    linordered_semidom(rat) ).

tff(tcon_Rat_Orat___Quickcheck__Random_Orandom_191,axiom,
    quickcheck_random(rat) ).

tff(tcon_Rat_Orat___Orderings_Odense__linorder,axiom,
    dense_linorder(rat) ).

tff(tcon_Rat_Orat___Lattices_Osemilattice__sup_192,axiom,
    semilattice_sup(rat) ).

tff(tcon_Rat_Orat___Lattices_Osemilattice__inf_193,axiom,
    semilattice_inf(rat) ).

tff(tcon_Rat_Orat___Groups_Oab__semigroup__mult_194,axiom,
    ab_semigroup_mult(rat) ).

tff(tcon_Rat_Orat___Groups_Ocomm__monoid__mult_195,axiom,
    comm_monoid_mult(rat) ).

tff(tcon_Rat_Orat___Groups_Oab__semigroup__add_196,axiom,
    ab_semigroup_add(rat) ).

tff(tcon_Rat_Orat___Fields_Olinordered__field,axiom,
    linordered_field(rat) ).

tff(tcon_Rat_Orat___Groups_Ocomm__monoid__add_197,axiom,
    comm_monoid_add(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__ring_198,axiom,
    linordered_ring(rat) ).

tff(tcon_Rat_Orat___Rings_Olinordered__idom_199,axiom,
    linordered_idom(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring__1_200,axiom,
    comm_semiring_1(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring__0_201,axiom,
    comm_semiring_0(rat) ).

tff(tcon_Rat_Orat___Groups_Osemigroup__mult_202,axiom,
    semigroup_mult(rat) ).

tff(tcon_Rat_Orat___Rings_Osemidom__divide_203,axiom,
    semidom_divide(rat) ).

tff(tcon_Rat_Orat___Num_Osemiring__numeral_204,axiom,
    semiring_numeral(rat) ).

tff(tcon_Rat_Orat___Groups_Osemigroup__add_205,axiom,
    semigroup_add(rat) ).

tff(tcon_Rat_Orat___Fields_Odivision__ring,axiom,
    division_ring(rat) ).

tff(tcon_Rat_Orat___Rings_Ozero__less__one_206,axiom,
    zero_less_one(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__semiring_207,axiom,
    comm_semiring(rat) ).

tff(tcon_Rat_Orat___Nat_Osemiring__char__0_208,axiom,
    semiring_char_0(rat) ).

tff(tcon_Rat_Orat___Groups_Oab__group__add_209,axiom,
    ab_group_add(rat) ).

tff(tcon_Rat_Orat___Fields_Ofield__char__0,axiom,
    field_char_0(rat) ).

tff(tcon_Rat_Orat___Countable_Ocountable_210,axiom,
    countable(rat) ).

tff(tcon_Rat_Orat___Rings_Ozero__neq__one_211,axiom,
    zero_neq_one(rat) ).

tff(tcon_Rat_Orat___Rings_Oordered__ring_212,axiom,
    ordered_ring(rat) ).

tff(tcon_Rat_Orat___Rings_Oidom__abs__sgn_213,axiom,
    idom_abs_sgn(rat) ).

tff(tcon_Rat_Orat___Orderings_Opreorder_214,axiom,
    preorder(rat) ).

tff(tcon_Rat_Orat___Orderings_Olinorder_215,axiom,
    linorder(rat) ).

tff(tcon_Rat_Orat___Groups_Omonoid__mult_216,axiom,
    monoid_mult(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__ring__1_217,axiom,
    comm_ring_1(rat) ).

tff(tcon_Rat_Orat___Groups_Omonoid__add_218,axiom,
    monoid_add(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__1_219,axiom,
    semiring_1(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring__0_220,axiom,
    semiring_0(rat) ).

tff(tcon_Rat_Orat___Orderings_Ono__top_221,axiom,
    no_top(rat) ).

tff(tcon_Rat_Orat___Orderings_Ono__bot_222,axiom,
    no_bot(rat) ).

tff(tcon_Rat_Orat___Groups_Ogroup__add_223,axiom,
    group_add(rat) ).

tff(tcon_Rat_Orat___Rings_Ocomm__ring_224,axiom,
    comm_ring(rat) ).

tff(tcon_Rat_Orat___Orderings_Oorder_225,axiom,
    order(rat) ).

tff(tcon_Rat_Orat___Num_Oneg__numeral_226,axiom,
    neg_numeral(rat) ).

tff(tcon_Rat_Orat___Nat_Oring__char__0_227,axiom,
    ring_char_0(rat) ).

tff(tcon_Rat_Orat___Rings_Osemiring_228,axiom,
    semiring(rat) ).

tff(tcon_Rat_Orat___Fields_Oinverse,axiom,
    inverse(rat) ).

tff(tcon_Rat_Orat___Orderings_Oord_229,axiom,
    ord(rat) ).

tff(tcon_Rat_Orat___Groups_Ouminus_230,axiom,
    uminus(rat) ).

tff(tcon_Rat_Orat___Rings_Oring__1_231,axiom,
    ring_1(rat) ).

tff(tcon_Rat_Orat___Lattices_Osup_232,axiom,
    sup(rat) ).

tff(tcon_Rat_Orat___Lattices_Oinf_233,axiom,
    inf(rat) ).

tff(tcon_Rat_Orat___Fields_Ofield,axiom,
    field(rat) ).

tff(tcon_Rat_Orat___Power_Opower_234,axiom,
    power(rat) ).

tff(tcon_Rat_Orat___Num_Onumeral_235,axiom,
    numeral(rat) ).

tff(tcon_Rat_Orat___Groups_Ozero_236,axiom,
    zero(rat) ).

tff(tcon_Rat_Orat___Groups_Oplus_237,axiom,
    plus(rat) ).

tff(tcon_Rat_Orat___Rings_Oring_238,axiom,
    ring(rat) ).

tff(tcon_Rat_Orat___Groups_Oone_239,axiom,
    one(rat) ).

tff(tcon_Rat_Orat___Rings_Odvd_240,axiom,
    dvd(rat) ).

tff(tcon_Rat_Orat___HOL_Oequal_241,axiom,
    cl_HOL_Oequal(rat) ).

tff(tcon_Set_Oset___Quickcheck__Exhaustive_Ofull__exhaustive_242,axiom,
    ! [A19: $tType] :
      ( quickc3360725361186068524ustive(A19)
     => quickc3360725361186068524ustive(set(A19)) ) ).

tff(tcon_Set_Oset___Complete__Lattices_Ocomplete__lattice_243,axiom,
    ! [A19: $tType] : comple6319245703460814977attice(set(A19)) ).

tff(tcon_Set_Oset___Quickcheck__Exhaustive_Oexhaustive_244,axiom,
    ! [A19: $tType] :
      ( quickc658316121487927005ustive(A19)
     => quickc658316121487927005ustive(set(A19)) ) ).

tff(tcon_Set_Oset___Boolean__Algebras_Oboolean__algebra_245,axiom,
    ! [A19: $tType] : boolea8198339166811842893lgebra(set(A19)) ).

tff(tcon_Set_Oset___Complete__Partial__Order_Occpo_246,axiom,
    ! [A19: $tType] : comple9053668089753744459l_ccpo(set(A19)) ).

tff(tcon_Set_Oset___Quickcheck__Random_Orandom_247,axiom,
    ! [A19: $tType] :
      ( quickcheck_random(A19)
     => quickcheck_random(set(A19)) ) ).

tff(tcon_Set_Oset___Lattices_Osemilattice__sup_248,axiom,
    ! [A19: $tType] : semilattice_sup(set(A19)) ).

tff(tcon_Set_Oset___Lattices_Osemilattice__inf_249,axiom,
    ! [A19: $tType] : semilattice_inf(set(A19)) ).

tff(tcon_Set_Oset___Lattices_Obounded__lattice_250,axiom,
    ! [A19: $tType] : bounded_lattice(set(A19)) ).

tff(tcon_Set_Oset___Complete__Lattices_OSup_251,axiom,
    ! [A19: $tType] : complete_Sup(set(A19)) ).

tff(tcon_Set_Oset___Complete__Lattices_OInf_252,axiom,
    ! [A19: $tType] : complete_Inf(set(A19)) ).

tff(tcon_Set_Oset___Orderings_Oorder__top_253,axiom,
    ! [A19: $tType] : order_top(set(A19)) ).

tff(tcon_Set_Oset___Orderings_Oorder__bot_254,axiom,
    ! [A19: $tType] : order_bot(set(A19)) ).

tff(tcon_Set_Oset___Countable_Ocountable_255,axiom,
    ! [A19: $tType] :
      ( finite_finite(A19)
     => countable(set(A19)) ) ).

tff(tcon_Set_Oset___Orderings_Opreorder_256,axiom,
    ! [A19: $tType] : preorder(set(A19)) ).

tff(tcon_Set_Oset___Finite__Set_Ofinite_257,axiom,
    ! [A19: $tType] :
      ( finite_finite(A19)
     => finite_finite(set(A19)) ) ).

tff(tcon_Set_Oset___Orderings_Oorder_258,axiom,
    ! [A19: $tType] : order(set(A19)) ).

tff(tcon_Set_Oset___Orderings_Oord_259,axiom,
    ! [A19: $tType] : ord(set(A19)) ).

tff(tcon_Set_Oset___Groups_Ouminus_260,axiom,
    ! [A19: $tType] : uminus(set(A19)) ).

tff(tcon_Set_Oset___Lattices_Osup_261,axiom,
    ! [A19: $tType] : sup(set(A19)) ).

tff(tcon_Set_Oset___Lattices_Oinf_262,axiom,
    ! [A19: $tType] : inf(set(A19)) ).

tff(tcon_Set_Oset___HOL_Oequal_263,axiom,
    ! [A19: $tType] :
      ( cl_HOL_Oequal(A19)
     => cl_HOL_Oequal(set(A19)) ) ).

tff(tcon_HOL_Obool___Quickcheck__Exhaustive_Ofull__exhaustive_264,axiom,
    quickc3360725361186068524ustive($o) ).

tff(tcon_HOL_Obool___Complete__Lattices_Ocomplete__lattice_265,axiom,
    comple6319245703460814977attice($o) ).

tff(tcon_HOL_Obool___Boolean__Algebras_Oboolean__algebra_266,axiom,
    boolea8198339166811842893lgebra($o) ).

tff(tcon_HOL_Obool___Complete__Partial__Order_Occpo_267,axiom,
    comple9053668089753744459l_ccpo($o) ).

tff(tcon_HOL_Obool___Quickcheck__Random_Orandom_268,axiom,
    quickcheck_random($o) ).

tff(tcon_HOL_Obool___Lattices_Osemilattice__sup_269,axiom,
    semilattice_sup($o) ).

tff(tcon_HOL_Obool___Lattices_Osemilattice__inf_270,axiom,
    semilattice_inf($o) ).

tff(tcon_HOL_Obool___Lattices_Obounded__lattice_271,axiom,
    bounded_lattice($o) ).

tff(tcon_HOL_Obool___Complete__Lattices_OSup_272,axiom,
    complete_Sup($o) ).

tff(tcon_HOL_Obool___Complete__Lattices_OInf_273,axiom,
    complete_Inf($o) ).

tff(tcon_HOL_Obool___Orderings_Oorder__top_274,axiom,
    order_top($o) ).

tff(tcon_HOL_Obool___Orderings_Oorder__bot_275,axiom,
    order_bot($o) ).

tff(tcon_HOL_Obool___Countable_Ocountable_276,axiom,
    countable($o) ).

tff(tcon_HOL_Obool___Orderings_Opreorder_277,axiom,
    preorder($o) ).

tff(tcon_HOL_Obool___Orderings_Olinorder_278,axiom,
    linorder($o) ).

tff(tcon_HOL_Obool___Finite__Set_Ofinite_279,axiom,
    finite_finite($o) ).

tff(tcon_HOL_Obool___Orderings_Oorder_280,axiom,
    order($o) ).

tff(tcon_HOL_Obool___Orderings_Oord_281,axiom,
    ord($o) ).

tff(tcon_HOL_Obool___Groups_Ouminus_282,axiom,
    uminus($o) ).

tff(tcon_HOL_Obool___Lattices_Osup_283,axiom,
    sup($o) ).

tff(tcon_HOL_Obool___Lattices_Oinf_284,axiom,
    inf($o) ).

tff(tcon_HOL_Obool___Heap_Oheap_285,axiom,
    heap($o) ).

tff(tcon_HOL_Obool___HOL_Oequal_286,axiom,
    cl_HOL_Oequal($o) ).

tff(tcon_Heap_Oref___Quickcheck__Exhaustive_Ofull__exhaustive_287,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => quickc3360725361186068524ustive(ref(A19)) ) ).

tff(tcon_Heap_Oref___Quickcheck__Random_Orandom_288,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => quickcheck_random(ref(A19)) ) ).

tff(tcon_Heap_Oref___Countable_Ocountable_289,axiom,
    ! [A19: $tType] : countable(ref(A19)) ).

tff(tcon_Heap_Oref___Heap_Oheap_290,axiom,
    ! [A19: $tType] : heap(ref(A19)) ).

tff(tcon_Heap_Oref___HOL_Oequal_291,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(ref(A19)) ).

tff(tcon_List_Olist___Quickcheck__Exhaustive_Ofull__exhaustive_292,axiom,
    ! [A19: $tType] :
      ( quickc3360725361186068524ustive(A19)
     => quickc3360725361186068524ustive(list(A19)) ) ).

tff(tcon_List_Olist___Quickcheck__Random_Orandom_293,axiom,
    ! [A19: $tType] :
      ( quickcheck_random(A19)
     => quickcheck_random(list(A19)) ) ).

tff(tcon_List_Olist___Countable_Ocountable_294,axiom,
    ! [A19: $tType] :
      ( countable(A19)
     => countable(list(A19)) ) ).

tff(tcon_List_Olist___Heap_Oheap_295,axiom,
    ! [A19: $tType] :
      ( heap(A19)
     => heap(list(A19)) ) ).

tff(tcon_List_Olist___HOL_Oequal_296,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(list(A19)) ).

tff(tcon_Heap_Oarray___Quickcheck__Exhaustive_Ofull__exhaustive_297,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => quickc3360725361186068524ustive(array(A19)) ) ).

tff(tcon_Heap_Oarray___Quickcheck__Random_Orandom_298,axiom,
    ! [A19: $tType] :
      ( typerep2(A19)
     => quickcheck_random(array(A19)) ) ).

tff(tcon_Heap_Oarray___Countable_Ocountable_299,axiom,
    ! [A19: $tType] : countable(array(A19)) ).

tff(tcon_Heap_Oarray___Heap_Oheap_300,axiom,
    ! [A19: $tType] : heap(array(A19)) ).

tff(tcon_Heap_Oarray___HOL_Oequal_301,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(array(A19)) ).

tff(tcon_String_Ochar___Quickcheck__Exhaustive_Ofull__exhaustive_302,axiom,
    quickc3360725361186068524ustive(char) ).

tff(tcon_String_Ochar___Quickcheck__Random_Orandom_303,axiom,
    quickcheck_random(char) ).

tff(tcon_String_Ochar___Countable_Ocountable_304,axiom,
    countable(char) ).

tff(tcon_String_Ochar___Finite__Set_Ofinite_305,axiom,
    finite_finite(char) ).

tff(tcon_String_Ochar___Heap_Oheap_306,axiom,
    heap(char) ).

tff(tcon_String_Ochar___HOL_Oequal_307,axiom,
    cl_HOL_Oequal(char) ).

tff(tcon_Sum__Type_Osum___Quickcheck__Exhaustive_Ofull__exhaustive_308,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( quickc3360725361186068524ustive(A19)
        & quickc3360725361186068524ustive(A20) )
     => quickc3360725361186068524ustive(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___Quickcheck__Random_Orandom_309,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( quickcheck_random(A19)
        & quickcheck_random(A20) )
     => quickcheck_random(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___Countable_Ocountable_310,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( countable(A19)
        & countable(A20) )
     => countable(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___Finite__Set_Ofinite_311,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( finite_finite(A19)
        & finite_finite(A20) )
     => finite_finite(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___Heap_Oheap_312,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( heap(A19)
        & heap(A20) )
     => heap(sum_sum(A19,A20)) ) ).

tff(tcon_Sum__Type_Osum___HOL_Oequal_313,axiom,
    ! [A19: $tType,A20: $tType] : cl_HOL_Oequal(sum_sum(A19,A20)) ).

tff(tcon_Option_Ooption___Quickcheck__Exhaustive_Ofull__exhaustive_314,axiom,
    ! [A19: $tType] :
      ( quickc3360725361186068524ustive(A19)
     => quickc3360725361186068524ustive(option(A19)) ) ).

tff(tcon_Option_Ooption___Complete__Lattices_Ocomplete__lattice_315,axiom,
    ! [A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => comple6319245703460814977attice(option(A19)) ) ).

tff(tcon_Option_Ooption___Complete__Partial__Order_Occpo_316,axiom,
    ! [A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => comple9053668089753744459l_ccpo(option(A19)) ) ).

tff(tcon_Option_Ooption___Quickcheck__Random_Orandom_317,axiom,
    ! [A19: $tType] :
      ( quickcheck_random(A19)
     => quickcheck_random(option(A19)) ) ).

tff(tcon_Option_Ooption___Lattices_Osemilattice__sup_318,axiom,
    ! [A19: $tType] :
      ( semilattice_sup(A19)
     => semilattice_sup(option(A19)) ) ).

tff(tcon_Option_Ooption___Lattices_Osemilattice__inf_319,axiom,
    ! [A19: $tType] :
      ( semilattice_inf(A19)
     => semilattice_inf(option(A19)) ) ).

tff(tcon_Option_Ooption___Lattices_Obounded__lattice_320,axiom,
    ! [A19: $tType] :
      ( bounded_lattice_top(A19)
     => bounded_lattice(option(A19)) ) ).

tff(tcon_Option_Ooption___Complete__Lattices_OSup_321,axiom,
    ! [A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => complete_Sup(option(A19)) ) ).

tff(tcon_Option_Ooption___Complete__Lattices_OInf_322,axiom,
    ! [A19: $tType] :
      ( comple6319245703460814977attice(A19)
     => complete_Inf(option(A19)) ) ).

tff(tcon_Option_Ooption___Orderings_Oorder__top_323,axiom,
    ! [A19: $tType] :
      ( order_top(A19)
     => order_top(option(A19)) ) ).

tff(tcon_Option_Ooption___Orderings_Oorder__bot_324,axiom,
    ! [A19: $tType] :
      ( order(A19)
     => order_bot(option(A19)) ) ).

tff(tcon_Option_Ooption___Countable_Ocountable_325,axiom,
    ! [A19: $tType] :
      ( countable(A19)
     => countable(option(A19)) ) ).

tff(tcon_Option_Ooption___Orderings_Opreorder_326,axiom,
    ! [A19: $tType] :
      ( preorder(A19)
     => preorder(option(A19)) ) ).

tff(tcon_Option_Ooption___Orderings_Olinorder_327,axiom,
    ! [A19: $tType] :
      ( linorder(A19)
     => linorder(option(A19)) ) ).

tff(tcon_Option_Ooption___Finite__Set_Ofinite_328,axiom,
    ! [A19: $tType] :
      ( finite_finite(A19)
     => finite_finite(option(A19)) ) ).

tff(tcon_Option_Ooption___Orderings_Oorder_329,axiom,
    ! [A19: $tType] :
      ( order(A19)
     => order(option(A19)) ) ).

tff(tcon_Option_Ooption___Orderings_Oord_330,axiom,
    ! [A19: $tType] :
      ( preorder(A19)
     => ord(option(A19)) ) ).

tff(tcon_Option_Ooption___Lattices_Osup_331,axiom,
    ! [A19: $tType] :
      ( sup(A19)
     => sup(option(A19)) ) ).

tff(tcon_Option_Ooption___Lattices_Oinf_332,axiom,
    ! [A19: $tType] :
      ( inf(A19)
     => inf(option(A19)) ) ).

tff(tcon_Option_Ooption___Heap_Oheap_333,axiom,
    ! [A19: $tType] :
      ( heap(A19)
     => heap(option(A19)) ) ).

tff(tcon_Option_Ooption___HOL_Oequal_334,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(option(A19)) ).

tff(tcon_Predicate_Oseq___HOL_Oequal_335,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(seq(A19)) ).

tff(tcon_Predicate_Opred___Complete__Lattices_Ocomplete__lattice_336,axiom,
    ! [A19: $tType] : comple6319245703460814977attice(pred(A19)) ).

tff(tcon_Predicate_Opred___Boolean__Algebras_Oboolean__algebra_337,axiom,
    ! [A19: $tType] : boolea8198339166811842893lgebra(pred(A19)) ).

tff(tcon_Predicate_Opred___Complete__Partial__Order_Occpo_338,axiom,
    ! [A19: $tType] : comple9053668089753744459l_ccpo(pred(A19)) ).

tff(tcon_Predicate_Opred___Lattices_Osemilattice__sup_339,axiom,
    ! [A19: $tType] : semilattice_sup(pred(A19)) ).

tff(tcon_Predicate_Opred___Lattices_Osemilattice__inf_340,axiom,
    ! [A19: $tType] : semilattice_inf(pred(A19)) ).

tff(tcon_Predicate_Opred___Lattices_Obounded__lattice_341,axiom,
    ! [A19: $tType] : bounded_lattice(pred(A19)) ).

tff(tcon_Predicate_Opred___Complete__Lattices_OSup_342,axiom,
    ! [A19: $tType] : complete_Sup(pred(A19)) ).

tff(tcon_Predicate_Opred___Complete__Lattices_OInf_343,axiom,
    ! [A19: $tType] : complete_Inf(pred(A19)) ).

tff(tcon_Predicate_Opred___Orderings_Oorder__top_344,axiom,
    ! [A19: $tType] : order_top(pred(A19)) ).

tff(tcon_Predicate_Opred___Orderings_Oorder__bot_345,axiom,
    ! [A19: $tType] : order_bot(pred(A19)) ).

tff(tcon_Predicate_Opred___Orderings_Opreorder_346,axiom,
    ! [A19: $tType] : preorder(pred(A19)) ).

tff(tcon_Predicate_Opred___Orderings_Oorder_347,axiom,
    ! [A19: $tType] : order(pred(A19)) ).

tff(tcon_Predicate_Opred___Orderings_Oord_348,axiom,
    ! [A19: $tType] : ord(pred(A19)) ).

tff(tcon_Predicate_Opred___Groups_Ouminus_349,axiom,
    ! [A19: $tType] : uminus(pred(A19)) ).

tff(tcon_Predicate_Opred___Lattices_Osup_350,axiom,
    ! [A19: $tType] : sup(pred(A19)) ).

tff(tcon_Predicate_Opred___Lattices_Oinf_351,axiom,
    ! [A19: $tType] : inf(pred(A19)) ).

tff(tcon_Predicate_Opred___HOL_Oequal_352,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(pred(A19)) ).

tff(tcon_Assertions_Oassn___Boolean__Algebras_Oboolean__algebra_353,axiom,
    boolea8198339166811842893lgebra(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Osemilattice__sup_354,axiom,
    semilattice_sup(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Osemilattice__inf_355,axiom,
    semilattice_inf(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Obounded__lattice_356,axiom,
    bounded_lattice(assn) ).

tff(tcon_Assertions_Oassn___Groups_Oab__semigroup__mult_357,axiom,
    ab_semigroup_mult(assn) ).

tff(tcon_Assertions_Oassn___Groups_Ocomm__monoid__mult_358,axiom,
    comm_monoid_mult(assn) ).

tff(tcon_Assertions_Oassn___Groups_Osemigroup__mult_359,axiom,
    semigroup_mult(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oorder__top_360,axiom,
    order_top(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oorder__bot_361,axiom,
    order_bot(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Opreorder_362,axiom,
    preorder(assn) ).

tff(tcon_Assertions_Oassn___Groups_Omonoid__mult_363,axiom,
    monoid_mult(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oorder_364,axiom,
    order(assn) ).

tff(tcon_Assertions_Oassn___Orderings_Oord_365,axiom,
    ord(assn) ).

tff(tcon_Assertions_Oassn___Groups_Ouminus_366,axiom,
    uminus(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Osup_367,axiom,
    sup(assn) ).

tff(tcon_Assertions_Oassn___Lattices_Oinf_368,axiom,
    inf(assn) ).

tff(tcon_Assertions_Oassn___Power_Opower_369,axiom,
    power(assn) ).

tff(tcon_Assertions_Oassn___Groups_Oone_370,axiom,
    one(assn) ).

tff(tcon_Assertions_Oassn___Rings_Odvd_371,axiom,
    dvd(assn) ).

tff(tcon_Typerep_Otyperep___Countable_Ocountable_372,axiom,
    countable(typerep) ).

tff(tcon_Typerep_Otyperep___Heap_Oheap_373,axiom,
    heap(typerep) ).

tff(tcon_Typerep_Otyperep___HOL_Oequal_374,axiom,
    cl_HOL_Oequal(typerep) ).

tff(tcon_Multiset_Omultiset___Quickcheck__Exhaustive_Ofull__exhaustive_375,axiom,
    ! [A19: $tType] :
      ( quickc3360725361186068524ustive(A19)
     => quickc3360725361186068524ustive(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Oordered__ab__semigroup__add_376,axiom,
    ! [A19: $tType] :
      ( preorder(A19)
     => ordere6658533253407199908up_add(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Ocancel__ab__semigroup__add_377,axiom,
    ! [A19: $tType] : cancel2418104881723323429up_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocancel__comm__monoid__add_378,axiom,
    ! [A19: $tType] : cancel1802427076303600483id_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocancel__semigroup__add_379,axiom,
    ! [A19: $tType] : cancel_semigroup_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Quickcheck__Random_Orandom_380,axiom,
    ! [A19: $tType] :
      ( quickcheck_random(A19)
     => quickcheck_random(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Ocomm__monoid__diff_381,axiom,
    ! [A19: $tType] : comm_monoid_diff(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Groups_Oab__semigroup__add_382,axiom,
    ! [A19: $tType] : ab_semigroup_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Groups_Ocomm__monoid__add_383,axiom,
    ! [A19: $tType] : comm_monoid_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Complete__Lattices_OSup_384,axiom,
    ! [A19: $tType] : complete_Sup(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Complete__Lattices_OInf_385,axiom,
    ! [A19: $tType] : complete_Inf(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Groups_Osemigroup__add_386,axiom,
    ! [A19: $tType] : semigroup_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Orderings_Opreorder_387,axiom,
    ! [A19: $tType] :
      ( preorder(A19)
     => preorder(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Omonoid__add_388,axiom,
    ! [A19: $tType] : monoid_add(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Orderings_Oorder_389,axiom,
    ! [A19: $tType] :
      ( preorder(A19)
     => order(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Orderings_Oord_390,axiom,
    ! [A19: $tType] :
      ( preorder(A19)
     => ord(multiset(A19)) ) ).

tff(tcon_Multiset_Omultiset___Groups_Ozero_391,axiom,
    ! [A19: $tType] : zero(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___Groups_Oplus_392,axiom,
    ! [A19: $tType] : plus(multiset(A19)) ).

tff(tcon_Multiset_Omultiset___HOL_Oequal_393,axiom,
    ! [A19: $tType] :
      ( cl_HOL_Oequal(A19)
     => cl_HOL_Oequal(multiset(A19)) ) ).

tff(tcon_Product__Type_Oprod___Quickcheck__Exhaustive_Ofull__exhaustive_394,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( quickc3360725361186068524ustive(A19)
        & quickc3360725361186068524ustive(A20) )
     => quickc3360725361186068524ustive(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Quickcheck__Exhaustive_Oexhaustive_395,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( quickc658316121487927005ustive(A19)
        & quickc658316121487927005ustive(A20) )
     => quickc658316121487927005ustive(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Quickcheck__Random_Orandom_396,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( quickcheck_random(A19)
        & quickcheck_random(A20) )
     => quickcheck_random(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Countable_Ocountable_397,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( countable(A19)
        & countable(A20) )
     => countable(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Finite__Set_Ofinite_398,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( finite_finite(A19)
        & finite_finite(A20) )
     => finite_finite(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___Heap_Oheap_399,axiom,
    ! [A19: $tType,A20: $tType] :
      ( ( heap(A19)
        & heap(A20) )
     => heap(product_prod(A19,A20)) ) ).

tff(tcon_Product__Type_Oprod___HOL_Oequal_400,axiom,
    ! [A19: $tType,A20: $tType] : cl_HOL_Oequal(product_prod(A19,A20)) ).

tff(tcon_Product__Type_Ounit___Quickcheck__Exhaustive_Ofull__exhaustive_401,axiom,
    quickc3360725361186068524ustive(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Lattices_Ocomplete__lattice_402,axiom,
    comple6319245703460814977attice(product_unit) ).

tff(tcon_Product__Type_Ounit___Boolean__Algebras_Oboolean__algebra_403,axiom,
    boolea8198339166811842893lgebra(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Partial__Order_Occpo_404,axiom,
    comple9053668089753744459l_ccpo(product_unit) ).

tff(tcon_Product__Type_Ounit___Quickcheck__Random_Orandom_405,axiom,
    quickcheck_random(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Osemilattice__sup_406,axiom,
    semilattice_sup(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Osemilattice__inf_407,axiom,
    semilattice_inf(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Obounded__lattice_408,axiom,
    bounded_lattice(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Lattices_OSup_409,axiom,
    complete_Sup(product_unit) ).

tff(tcon_Product__Type_Ounit___Complete__Lattices_OInf_410,axiom,
    complete_Inf(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oorder__top_411,axiom,
    order_top(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oorder__bot_412,axiom,
    order_bot(product_unit) ).

tff(tcon_Product__Type_Ounit___Countable_Ocountable_413,axiom,
    countable(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Opreorder_414,axiom,
    preorder(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Olinorder_415,axiom,
    linorder(product_unit) ).

tff(tcon_Product__Type_Ounit___Finite__Set_Ofinite_416,axiom,
    finite_finite(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oorder_417,axiom,
    order(product_unit) ).

tff(tcon_Product__Type_Ounit___Orderings_Oord_418,axiom,
    ord(product_unit) ).

tff(tcon_Product__Type_Ounit___Groups_Ouminus_419,axiom,
    uminus(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Osup_420,axiom,
    sup(product_unit) ).

tff(tcon_Product__Type_Ounit___Lattices_Oinf_421,axiom,
    inf(product_unit) ).

tff(tcon_Product__Type_Ounit___Heap_Oheap_422,axiom,
    heap(product_unit) ).

tff(tcon_Product__Type_Ounit___HOL_Oequal_423,axiom,
    cl_HOL_Oequal(product_unit) ).

tff(tcon_Heap_Oheap_Oheap__ext___Quickcheck__Random_Orandom_424,axiom,
    ! [A19: $tType] :
      ( quickcheck_random(A19)
     => quickcheck_random(heap_ext(A19)) ) ).

tff(tcon_Heap_Oheap_Oheap__ext___HOL_Oequal_425,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(heap_ext(A19)) ).

tff(tcon_Code__Numeral_Ointeger___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations_426,axiom,
    bit_un5681908812861735899ations(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Semiring__Normalization_Ocomm__semiring__1__cancel__crossproduct_427,axiom,
    semiri1453513574482234551roduct(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Euclidean__Division_Ounique__euclidean__semiring__with__nat_428,axiom,
    euclid5411537665997757685th_nat(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Euclidean__Division_Ounique__euclidean__ring__with__nat_429,axiom,
    euclid8789492081693882211th_nat(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__ab__semigroup__monoid__add__imp__le_430,axiom,
    ordere1937475149494474687imp_le(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Euclidean__Division_Ounique__euclidean__semiring_431,axiom,
    euclid3128863361964157862miring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Euclidean__Division_Oeuclidean__semiring__cancel_432,axiom,
    euclid4440199948858584721cancel(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Divides_Ounique__euclidean__semiring__numeral_433,axiom,
    unique1627219031080169319umeral(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Euclidean__Division_Oeuclidean__ring__cancel_434,axiom,
    euclid8851590272496341667cancel(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ostrict__ordered__ab__semigroup__add_435,axiom,
    strict9044650504122735259up_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__cancel__ab__semigroup__add_436,axiom,
    ordere580206878836729694up_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__ab__semigroup__add__imp__le_437,axiom,
    ordere2412721322843649153imp_le(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Bit__Operations_Osemiring__bit__operations_438,axiom,
    bit_se359711467146920520ations(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Quickcheck__Exhaustive_Ofull__exhaustive_439,axiom,
    quickc3360725361186068524ustive(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ostrict__ordered__comm__monoid__add_440,axiom,
    strict7427464778891057005id_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__cancel__comm__monoid__add_441,axiom,
    ordere8940638589300402666id_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Euclidean__Division_Oeuclidean__semiring_442,axiom,
    euclid3725896446679973847miring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__semiring__1__strict_443,axiom,
    linord715952674999750819strict(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Olinordered__ab__semigroup__add_444,axiom,
    linord4140545234300271783up_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Bit__Operations_Oring__bit__operations_445,axiom,
    bit_ri3973907225187159222ations(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__nonzero__semiring_446,axiom,
    linord181362715937106298miring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Quickcheck__Exhaustive_Oexhaustive_447,axiom,
    quickc658316121487927005ustive(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemiring__no__zero__divisors_448,axiom,
    semiri3467727345109120633visors(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__ab__semigroup__add_449,axiom,
    ordere6658533253407199908up_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__ab__group__add__abs_450,axiom,
    ordere166539214618696060dd_abs(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__comm__monoid__add_451,axiom,
    ordere6911136660526730532id_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Olinordered__ab__group__add_452,axiom,
    linord5086331880401160121up_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ocancel__ab__semigroup__add_453,axiom,
    cancel2418104881723323429up_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Oring__1__no__zero__divisors_454,axiom,
    ring_15535105094025558882visors(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ocancel__comm__monoid__add_455,axiom,
    cancel1802427076303600483id_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__ring__strict_456,axiom,
    linord4710134922213307826strict(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ocomm__semiring__1__cancel_457,axiom,
    comm_s4317794764714335236cancel(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Bit__Operations_Osemiring__bits_458,axiom,
    bit_semiring_bits(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__semiring__1_459,axiom,
    linord6961819062388156250ring_1(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oordered__ab__group__add_460,axiom,
    ordered_ab_group_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ocancel__semigroup__add_461,axiom,
    cancel_semigroup_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__semidom_462,axiom,
    linordered_semidom(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Quickcheck__Random_Orandom_463,axiom,
    quickcheck_random(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oab__semigroup__mult_464,axiom,
    ab_semigroup_mult(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Oalgebraic__semidom_465,axiom,
    algebraic_semidom(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ocomm__monoid__mult_466,axiom,
    comm_monoid_mult(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oab__semigroup__add_467,axiom,
    ab_semigroup_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Parity_Osemiring__parity_468,axiom,
    semiring_parity(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ocomm__monoid__add_469,axiom,
    comm_monoid_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemiring__modulo_470,axiom,
    semiring_modulo(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__ring_471,axiom,
    linordered_ring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Olinordered__idom_472,axiom,
    linordered_idom(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ocomm__semiring__1_473,axiom,
    comm_semiring_1(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ocomm__semiring__0_474,axiom,
    comm_semiring_0(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Osemigroup__mult_475,axiom,
    semigroup_mult(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemidom__modulo_476,axiom,
    semidom_modulo(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemidom__divide_477,axiom,
    semidom_divide(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Num_Osemiring__numeral_478,axiom,
    semiring_numeral(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Osemigroup__add_479,axiom,
    semigroup_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ozero__less__one_480,axiom,
    zero_less_one(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ocomm__semiring_481,axiom,
    comm_semiring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Nat_Osemiring__char__0_482,axiom,
    semiring_char_0(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oab__group__add_483,axiom,
    ab_group_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ozero__neq__one_484,axiom,
    zero_neq_one(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Oordered__ring_485,axiom,
    ordered_ring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Oidom__abs__sgn_486,axiom,
    idom_abs_sgn(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Parity_Oring__parity_487,axiom,
    ring_parity(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Orderings_Opreorder_488,axiom,
    preorder(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Orderings_Olinorder_489,axiom,
    linorder(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Omonoid__mult_490,axiom,
    monoid_mult(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ocomm__ring__1_491,axiom,
    comm_ring_1(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Omonoid__add_492,axiom,
    monoid_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemiring__1_493,axiom,
    semiring_1(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemiring__0_494,axiom,
    semiring_0(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ogroup__add_495,axiom,
    group_add(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Ocomm__ring_496,axiom,
    comm_ring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Orderings_Oorder_497,axiom,
    order(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Num_Oneg__numeral_498,axiom,
    neg_numeral(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Nat_Oring__char__0_499,axiom,
    ring_char_0(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Osemiring_500,axiom,
    semiring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Orderings_Oord_501,axiom,
    ord(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ouminus_502,axiom,
    uminus(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Oring__1_503,axiom,
    ring_1(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Power_Opower_504,axiom,
    power(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Num_Onumeral_505,axiom,
    numeral(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Ozero_506,axiom,
    zero(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oplus_507,axiom,
    plus(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Oring_508,axiom,
    ring(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Groups_Oone_509,axiom,
    one(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___Rings_Odvd_510,axiom,
    dvd(code_integer) ).

tff(tcon_Code__Numeral_Ointeger___HOL_Oequal_511,axiom,
    cl_HOL_Oequal(code_integer) ).

tff(tcon_Code__Numeral_Onatural___Bit__Operations_Ounique__euclidean__semiring__with__bit__operations_512,axiom,
    bit_un5681908812861735899ations(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Ounique__euclidean__semiring__with__nat_513,axiom,
    euclid5411537665997757685th_nat(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__ab__semigroup__monoid__add__imp__le_514,axiom,
    ordere1937475149494474687imp_le(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Ounique__euclidean__semiring_515,axiom,
    euclid3128863361964157862miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Oeuclidean__semiring__cancel_516,axiom,
    euclid4440199948858584721cancel(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ostrict__ordered__ab__semigroup__add_517,axiom,
    strict9044650504122735259up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__cancel__ab__semigroup__add_518,axiom,
    ordere580206878836729694up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__ab__semigroup__add__imp__le_519,axiom,
    ordere2412721322843649153imp_le(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Bit__Operations_Osemiring__bit__operations_520,axiom,
    bit_se359711467146920520ations(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Quickcheck__Exhaustive_Ofull__exhaustive_521,axiom,
    quickc3360725361186068524ustive(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ostrict__ordered__comm__monoid__add_522,axiom,
    strict7427464778891057005id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__cancel__comm__monoid__add_523,axiom,
    ordere8940638589300402666id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Euclidean__Division_Oeuclidean__semiring_524,axiom,
    euclid3725896446679973847miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Olinordered__ab__semigroup__add_525,axiom,
    linord4140545234300271783up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__nonzero__semiring_526,axiom,
    linord181362715937106298miring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Quickcheck__Exhaustive_Oexhaustive_527,axiom,
    quickc658316121487927005ustive(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__no__zero__divisors_528,axiom,
    semiri3467727345109120633visors(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__ab__semigroup__add_529,axiom,
    ordere6658533253407199908up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oordered__comm__monoid__add_530,axiom,
    ordere6911136660526730532id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocancel__ab__semigroup__add_531,axiom,
    cancel2418104881723323429up_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocancel__comm__monoid__add_532,axiom,
    cancel1802427076303600483id_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring__1__cancel_533,axiom,
    comm_s4317794764714335236cancel(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Bit__Operations_Osemiring__bits_534,axiom,
    bit_semiring_bits(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocancel__semigroup__add_535,axiom,
    cancel_semigroup_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Olinordered__semidom_536,axiom,
    linordered_semidom(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Quickcheck__Random_Orandom_537,axiom,
    quickcheck_random(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oab__semigroup__mult_538,axiom,
    ab_semigroup_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Oalgebraic__semidom_539,axiom,
    algebraic_semidom(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocomm__monoid__mult_540,axiom,
    comm_monoid_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocomm__monoid__diff_541,axiom,
    comm_monoid_diff(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oab__semigroup__add_542,axiom,
    ab_semigroup_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Parity_Osemiring__parity_543,axiom,
    semiring_parity(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ocomm__monoid__add_544,axiom,
    comm_monoid_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__modulo_545,axiom,
    semiring_modulo(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring__1_546,axiom,
    comm_semiring_1(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring__0_547,axiom,
    comm_semiring_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Osemigroup__mult_548,axiom,
    semigroup_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemidom__modulo_549,axiom,
    semidom_modulo(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemidom__divide_550,axiom,
    semidom_divide(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Num_Osemiring__numeral_551,axiom,
    semiring_numeral(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Osemigroup__add_552,axiom,
    semigroup_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ozero__less__one_553,axiom,
    zero_less_one(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ocomm__semiring_554,axiom,
    comm_semiring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Nat_Osemiring__char__0_555,axiom,
    semiring_char_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Ozero__neq__one_556,axiom,
    zero_neq_one(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Opreorder_557,axiom,
    preorder(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Olinorder_558,axiom,
    linorder(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Omonoid__mult_559,axiom,
    monoid_mult(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Omonoid__add_560,axiom,
    monoid_add(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__1_561,axiom,
    semiring_1(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring__0_562,axiom,
    semiring_0(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Oorder_563,axiom,
    order(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Osemiring_564,axiom,
    semiring(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Orderings_Oord_565,axiom,
    ord(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Power_Opower_566,axiom,
    power(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Num_Onumeral_567,axiom,
    numeral(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Ozero_568,axiom,
    zero(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oplus_569,axiom,
    plus(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Groups_Oone_570,axiom,
    one(code_natural) ).

tff(tcon_Code__Numeral_Onatural___Rings_Odvd_571,axiom,
    dvd(code_natural) ).

tff(tcon_Code__Numeral_Onatural___HOL_Oequal_572,axiom,
    cl_HOL_Oequal(code_natural) ).

tff(tcon_Heap__Time__Monad_OHeap___Quickcheck__Random_Orandom_573,axiom,
    ! [A19: $tType] :
      ( quickcheck_random(A19)
     => quickcheck_random(heap_Time_Heap(A19)) ) ).

tff(tcon_Heap__Time__Monad_OHeap___HOL_Oequal_574,axiom,
    ! [A19: $tType] : cl_HOL_Oequal(heap_Time_Heap(A19)) ).

% Helper facts (5)
tff(help_fNot_2_1_U,axiom,
    ! [P: $o] :
      ( (P)
      | aa($o,$o,fNot,(P)) ) ).

tff(help_fNot_1_1_U,axiom,
    ! [P: $o] :
      ( ~ aa($o,$o,fNot,(P))
      | ~ (P) ) ).

tff(help_fequal_2_1_T,axiom,
    ! [A: $tType,X2: A,Y: A] :
      ( ( X2 != Y )
      | aa(A,$o,aa(A,fun(A,$o),fequal(A),X2),Y) ) ).

tff(help_fequal_1_1_T,axiom,
    ! [A: $tType,X2: A,Y: A] :
      ( ~ aa(A,$o,aa(A,fun(A,$o),fequal(A),X2),Y)
      | ( X2 = Y ) ) ).

tff(help_fChoice_1_1_T,axiom,
    ! [A: $tType,P: fun(A,$o)] :
      ( aa(A,$o,P,fChoice(A,P))
      = ( ? [X9: A] : aa(A,$o,P,X9) ) ) ).

% Free types (3)
tff(tfree_0,hypothesis,
    heap(b) ).

tff(tfree_1,hypothesis,
    linorder(c) ).

tff(tfree_2,hypothesis,
    heap(a) ).

% Conjectures (1)
tff(conj_0,conjecture,
    aa(heap_ext(product_unit),option(product_prod(array(a),product_prod(heap_ext(product_unit),nat))),aa(heap_Time_Heap(array(a)),fun(heap_ext(product_unit),option(product_prod(array(a),product_prod(heap_ext(product_unit),nat)))),heap_Time_execute(array(a)),array_of_list(a,xs)),h) != none(product_prod(array(a),product_prod(heap_ext(product_unit),nat))) ).

%------------------------------------------------------------------------------