TPTP Problem File: SWV629_5.p
View Solutions
- Solve Problem
%------------------------------------------------------------------------------
% File : SWV629_5 : TPTP v9.2.1. Released v6.0.0.
% Domain : Software Verification
% Problem : Fast Fourier Transform line 223
% Version : Especial.
% English : Formalization of a functional implementation of the FFT algorithm
% over the complex numbers, and its inverse. Both are shown
% equivalent to the usual definitions of these operations through
% Vandermonde matrices. They are also shown to be inverse to each
% other, more precisely, that composition of the inverse and the
% transformation yield the identity up to a scalar.
% Refs : [BN10] Boehme & Nipkow (2010), Sledgehammer: Judgement Day
% : [Bla13] Blanchette (2011), Email to Geoff Sutcliffe
% Source : [Bla13]
% Names : fft_223 [Bla13]
% Status : Theorem
% Rating : 0.00 v7.5.0, 0.33 v7.4.0, 0.25 v7.1.0, 0.33 v6.4.0
% Syntax : Number of formulae : 205 ( 86 unt; 48 typ; 0 def)
% Number of atoms : 306 ( 107 equ)
% Maximal formula atoms : 7 ( 1 avg)
% Number of connectives : 171 ( 22 ~; 4 |; 26 &)
% ( 25 <=>; 94 =>; 0 <=; 0 <~>)
% Maximal formula depth : 11 ( 3 avg)
% Maximal term depth : 5 ( 1 avg)
% Number of types : 5 ( 4 usr)
% Number of type conns : 23 ( 15 >; 8 *; 0 +; 0 <<)
% Number of predicates : 30 ( 29 usr; 0 prp; 1-4 aty)
% Number of functors : 15 ( 15 usr; 3 con; 0-4 aty)
% Number of variables : 249 ( 206 !; 3 ?; 249 :)
% ( 40 !>; 0 ?*; 0 @-; 0 @+)
% SPC : TF1_THM_EQU_NAR
% Comments : This file was generated by Isabelle (most likely Sledgehammer)
% 2011-12-13 16:17:08
%------------------------------------------------------------------------------
%----Should-be-implicit typings (5)
tff(ty_tc_Complex_Ocomplex,type,
complex: $tType ).
tff(ty_tc_HOL_Obool,type,
bool: $tType ).
tff(ty_tc_Int_Oint,type,
int: $tType ).
tff(ty_tc_Nat_Onat,type,
nat: $tType ).
tff(ty_tc_fun,type,
fun: ( $tType * $tType ) > $tType ).
%----Explicit typings (43)
tff(sy_cl_Groups_Oone,type,
one:
!>[A: $tType] : $o ).
tff(sy_cl_Int_Onumber,type,
number:
!>[A: $tType] : $o ).
tff(sy_cl_Groups_Ozero,type,
zero:
!>[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_Groups_Osgn__if,type,
sgn_if:
!>[A: $tType] : $o ).
tff(sy_cl_Int_Onumber__ring,type,
number_ring:
!>[A: $tType] : $o ).
tff(sy_cl_Int_Oring__char__0,type,
ring_char_0:
!>[A: $tType] : $o ).
tff(sy_cl_Rings_Omult__zero,type,
mult_zero:
!>[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_Groups_Omonoid__mult,type,
monoid_mult:
!>[A: $tType] : $o ).
tff(sy_cl_Rings_Ozero__neq__one,type,
zero_neq_one:
!>[A: $tType] : $o ).
tff(sy_cl_Groups_Oab__group__add,type,
ab_group_add:
!>[A: $tType] : $o ).
tff(sy_cl_Int_Onumber__semiring,type,
number_semiring:
!>[A: $tType] : $o ).
tff(sy_cl_Nat_Osemiring__char__0,type,
semiring_char_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_Ono__zero__divisors,type,
no_zero_divisors:
!>[A: $tType] : $o ).
tff(sy_cl_Rings_Olinordered__semidom,type,
linordered_semidom:
!>[A: $tType] : $o ).
tff(sy_cl_RealVector_Oreal__normed__vector,type,
real_normed_vector:
!>[A: $tType] : $o ).
tff(sy_cl_Rings_Oring__1__no__zero__divisors,type,
ring_11004092258visors:
!>[A: $tType] : $o ).
tff(sy_cl_RealVector_Oreal__normed__algebra__1,type,
real_n2089651433ebra_1:
!>[A: $tType] : $o ).
tff(sy_c_Complex_Ocnj,type,
cnj: complex > complex ).
tff(sy_c_Complex_Oii,type,
ii: complex ).
tff(sy_c_FFT__Mirabelle__uutasbvzez_Oroot,type,
fFT_Mirabelle_root: nat > complex ).
tff(sy_c_Groups_Oone__class_Oone,type,
one_one:
!>[A: $tType] : A ).
tff(sy_c_Groups_Osgn__class_Osgn,type,
sgn_sgn:
!>[A: $tType] : ( A > A ) ).
tff(sy_c_Groups_Ozero__class_Ozero,type,
zero_zero:
!>[A: $tType] : A ).
tff(sy_c_If,type,
if:
!>[A: $tType] : ( ( bool * A * A ) > A ) ).
tff(sy_c_Int_Oiszero,type,
iszero:
!>[A: $tType] : ( A > $o ) ).
tff(sy_c_Int_Onumber__class_Onumber__of,type,
number_number_of:
!>[A: $tType] : ( int > A ) ).
tff(sy_c_Nat_Osemiring__1__class_ONats,type,
semiring_1_Nats:
!>[A: $tType] : fun(A,bool) ).
tff(sy_c_Nat_Osemiring__1__class_Oof__nat,type,
semiring_1_of_nat:
!>[A: $tType] : ( nat > A ) ).
tff(sy_c_Nat__Transfer_Otransfer__morphism,type,
nat_tr1645093318rphism:
!>[B1: $tType,A: $tType] : ( ( fun(B1,A) * fun(B1,bool) ) > $o ) ).
tff(sy_c_Orderings_Oord__class_Oless__eq,type,
ord_less_eq:
!>[A: $tType] : ( ( A * A ) > $o ) ).
tff(sy_c_Power_Opower__class_Opower,type,
power_power:
!>[A: $tType] : ( ( A * nat ) > A ) ).
tff(sy_c_RealVector_Ovector__space,type,
vector_space:
!>[A: $tType,B1: $tType] : ( fun(A,fun(B1,B1)) > $o ) ).
tff(sy_c_aa,type,
aa:
!>[A: $tType,B1: $tType] : ( ( fun(A,B1) * A ) > B1 ) ).
tff(sy_c_fFalse,type,
fFalse: bool ).
tff(sy_c_fTrue,type,
fTrue: bool ).
tff(sy_c_member,type,
member:
!>[A: $tType] : ( ( A * fun(A,bool) ) > $o ) ).
tff(sy_c_pp,type,
pp: bool > $o ).
%----Relevant facts (97)
tff(fact_0_root0,axiom,
fFT_Mirabelle_root(zero_zero(nat)) = one_one(complex) ).
tff(fact_1_one__reorient,axiom,
! [A: $tType] :
( one(A)
=> ! [X2: A] :
( ( one_one(A) = X2 )
<=> ( X2 = one_one(A) ) ) ) ).
tff(fact_2_root__unity,axiom,
! [N: nat] : ( power_power(complex,fFT_Mirabelle_root(N),N) = one_one(complex) ) ).
tff(fact_3_root__nonzero,axiom,
! [N: nat] : ( fFT_Mirabelle_root(N) != zero_zero(complex) ) ).
tff(fact_4_of__nat__1,axiom,
! [A: $tType] :
( semiring_1(A)
=> ( semiring_1_of_nat(A,one_one(nat)) = one_one(A) ) ) ).
tff(fact_5_complex__i__not__one,axiom,
ii != one_one(complex) ).
tff(fact_6_complex__cnj__one,axiom,
cnj(one_one(complex)) = one_one(complex) ).
tff(fact_7_Nats__1,axiom,
! [A: $tType] :
( semiring_1(A)
=> member(A,one_one(A),semiring_1_Nats(A)) ) ).
tff(fact_8_not__iszero__1,axiom,
! [A: $tType] :
( semiring_1(A)
=> ~ iszero(A,one_one(A)) ) ).
tff(fact_9_sgn__one,axiom,
! [A: $tType] :
( real_n2089651433ebra_1(A)
=> ( sgn_sgn(A,one_one(A)) = one_one(A) ) ) ).
tff(fact_10_vector__space_Oscale__one,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [X2: B1,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( aa(B1,B1,aa(A,fun(B1,B1),Scale,one_one(A)),X2) = X2 ) ) ) ).
tff(fact_11_of__nat__eq__iff,axiom,
! [A: $tType] :
( semiring_char_0(A)
=> ! [N1: nat,M2: nat] :
( ( semiring_1_of_nat(A,M2) = semiring_1_of_nat(A,N1) )
<=> ( M2 = N1 ) ) ) ).
tff(fact_12_complex__cnj__of__nat,axiom,
! [N: nat] : ( cnj(semiring_1_of_nat(complex,N)) = semiring_1_of_nat(complex,N) ) ).
tff(fact_13_complex__cnj__cancel__iff,axiom,
! [Y1: complex,X2: complex] :
( ( cnj(X2) = cnj(Y1) )
<=> ( X2 = Y1 ) ) ).
tff(fact_14_sgn0,axiom,
! [A: $tType] :
( sgn_if(A)
=> ( sgn_sgn(A,zero_zero(A)) = zero_zero(A) ) ) ).
tff(fact_15_sgn__zero,axiom,
! [A: $tType] :
( real_normed_vector(A)
=> ( sgn_sgn(A,zero_zero(A)) = zero_zero(A) ) ) ).
tff(fact_16_complex__cnj__zero,axiom,
cnj(zero_zero(complex)) = zero_zero(complex) ).
tff(fact_17_complex__cnj__zero__iff,axiom,
! [Z1: complex] :
( ( cnj(Z1) = zero_zero(complex) )
<=> ( Z1 = zero_zero(complex) ) ) ).
tff(fact_18_of__nat__0,axiom,
! [A: $tType] :
( semiring_1(A)
=> ( semiring_1_of_nat(A,zero_zero(nat)) = zero_zero(A) ) ) ).
tff(fact_19_iszero__0,axiom,
! [A: $tType] :
( semiring_1(A)
=> iszero(A,zero_zero(A)) ) ).
tff(fact_20_complex__i__not__zero,axiom,
ii != zero_zero(complex) ).
tff(fact_21_Nats__0,axiom,
! [A: $tType] :
( semiring_1(A)
=> member(A,zero_zero(A),semiring_1_Nats(A)) ) ).
tff(fact_22_int__1,axiom,
semiring_1_of_nat(int,one_one(nat)) = one_one(int) ).
tff(fact_23_of__nat__in__Nats,axiom,
! [A: $tType] :
( semiring_1(A)
=> ! [N1: nat] : member(A,semiring_1_of_nat(A,N1),semiring_1_Nats(A)) ) ).
tff(fact_24_iszero__def,axiom,
! [A: $tType] :
( semiring_1(A)
=> ! [Z1: A] :
( iszero(A,Z1)
<=> ( Z1 = zero_zero(A) ) ) ) ).
tff(fact_25_complex__cnj__cnj,axiom,
! [Z: complex] : ( cnj(cnj(Z)) = Z ) ).
tff(fact_26_complex__cnj__power,axiom,
! [N: nat,X: complex] : ( cnj(power_power(complex,X,N)) = power_power(complex,cnj(X),N) ) ).
tff(fact_27_zero__reorient,axiom,
! [A: $tType] :
( zero(A)
=> ! [X2: A] :
( ( zero_zero(A) = X2 )
<=> ( X2 = zero_zero(A) ) ) ) ).
tff(fact_28_sgn__zero__iff,axiom,
! [A: $tType] :
( real_normed_vector(A)
=> ! [X2: A] :
( ( sgn_sgn(A,X2) = zero_zero(A) )
<=> ( X2 = zero_zero(A) ) ) ) ).
tff(fact_29_vector__space_Oscale__eq__0__iff,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [X2: B1,A3: A,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),X2) = zero_zero(B1) )
<=> ( ( A3 = zero_zero(A) )
| ( X2 = zero_zero(B1) ) ) ) ) ) ).
tff(fact_30_vector__space_Oscale__cancel__left,axiom,
! [B1: $tType,A: $tType] :
( ( field(A)
& ab_group_add(B1) )
=> ! [Y1: B1,X2: B1,A3: A,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),X2) = aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),Y1) )
<=> ( ( X2 = Y1 )
| ( A3 = zero_zero(A) ) ) ) ) ) ).
tff(fact_31_vector__space_Oscale__cancel__right,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [B2: A,X2: B1,A3: A,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),X2) = aa(B1,B1,aa(A,fun(B1,B1),Scale,B2),X2) )
<=> ( ( A3 = B2 )
| ( X2 = zero_zero(B1) ) ) ) ) ) ).
tff(fact_32_vector__space_Oscale__zero__left,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [X2: B1,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( aa(B1,B1,aa(A,fun(B1,B1),Scale,zero_zero(A)),X2) = zero_zero(B1) ) ) ) ).
tff(fact_33_vector__space_Oscale__zero__right,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [A3: A,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),zero_zero(B1)) = zero_zero(B1) ) ) ) ).
tff(fact_34_vector__space_Oscale__left__commute,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [X2: B1,B2: A,A3: A,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),aa(B1,B1,aa(A,fun(B1,B1),Scale,B2),X2)) = aa(B1,B1,aa(A,fun(B1,B1),Scale,B2),aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),X2)) ) ) ) ).
tff(fact_35_vector__space_Oscale__left__imp__eq,axiom,
! [A: $tType,B1: $tType] :
( ( ab_group_add(B1)
& field(A) )
=> ! [Y1: B1,X2: B1,A3: A,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( ( A3 != zero_zero(A) )
=> ( ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),X2) = aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),Y1) )
=> ( X2 = Y1 ) ) ) ) ) ).
tff(fact_36_vector__space_Oscale__right__imp__eq,axiom,
! [B1: $tType,A: $tType] :
( ( field(A)
& ab_group_add(B1) )
=> ! [B2: A,A3: A,X2: B1,Scale: fun(A,fun(B1,B1))] :
( vector_space(A,B1,Scale)
=> ( ( X2 != zero_zero(B1) )
=> ( ( aa(B1,B1,aa(A,fun(B1,B1),Scale,A3),X2) = aa(B1,B1,aa(A,fun(B1,B1),Scale,B2),X2) )
=> ( A3 = B2 ) ) ) ) ) ).
tff(fact_37_power__0,axiom,
! [A: $tType] :
( power(A)
=> ! [A1: A] : ( power_power(A,A1,zero_zero(nat)) = one_one(A) ) ) ).
tff(fact_38_power__eq__0__iff,axiom,
! [A: $tType] :
( ( power(A)
& mult_zero(A)
& no_zero_divisors(A)
& zero_neq_one(A) )
=> ! [N1: nat,A3: A] :
( ( power_power(A,A3,N1) = zero_zero(A) )
<=> ( ( A3 = zero_zero(A) )
& ( N1 != zero_zero(nat) ) ) ) ) ).
tff(fact_39_power__one,axiom,
! [A: $tType] :
( monoid_mult(A)
=> ! [N: nat] : ( power_power(A,one_one(A),N) = one_one(A) ) ) ).
tff(fact_40_power__0__left,axiom,
! [A: $tType] :
( ( power(A)
& semiring_0(A) )
=> ! [N: nat] :
( ( ( N = zero_zero(nat) )
=> ( power_power(A,zero_zero(A),N) = one_one(A) ) )
& ( ( N != zero_zero(nat) )
=> ( power_power(A,zero_zero(A),N) = zero_zero(A) ) ) ) ) ).
tff(fact_41_comm__semiring__1__class_Onormalizing__semiring__rules_I32_J,axiom,
! [A: $tType] :
( comm_semiring_1(A)
=> ! [X: A] : ( power_power(A,X,zero_zero(nat)) = one_one(A) ) ) ).
tff(fact_42_sgn__sgn,axiom,
! [A: $tType] :
( linordered_idom(A)
=> ! [A1: A] : ( sgn_sgn(A,sgn_sgn(A,A1)) = sgn_sgn(A,A1) ) ) ).
tff(fact_43_Nats__induct,axiom,
! [A: $tType] :
( semiring_1(A)
=> ! [P1: fun(A,bool),X2: A] :
( member(A,X2,semiring_1_Nats(A))
=> ( ! [N2: nat] : pp(aa(A,bool,P1,semiring_1_of_nat(A,N2)))
=> pp(aa(A,bool,P1,X2)) ) ) ) ).
tff(fact_44_Nats__cases,axiom,
! [A: $tType] :
( semiring_1(A)
=> ! [X2: A] :
( member(A,X2,semiring_1_Nats(A))
=> ~ ! [N2: nat] : ( X2 != semiring_1_of_nat(A,N2) ) ) ) ).
tff(fact_45_sgn__0__0,axiom,
! [A: $tType] :
( linordered_idom(A)
=> ! [A3: A] :
( ( sgn_sgn(A,A3) = zero_zero(A) )
<=> ( A3 = zero_zero(A) ) ) ) ).
tff(fact_46_int__power,axiom,
! [N: nat,M1: nat] : ( semiring_1_of_nat(int,power_power(nat,M1,N)) = power_power(int,semiring_1_of_nat(int,M1),N) ) ).
tff(fact_47_zpower__int,axiom,
! [N: nat,M1: nat] : ( power_power(int,semiring_1_of_nat(int,M1),N) = semiring_1_of_nat(int,power_power(nat,M1,N)) ) ).
tff(fact_48_int__int__eq,axiom,
! [N1: nat,M2: nat] :
( ( semiring_1_of_nat(int,M2) = semiring_1_of_nat(int,N1) )
<=> ( M2 = N1 ) ) ).
tff(fact_49_int__eq__0__conv,axiom,
! [N1: nat] :
( ( semiring_1_of_nat(int,N1) = zero_zero(int) )
<=> ( N1 = zero_zero(nat) ) ) ).
tff(fact_50_int__0,axiom,
semiring_1_of_nat(int,zero_zero(nat)) = zero_zero(int) ).
tff(fact_51_one__neq__zero,axiom,
! [A: $tType] :
( zero_neq_one(A)
=> ( one_one(A) != zero_zero(A) ) ) ).
tff(fact_52_zero__neq__one,axiom,
! [A: $tType] :
( zero_neq_one(A)
=> ( zero_zero(A) != one_one(A) ) ) ).
tff(fact_53_field__power__not__zero,axiom,
! [A: $tType] :
( ring_11004092258visors(A)
=> ! [N: nat,A1: A] :
( ( A1 != zero_zero(A) )
=> ( power_power(A,A1,N) != zero_zero(A) ) ) ) ).
tff(fact_54_of__nat__power,axiom,
! [A: $tType] :
( semiring_1(A)
=> ! [N: nat,M1: nat] : ( semiring_1_of_nat(A,power_power(nat,M1,N)) = power_power(A,semiring_1_of_nat(A,M1),N) ) ) ).
tff(fact_55_power__one__right,axiom,
! [A: $tType] :
( monoid_mult(A)
=> ! [A1: A] : ( power_power(A,A1,one_one(nat)) = A1 ) ) ).
tff(fact_56_comm__semiring__1__class_Onormalizing__semiring__rules_I33_J,axiom,
! [A: $tType] :
( comm_semiring_1(A)
=> ! [X: A] : ( power_power(A,X,one_one(nat)) = X ) ) ).
tff(fact_57_transfer__int__nat__numerals_I2_J,axiom,
one_one(int) = semiring_1_of_nat(int,one_one(nat)) ).
tff(fact_58_transfer__int__nat__numerals_I1_J,axiom,
zero_zero(int) = semiring_1_of_nat(int,zero_zero(nat)) ).
tff(fact_59_Nat__Transfer_Otransfer__int__nat__functions_I4_J,axiom,
! [N: nat,X: nat] : ( power_power(int,semiring_1_of_nat(int,X),N) = semiring_1_of_nat(int,power_power(nat,X,N)) ) ).
tff(fact_60_Nat__Transfer_Otransfer__int__nat__relations_I1_J,axiom,
! [Y1: nat,X2: nat] :
( ( semiring_1_of_nat(int,X2) = semiring_1_of_nat(int,Y1) )
<=> ( X2 = Y1 ) ) ).
tff(fact_61_int__if__cong,axiom,
! [Y1: nat,X2: nat,P1: bool] :
( ( pp(P1)
=> ( semiring_1_of_nat(int,X2) = semiring_1_of_nat(int,if(nat,P1,X2,Y1)) ) )
& ( ~ pp(P1)
=> ( semiring_1_of_nat(int,Y1) = semiring_1_of_nat(int,if(nat,P1,X2,Y1)) ) ) ) ).
tff(fact_62_power__0__left__number__of,axiom,
! [A: $tType] :
( ( power(A)
& semiring_0(A) )
=> ! [W: int] :
( ( ( number_number_of(nat,W) = zero_zero(nat) )
=> ( power_power(A,zero_zero(A),number_number_of(nat,W)) = one_one(A) ) )
& ( ( number_number_of(nat,W) != zero_zero(nat) )
=> ( power_power(A,zero_zero(A),number_number_of(nat,W)) = zero_zero(A) ) ) ) ) ).
tff(fact_63_int__le__0__conv,axiom,
! [N1: nat] :
( ord_less_eq(int,semiring_1_of_nat(int,N1),zero_zero(int))
<=> ( N1 = zero_zero(nat) ) ) ).
tff(fact_64_transfer__morphismI,axiom,
! [B1: $tType,A: $tType,A2: fun(A,bool),F: fun(A,B1)] : nat_tr1645093318rphism(A,B1,F,A2) ).
tff(fact_65_eq__number__of,axiom,
! [A: $tType] :
( ( number_ring(A)
& ring_char_0(A) )
=> ! [Y1: int,X2: int] :
( ( number_number_of(A,X2) = number_number_of(A,Y1) )
<=> ( X2 = Y1 ) ) ) ).
tff(fact_66_of__nat__le__iff,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [N1: nat,M2: nat] :
( ord_less_eq(A,semiring_1_of_nat(A,M2),semiring_1_of_nat(A,N1))
<=> ord_less_eq(nat,M2,N1) ) ) ).
tff(fact_67_le__number__of,axiom,
! [A: $tType] :
( ( number_ring(A)
& linordered_idom(A) )
=> ! [Y1: int,X2: int] :
( ord_less_eq(A,number_number_of(A,X2),number_number_of(A,Y1))
<=> ord_less_eq(int,X2,Y1) ) ) ).
tff(fact_68_power__eq__0__iff__number__of,axiom,
! [A: $tType] :
( ( power(A)
& mult_zero(A)
& no_zero_divisors(A)
& zero_neq_one(A) )
=> ! [W1: int,A3: A] :
( ( power_power(A,A3,number_number_of(nat,W1)) = zero_zero(A) )
<=> ( ( A3 = zero_zero(A) )
& ( number_number_of(nat,W1) != zero_zero(nat) ) ) ) ) ).
tff(fact_69_Nat__Transfer_Otransfer__nat__int__function__closures_I5_J,axiom,
ord_less_eq(int,zero_zero(int),zero_zero(int)) ).
tff(fact_70_power__increasing,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [A1: A,N3: nat,N: nat] :
( ord_less_eq(nat,N,N3)
=> ( ord_less_eq(A,one_one(A),A1)
=> ord_less_eq(A,power_power(A,A1,N),power_power(A,A1,N3)) ) ) ) ).
tff(fact_71_transfer__morphism__def,axiom,
! [B1: $tType,A: $tType,A2: fun(A,bool),F: fun(A,B1)] : nat_tr1645093318rphism(A,B1,F,A2) ).
tff(fact_72_mem__def,axiom,
! [A: $tType,A2: fun(A,bool),X2: A] :
( member(A,X2,A2)
<=> pp(aa(A,bool,A2,X2)) ) ).
tff(fact_73_power__decreasing,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [A1: A,N3: nat,N: nat] :
( ord_less_eq(nat,N,N3)
=> ( ord_less_eq(A,zero_zero(A),A1)
=> ( ord_less_eq(A,A1,one_one(A))
=> ord_less_eq(A,power_power(A,A1,N3),power_power(A,A1,N)) ) ) ) ) ).
tff(fact_74_number__of__reorient,axiom,
! [A: $tType] :
( number(A)
=> ! [X2: A,W1: int] :
( ( number_number_of(A,W1) = X2 )
<=> ( X2 = number_number_of(A,W1) ) ) ) ).
tff(fact_75_zero__le__one,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ord_less_eq(A,zero_zero(A),one_one(A)) ) ).
tff(fact_76_not__one__le__zero,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ~ ord_less_eq(A,one_one(A),zero_zero(A)) ) ).
tff(fact_77_power__mono,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [N: nat,B: A,A1: A] :
( ord_less_eq(A,A1,B)
=> ( ord_less_eq(A,zero_zero(A),A1)
=> ord_less_eq(A,power_power(A,A1,N),power_power(A,B,N)) ) ) ) ).
tff(fact_78_zero__le__power,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [N: nat,A1: A] :
( ord_less_eq(A,zero_zero(A),A1)
=> ord_less_eq(A,zero_zero(A),power_power(A,A1,N)) ) ) ).
tff(fact_79_number__of__int,axiom,
! [A: $tType] :
( number_semiring(A)
=> ! [N: nat] : ( number_number_of(A,semiring_1_of_nat(int,N)) = semiring_1_of_nat(A,N) ) ) ).
tff(fact_80_one__le__power,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [N: nat,A1: A] :
( ord_less_eq(A,one_one(A),A1)
=> ord_less_eq(A,one_one(A),power_power(A,A1,N)) ) ) ).
tff(fact_81_of__nat__0__le__iff,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [N: nat] : ord_less_eq(A,zero_zero(A),semiring_1_of_nat(A,N)) ) ).
tff(fact_82_zero__le__imp__of__nat,axiom,
! [A: $tType] :
( linordered_semidom(A)
=> ! [M1: nat] : ord_less_eq(A,zero_zero(A),semiring_1_of_nat(A,M1)) ) ).
tff(fact_83_Nat__Transfer_Otransfer__nat__int__function__closures_I6_J,axiom,
ord_less_eq(int,zero_zero(int),one_one(int)) ).
tff(fact_84_transfer__int__nat__quantifiers_I1_J,axiom,
! [P1: fun(int,bool)] :
( ! [X1: int] :
( ord_less_eq(int,zero_zero(int),X1)
=> pp(aa(int,bool,P1,X1)) )
<=> ! [X1: nat] : pp(aa(int,bool,P1,semiring_1_of_nat(int,X1))) ) ).
tff(fact_85_transfer__int__nat__quantifiers_I2_J,axiom,
! [P1: fun(int,bool)] :
( ? [X1: int] :
( ord_less_eq(int,zero_zero(int),X1)
& pp(aa(int,bool,P1,X1)) )
<=> ? [X1: nat] : pp(aa(int,bool,P1,semiring_1_of_nat(int,X1))) ) ).
tff(fact_86_Nat__Transfer_Otransfer__nat__int__function__closures_I9_J,axiom,
! [Z: nat] : ord_less_eq(int,zero_zero(int),semiring_1_of_nat(int,Z)) ).
tff(fact_87_zero__zle__int,axiom,
! [N: nat] : ord_less_eq(int,zero_zero(int),semiring_1_of_nat(int,N)) ).
tff(fact_88_Nat__Transfer_Otransfer__nat__int__function__closures_I4_J,axiom,
! [N: nat,X: int] :
( ord_less_eq(int,zero_zero(int),X)
=> ord_less_eq(int,zero_zero(int),power_power(int,X,N)) ) ).
tff(fact_89_of__nat__number__of__lemma,axiom,
! [A: $tType] :
( number_semiring(A)
=> ! [V: int] :
( ( ord_less_eq(int,zero_zero(int),number_number_of(int,V))
=> ( semiring_1_of_nat(A,number_number_of(nat,V)) = number_number_of(A,V) ) )
& ( ~ ord_less_eq(int,zero_zero(int),number_number_of(int,V))
=> ( semiring_1_of_nat(A,number_number_of(nat,V)) = zero_zero(A) ) ) ) ) ).
tff(fact_90_zero__le__imp__eq__int,axiom,
! [K: int] :
( ord_less_eq(int,zero_zero(int),K)
=> ? [N2: nat] : ( K = semiring_1_of_nat(int,N2) ) ) ).
tff(fact_91_nonneg__eq__int,axiom,
! [Z: int] :
( ord_less_eq(int,zero_zero(int),Z)
=> ~ ! [M: nat] : ( Z != semiring_1_of_nat(int,M) ) ) ).
tff(fact_92_complex__cnj__number__of,axiom,
! [W: int] : ( cnj(number_number_of(complex,W)) = number_number_of(complex,W) ) ).
tff(fact_93_le0,axiom,
! [N: nat] : ord_less_eq(nat,zero_zero(nat),N) ).
tff(fact_94_less__eq__nat_Osimps_I1_J,axiom,
! [N: nat] : ord_less_eq(nat,zero_zero(nat),N) ).
tff(fact_95_le__0__eq,axiom,
! [N1: nat] :
( ord_less_eq(nat,N1,zero_zero(nat))
<=> ( N1 = zero_zero(nat) ) ) ).
tff(fact_96_le__refl,axiom,
! [N: nat] : ord_less_eq(nat,N,N) ).
%----Arities (54)
tff(arity_Int_Oint___Rings_Oring__1__no__zero__divisors,axiom,
ring_11004092258visors(int) ).
tff(arity_Int_Oint___Rings_Olinordered__semidom,axiom,
linordered_semidom(int) ).
tff(arity_Int_Oint___Rings_Ono__zero__divisors,axiom,
no_zero_divisors(int) ).
tff(arity_Int_Oint___Rings_Olinordered__idom,axiom,
linordered_idom(int) ).
tff(arity_Int_Oint___Rings_Ocomm__semiring__1,axiom,
comm_semiring_1(int) ).
tff(arity_Int_Oint___Nat_Osemiring__char__0,axiom,
semiring_char_0(int) ).
tff(arity_Int_Oint___Int_Onumber__semiring,axiom,
number_semiring(int) ).
tff(arity_Int_Oint___Groups_Oab__group__add,axiom,
ab_group_add(int) ).
tff(arity_Int_Oint___Rings_Ozero__neq__one,axiom,
zero_neq_one(int) ).
tff(arity_Int_Oint___Groups_Omonoid__mult,axiom,
monoid_mult(int) ).
tff(arity_Int_Oint___Rings_Osemiring__1,axiom,
semiring_1(int) ).
tff(arity_Int_Oint___Rings_Osemiring__0,axiom,
semiring_0(int) ).
tff(arity_Int_Oint___Rings_Omult__zero,axiom,
mult_zero(int) ).
tff(arity_Int_Oint___Int_Oring__char__0,axiom,
ring_char_0(int) ).
tff(arity_Int_Oint___Int_Onumber__ring,axiom,
number_ring(int) ).
tff(arity_Int_Oint___Groups_Osgn__if,axiom,
sgn_if(int) ).
tff(arity_Int_Oint___Power_Opower,axiom,
power(int) ).
tff(arity_Int_Oint___Groups_Ozero,axiom,
zero(int) ).
tff(arity_Int_Oint___Int_Onumber,axiom,
number(int) ).
tff(arity_Int_Oint___Groups_Oone,axiom,
one(int) ).
tff(arity_Nat_Onat___Rings_Olinordered__semidom,axiom,
linordered_semidom(nat) ).
tff(arity_Nat_Onat___Rings_Ono__zero__divisors,axiom,
no_zero_divisors(nat) ).
tff(arity_Nat_Onat___Rings_Ocomm__semiring__1,axiom,
comm_semiring_1(nat) ).
tff(arity_Nat_Onat___Nat_Osemiring__char__0,axiom,
semiring_char_0(nat) ).
tff(arity_Nat_Onat___Int_Onumber__semiring,axiom,
number_semiring(nat) ).
tff(arity_Nat_Onat___Rings_Ozero__neq__one,axiom,
zero_neq_one(nat) ).
tff(arity_Nat_Onat___Groups_Omonoid__mult,axiom,
monoid_mult(nat) ).
tff(arity_Nat_Onat___Rings_Osemiring__1,axiom,
semiring_1(nat) ).
tff(arity_Nat_Onat___Rings_Osemiring__0,axiom,
semiring_0(nat) ).
tff(arity_Nat_Onat___Rings_Omult__zero,axiom,
mult_zero(nat) ).
tff(arity_Nat_Onat___Power_Opower,axiom,
power(nat) ).
tff(arity_Nat_Onat___Groups_Ozero,axiom,
zero(nat) ).
tff(arity_Nat_Onat___Int_Onumber,axiom,
number(nat) ).
tff(arity_Nat_Onat___Groups_Oone,axiom,
one(nat) ).
tff(arity_Complex_Ocomplex___RealVector_Oreal__normed__algebra__1,axiom,
real_n2089651433ebra_1(complex) ).
tff(arity_Complex_Ocomplex___Rings_Oring__1__no__zero__divisors,axiom,
ring_11004092258visors(complex) ).
tff(arity_Complex_Ocomplex___RealVector_Oreal__normed__vector,axiom,
real_normed_vector(complex) ).
tff(arity_Complex_Ocomplex___Rings_Ono__zero__divisors,axiom,
no_zero_divisors(complex) ).
tff(arity_Complex_Ocomplex___Rings_Ocomm__semiring__1,axiom,
comm_semiring_1(complex) ).
tff(arity_Complex_Ocomplex___Nat_Osemiring__char__0,axiom,
semiring_char_0(complex) ).
tff(arity_Complex_Ocomplex___Int_Onumber__semiring,axiom,
number_semiring(complex) ).
tff(arity_Complex_Ocomplex___Groups_Oab__group__add,axiom,
ab_group_add(complex) ).
tff(arity_Complex_Ocomplex___Rings_Ozero__neq__one,axiom,
zero_neq_one(complex) ).
tff(arity_Complex_Ocomplex___Groups_Omonoid__mult,axiom,
monoid_mult(complex) ).
tff(arity_Complex_Ocomplex___Rings_Osemiring__1,axiom,
semiring_1(complex) ).
tff(arity_Complex_Ocomplex___Rings_Osemiring__0,axiom,
semiring_0(complex) ).
tff(arity_Complex_Ocomplex___Rings_Omult__zero,axiom,
mult_zero(complex) ).
tff(arity_Complex_Ocomplex___Int_Oring__char__0,axiom,
ring_char_0(complex) ).
tff(arity_Complex_Ocomplex___Int_Onumber__ring,axiom,
number_ring(complex) ).
tff(arity_Complex_Ocomplex___Fields_Ofield,axiom,
field(complex) ).
tff(arity_Complex_Ocomplex___Power_Opower,axiom,
power(complex) ).
tff(arity_Complex_Ocomplex___Groups_Ozero,axiom,
zero(complex) ).
tff(arity_Complex_Ocomplex___Int_Onumber,axiom,
number(complex) ).
tff(arity_Complex_Ocomplex___Groups_Oone,axiom,
one(complex) ).
%----Helper facts (5)
tff(help_If_1_1_T,axiom,
! [A: $tType,Y: A,X: A] : ( if(A,fTrue,X,Y) = X ) ).
tff(help_If_2_1_T,axiom,
! [A: $tType,Y: A,X: A] : ( if(A,fFalse,X,Y) = Y ) ).
tff(help_If_3_1_T,axiom,
! [P: bool] :
( ( P = fTrue )
| ( P = fFalse ) ) ).
tff(help_pp_1_1_U,axiom,
~ pp(fFalse) ).
tff(help_pp_2_1_U,axiom,
pp(fTrue) ).
%----Conjectures (1)
tff(conj_0,conjecture,
fFT_Mirabelle_root(one_one(nat)) = one_one(complex) ).
%------------------------------------------------------------------------------